52 lines
1.8 KiB
Python
52 lines
1.8 KiB
Python
|
from flask import current_app, render_template, request, redirect, Blueprint, flash, url_for
|
||
|
from realms.modules.auth.local.models import User
|
||
|
from realms.modules.auth.local.forms import LoginForm, RegistrationForm
|
||
|
|
||
|
blueprint = Blueprint('auth.local', __name__)
|
||
|
|
||
|
|
||
|
@blueprint.route("/login/local", methods=['POST'])
|
||
|
def login():
|
||
|
form = LoginForm()
|
||
|
|
||
|
if not form.validate():
|
||
|
flash('Form invalid', 'warning')
|
||
|
return redirect(url_for('auth.login'))
|
||
|
|
||
|
if User.auth(request.form['email'], request.form['password']):
|
||
|
return redirect(request.args.get("next") or url_for(current_app.config['ROOT_ENDPOINT']))
|
||
|
else:
|
||
|
flash('Email or Password Incorrect', 'warning')
|
||
|
return redirect(url_for('auth.login'))
|
||
|
|
||
|
|
||
|
@blueprint.route("/register", methods=['GET', 'POST'])
|
||
|
def register():
|
||
|
|
||
|
if not current_app.config['REGISTRATION_ENABLED']:
|
||
|
flash("Registration is disabled")
|
||
|
return redirect(url_for(current_app.config['ROOT_ENDPOINT']))
|
||
|
|
||
|
form = RegistrationForm()
|
||
|
|
||
|
if request.method == "POST":
|
||
|
|
||
|
if not form.validate():
|
||
|
flash('Form invalid', 'warning')
|
||
|
return redirect(url_for('auth.local.register'))
|
||
|
|
||
|
if User.get_by_username(request.form['username']):
|
||
|
flash('Username is taken', 'warning')
|
||
|
return redirect(url_for('auth.local.register'))
|
||
|
|
||
|
if User.get_by_email(request.form['email']):
|
||
|
flash('Email is taken', 'warning')
|
||
|
return redirect(url_for('auth.local.register'))
|
||
|
|
||
|
User.create(request.form['username'], request.form['email'], request.form['password'])
|
||
|
User.auth(request.form['email'], request.form['password'])
|
||
|
|
||
|
return redirect(request.args.get("next") or url_for(current_app.config['ROOT_ENDPOINT']))
|
||
|
|
||
|
return render_template("auth/register.html", form=form)
|