Example #1
0
def login(request):
    FORM_TITLE = _('Login')
    localizer = get_localizer(request)
    main = get_renderer(BASE_TEMPLATE).implementation()
    login_form = LoginForm.get_form(localizer)

    login_url = route_url('users.login', request)
    referrer = request.url
    if referrer == login_url:
        referrer = route_url('staff.panel', request)

    b64_caller = request.params.get('caller', None)
    caller = base64.b64decode(b64_caller) if b64_caller is not None else referrer

    if request.method == 'POST':

        controls = request.POST.items()
        try:
            appstruct = login_form.validate(controls)
        except deform.ValidationFailure, e:

            return {'content':e.render(),
                    'main':main,
                    'general_stuff':{'form_title':FORM_TITLE},
                    'user':get_logged_user(request),
                    }
        try:
            user = request.rel_db_session.query(users.User).filter_by(username=appstruct['username']).one()
        except NoResultFound:
            request.session.flash(_("Username doesn't exist."))
        else:
            if SHA256.new(appstruct['password']).hexdigest() == user.password:
                if not user.is_active:
                    request.session.flash(_("The username is not active. Check your email account for the activation instructions."))
                else:
                    headers = remember(request, user.id)
                    return HTTPFound(location=caller, headers=headers)
            else:
                request.session.flash(_("Username/password doesn't match"))
Example #2
0
def login(request):
    FORM_TITLE = _('Login')
    localizer = get_localizer(request)
    main = get_renderer(BASE_TEMPLATE).implementation()
    login_form = LoginForm.get_form(localizer)

    login_url = route_url('users.login', request)
    referrer = request.url
    if referrer == login_url:
        referrer = route_url('staff.panel', request)

    b64_caller = request.params.get('caller', None)
    caller = base64.b64decode(b64_caller) if b64_caller is not None else referrer
    
    if request.method == 'POST':
        
        controls = request.POST.items()
        try:
            appstruct = login_form.validate(controls)
        except deform.ValidationFailure, e:
            
            return {'content':e.render(), 
                    'main':main, 
                    'form_stuff':{'form_title':FORM_TITLE},
                    'user':get_logged_user(request),
                    }
        try:
            user = request.rel_db_session.query(users.User).filter_by(username=appstruct['username']).one()
        except NoResultFound:
            request.session.flash(_("Username doesn't exist."))
        else:
            if SHA256.new(appstruct['password']).hexdigest() == user.password:
                if not user.is_active:
                    request.session.flash(_("The username is not active. Check your email account for the activation instructions."))
                else:
                    headers = remember(request, user.id)
                    return HTTPFound(location=caller, headers=headers)
            else:
                request.session.flash(_("Username/password doesn't match"))             
Example #3
0
def login(request):
    FORM_TITLE = "Login"
    localizer = get_localizer(request)
    main = get_renderer(BASE_TEMPLATE).implementation()
    login_form = LoginForm.get_form(localizer)

    if "submit" in request.POST:

        controls = request.POST.items()
        try:
            appstruct = login_form.validate(controls)
        except deform.ValidationFailure, e:

            return {"content": e.render(), "main": main, "form_title": FORM_TITLE, "user": get_user(request)}
        try:
            user = request.dbsession.query(User).filter_by(username=appstruct["username"]).one()
        except NoResultFound:
            request.session.flash(u"Username doesnot exist.")
            return {
                "content": login_form.render(appstruct),
                "main": main,
                "form_title": FORM_TITLE,
                "user": get_user(request),
            }

        if SHA256.new(appstruct["password"]).hexdigest() == user.password:
            headers = remember(request, user.id)
            return HTTPFound(location="/", headers=headers)
        else:
            request.session.flash(u"Username/password doesnot match.")
            return {
                "content": login_form.render(appstruct),
                "main": main,
                "form_title": FORM_TITLE,
                "user": get_user(request),
            }