blob: 41dfd19c14ace4f2e86ff07944403c4f31fdc3fc (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
from pyramid.view import view_config
from pyramid.httpexceptions import HTTPFound
from pyramid.security import remember, forget
from pyramid.i18n import TranslationString as _
from sqlalchemy import select
from sqlalchemy.exc import NoResultFound
from .. import models
from ..models.user import PasswordMismatch
@view_config(route_name='login', renderer='fietsboek:templates/login.jinja2', request_method='GET')
def login(request):
return {}
@view_config(route_name='login', request_method='POST')
def do_login(request):
query = select(models.User).filter_by(email=request.params['email'])
try:
user = request.dbsession.execute(query).scalar_one()
user.check_password(request.params['password'])
except (NoResultFound, PasswordMismatch):
request.session.flash(request.localizer.translate(_('flash.invalid_credentials')))
return HTTPFound(request.route_url('login'))
request.session.flash(request.localizer.translate(_('flash.logged_in')))
headers = remember(request, str(user.id))
return HTTPFound('/', headers=headers)
@view_config(route_name='logout')
def logout(request):
request.session.flash(request.localizer.translate(_('flash.logged_out')))
headers = forget(request)
return HTTPFound('/', headers=headers)
|