Exemple #1
0
def login():
    if g.user is not None and g.user.is_authenticated():
        # TODO: Already logged in. Move to a default after-login page.
        # For now asks to logout
        return 'Now logged in <a href="logout">Logout</a>'
    form = LoginForm()
    if form.validate_on_submit():
        return oid.try_login(form.openid.data, ask_for = ['nickname', 'email'])
    return render_template('/login.html', form = form)
Exemple #2
0
def login():
    form = LoginForm(request.form)
    if form.validate_on_submit():
        user = User.get_or_none(User.email_address == form.email_address.data)
        if user and check_password_hash(user.password, form.password.data):
            Log.insert(user_id=user.id, action='LOGIN').execute()
            session['user'] = model_to_dict(user)

            flash("Welcome back, {}!".format(user.first_name))
            return redirect(request.args.get('next', url_for('main.index')))
    return render_template('main/login.html', form=form)
Exemple #3
0
def login():
    if current_user.is_authenticated:
        return redirect(url_for('home'))

    form = LoginForm()
    if form.validate_on_submit():
        user = User.query.filter_by(email=form.email.data.lower()).first()
        if user and bcrypt.check_password_hash(user.password,
                                               form.password.data):
            login_user(user, remember=form.remember.data)
            next_page = request.args.get('next')
            return redirect(next_page) if next_page else redirect(
                url_for('home'))
        else:
            flash('Login failed, please check email and password.', 'danger')
    return render_template('login.html', title='Login', form=form)
Exemple #4
0
def login():
    if not User.query.first():
        return redirect(url_for('auth.register'))

    if current_user.is_authenticated:
        return redirect(url_for('messages.read'))

    form = LoginForm()
    if form.validate_on_submit():
        user = User.query.filter_by(username=form.username.data).first()

        if (user is None) or (not check_password_hash(user.password, form.password.data)):
            flash('Invalid username or password')
            return redirect(url_for('auth.login'))

        login_user(user, remember=form.remember_me.data)
        next_page = request.args.get('next')
        if not next_page or url_parse(next_page).netloc != '':
            next_page = url_for('messages.read')
        return redirect(next_page)
    return render_template('auth/login.html', title='Login', form=form)
Exemple #5
0
def login():
    """Login form, also includes registration link if reg is open."""
    if current_user.is_authenticated:
        return redirect(url_for("index"))
    form = LoginForm()

    # @TODO Refactor this around content model
    if form.validate_on_submit():
        user = User.query.filter_by(username=form.username.data).first()

        if user is None or not user.check_password(form.password.data):
            flash("Invalid username or password")
            return redirect(url_for("login"))
        login_user(user, remember=form.remember_me.data)
        current_user.last_login = datetime.utcnow()
        db.session.commit()

        next_page = request.args.get("next")
        if not next_page or url_parse(next_page).netloc != "":
            next_page = url_for("index")

        return redirect(next_page)

    return render_template("login.html", title="Sign In", form=form)