diff options
author | anoop | 2010-02-04 22:14:34 +0530 |
---|---|---|
committer | anoop | 2010-02-04 22:14:34 +0530 |
commit | f9d063ba2c95fcb836437fbba60b2e5510e75d47 (patch) | |
tree | 9fbd66837c8ef6913cce03339b8b887d604f7d07 | |
parent | 6abcf4483cdfed7da478c626f48d22bee8448047 (diff) | |
download | pytask-f9d063ba2c95fcb836437fbba60b2e5510e75d47.tar.gz pytask-f9d063ba2c95fcb836437fbba60b2e5510e75d47.tar.bz2 pytask-f9d063ba2c95fcb836437fbba60b2e5510e75d47.zip |
added views, templates for register, login, logout user.
-rw-r--r-- | taskapp/forms/user.py | 16 | ||||
-rw-r--r-- | taskapp/views/users.py | 53 | ||||
-rw-r--r-- | templates/user/login.html | 17 | ||||
-rw-r--r-- | templates/user/register.html | 17 | ||||
-rw-r--r-- | urls.py | 7 |
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 %} @@ -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) ) |