aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/auth/views.py
diff options
context:
space:
mode:
Diffstat (limited to 'mediagoblin/auth/views.py')
-rw-r--r--mediagoblin/auth/views.py21
1 files changed, 17 insertions, 4 deletions
diff --git a/mediagoblin/auth/views.py b/mediagoblin/auth/views.py
index cbf7c816..16588a5b 100644
--- a/mediagoblin/auth/views.py
+++ b/mediagoblin/auth/views.py
@@ -69,8 +69,15 @@ def register_success(request):
def login(request):
+ """
+ Mediagoblin login view.
+
+ If you provide the POST with 'next', it'll redirect to that view.
+ """
login_form = auth_forms.LoginForm(request.POST)
+ login_failed = False
+
if request.method == 'POST' and login_form.validate():
#try:
user = request.db.User.find_one(
@@ -79,15 +86,19 @@ def login(request):
if user.check_login(request.POST['password']):
# set up login in session
request.session['user_id'] = unicode(user['_id'])
+ request.session.save()
- import pdb
- pdb.set_trace()
-
+ if request.POST.has_key('next'):
+ return exc.HTTPFound(location=request.POST['next'])
+ else:
+ return exc.HTTPFound(
+ location=request.urlgen("index"))
else:
# Prevent detecting who's on this system by testing login
# attempt timings
auth_lib.fake_login_attempt()
+ login_failed = True
# render
template = request.template_env.get_template(
@@ -95,7 +106,9 @@ def login(request):
return Response(
template.render(
{'request': request,
- 'login_form': login_form}))
+ 'login_form': login_form,
+ 'next': request.GET.get('next') or request.POST.get('next'),
+ 'login_failed': login_failed}))
def logout(request):