1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- from django.contrib.auth import update_session_auth_hash
- from django.db import IntegrityError
- from django.shortcuts import render
- from django.utils.translation import ugettext as _
- from misago.users.credentialchange import read_new_credential
- from misago.users.decorators import deny_guests
- from misago.users.pages import usercp
- @deny_guests
- def index(request, *args, **kwargs):
- user_options = []
- for section in usercp.get_sections(request):
- user_options.append({
- 'name': str(section['name']),
- 'icon': section['icon'],
- 'component': section['component'],
- })
- request.frontend_context.update({'USER_OPTIONS': user_options})
- return render(request, 'misago/options/noscript.html')
- class ChangeError(Exception):
- pass
- def confirm_change_view(f):
- @deny_guests
- def decorator(request, token):
- try:
- return f(request, token)
- except ChangeError:
- return render(request, 'misago/options/credentials_error.html', status=400)
- return decorator
- @confirm_change_view
- def confirm_email_change(request, token):
- new_credential = read_new_credential(request, 'email', token)
- if not new_credential:
- raise ChangeError()
- try:
- request.user.set_email(new_credential)
- request.user.save(update_fields=['email', 'email_hash'])
- except IntegrityError:
- raise ChangeError()
- message = _("%(user)s, your e-mail has been changed.")
- return render(
- request, 'misago/options/credentials_changed.html', {
- 'message': message % {
- 'user': request.user.username,
- },
- }
- )
- @confirm_change_view
- def confirm_password_change(request, token):
- new_credential = read_new_credential(request, 'password', token)
- if not new_credential:
- raise ChangeError()
- request.user.set_password(new_credential)
- update_session_auth_hash(request, request.user)
- request.user.save(update_fields=['password'])
- message = _("%(user)s, your password has been changed.")
- return render(
- request, 'misago/options/credentials_changed.html', {
- 'message': message % {
- 'user': request.user.username,
- },
- }
- )
|