summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoranoop2010-02-04 22:14:34 +0530
committeranoop2010-02-04 22:14:34 +0530
commitf9d063ba2c95fcb836437fbba60b2e5510e75d47 (patch)
tree9fbd66837c8ef6913cce03339b8b887d604f7d07
parent6abcf4483cdfed7da478c626f48d22bee8448047 (diff)
downloadpytask-f9d063ba2c95fcb836437fbba60b2e5510e75d47.tar.gz
pytask-f9d063ba2c95fcb836437fbba60b2e5510e75d47.tar.bz2
pytask-f9d063ba2c95fcb836437fbba60b2e5510e75d47.zip
added views, templates for register, login, logout user.
-rw-r--r--taskapp/forms/user.py16
-rw-r--r--taskapp/views/users.py53
-rw-r--r--templates/user/login.html17
-rw-r--r--templates/user/register.html17
-rw-r--r--urls.py7
5 files changed, 107 insertions, 3 deletions
diff --git a/taskapp/forms/user.py b/taskapp/forms/user.py
index e69de29..cca8173 100644
--- a/taskapp/forms/user.py
+++ b/taskapp/forms/user.py
@@ -0,0 +1,16 @@
+#!/usr/bin/python2.5
+
+from django import forms
+from pytask.taskapp.models import GENDER_CHOICES
+
+class RegistrationForm(forms.Form):
+ username = forms.CharField(max_length=30, required=True)
+ password = forms.CharField(max_length=60, required=True, widget=forms.PasswordInput)
+ repeat_password = forms.CharField(max_length=60, required=True, widget=forms.PasswordInput)
+ email = forms.EmailField(max_length=30, required=True)
+ gender = forms.ChoiceField(choices=GENDER_CHOICES, required = True)
+ dob = forms.DateField(required=True, help_text = "(YYYY-MM-DD)")
+
+class LoginForm(forms.Form):
+ username = forms.CharField(max_length=30, required=True)
+ password = forms.CharField(max_length=60, required=True, widget=forms.PasswordInput)
diff --git a/taskapp/views/users.py b/taskapp/views/users.py
index d99adfb..ba78e95 100644
--- a/taskapp/views/users.py
+++ b/taskapp/views/users.py
@@ -1,6 +1,10 @@
from django.http import HttpResponse
from django.shortcuts import redirect, render_to_response
from pytask.taskapp.models import Task
+from pytask.taskapp.forms.user import RegistrationForm, LoginForm
+from pytask.taskapp.events.user import createUser
+from django.contrib.auth import login, logout, authenticate
+from django.contrib.auth.models import User
def redirect_to_homepage(request):
""" simply redirect to homepage """
@@ -37,5 +41,52 @@ def homepage(request):
}
return render_to_response('index.html', context)
-
+
+def register(request):
+ """ user registration: gets the user details and create the user and userprofile if data entered is valid"""
+ if request.method == 'POST':
+ form = RegistrationForm(request.POST)
+ if form.is_valid():
+ data = form.cleaned_data
+ if data['password'] == data['repeat_password']:
+ try:
+ if User.objects.get(username__exact = data['username']):
+ errors=['Choose some other username']
+ return render_to_response('user/register.html',{'form':form,'errors':errors})
+ except:
+ u = createUser(username=data['username'], email=data['email'], password=data['password'],dob = data['dob'],gender = data['gender'])
+ return redirect('/accounts/login/')
+ else:
+ errors=['Password do not match']
+ form = RegistrationForm(request.POST)
+ return render_to_response('user/register.html',{'form':form,'errors':errors})#HttpResponse('Password did not match')
+ else:
+ form = RegistrationForm()
+ else:
+ form = RegistrationForm()
+ return render_to_response('user/register.html', {'form': form})
+
+def user_login(request):
+ if request.method == 'POST':
+ username = request.POST['username']
+ password = request.POST['password']
+ user = authenticate(username=username, password=password)
+ if user is not None:
+ if user.is_active:
+ login(request, user)
+ return redirect('/')# Redirect to a success page.
+ else:
+ return HttpResponse('username is not active, please contact the administrator')# Return a 'disabled account' error message
+ else:
+ errors = ['Please check your username and password']
+ form = LoginForm()
+ return render_to_response('user/login.html',{'form':form,'errors':errors})# Return an 'invalid login' error message.
+ return redirect('/')
+ else:
+ form = LoginForm()
+ return render_to_response('user/login.html',{'form': form})
+
+def user_logout(request):
+ logout(request)
+ return HttpResponse('You have logged off successfully!!!')
diff --git a/templates/user/login.html b/templates/user/login.html
new file mode 100644
index 0000000..4e7b933
--- /dev/null
+++ b/templates/user/login.html
@@ -0,0 +1,17 @@
+{% extends 'base.html' %}
+{% block content %}
+<form action="/accounts/login/" method="post">
+ {{ form.as_p }}
+
+{% if errors %}
+ <p style="color: red;">
+ Please correct the error{{ errors|pluralize }} below.
+ {% for i in errors %}
+ <br>{{ i }}
+ {% endfor %}
+ </p>
+{% endif %}
+
+<input type="submit" value="Submit" />
+</form>
+{% endblock %}
diff --git a/templates/user/register.html b/templates/user/register.html
new file mode 100644
index 0000000..9228ac7
--- /dev/null
+++ b/templates/user/register.html
@@ -0,0 +1,17 @@
+{% extends 'base.html' %}
+{% block content %}
+<form action="/accounts/register/" method="post">
+ {{ form.as_p }}
+
+{% if errors %}
+ <p style="color: red;">
+ Please correct the error{{ errors|pluralize }} below.
+ {% for i in errors %}
+ <br>{{ i }}
+ {% endfor %}
+ </p>
+{% endif %}
+
+<input type="submit" value="Submit" />
+</form>
+{% endblock %}
diff --git a/urls.py b/urls.py
index 7d89381..f237544 100644
--- a/urls.py
+++ b/urls.py
@@ -4,7 +4,7 @@ from django.conf.urls.defaults import *
from django.contrib import admin
admin.autodiscover()
-from pytask.taskapp.views.users import redirect_to_homepage, homepage
+from pytask.taskapp.views.users import redirect_to_homepage, homepage, register, user_login, user_logout
from pytask.taskapp.views.tasks import browse_tasks, view_task
urlpatterns = patterns('',
@@ -20,5 +20,8 @@ urlpatterns = patterns('',
(r'^task/view/tid=(\d+)', view_task),
(r'^admin/', include(admin.site.urls)),
-
+
+ (r'^accounts/register/$',register),
+ (r'^accounts/login/$',user_login),
+ (r'^accounts/logout/$',user_logout)
)