50 lines
1.6 KiB
Python
50 lines
1.6 KiB
Python
from flask import Module, render_template, session, redirect, url_for, \
|
|
request, flash, g, Response
|
|
from flask_website import openid_auth
|
|
from flask_website.database import db_session, User
|
|
|
|
general = Module(__name__)
|
|
|
|
|
|
@general.route('/')
|
|
def index():
|
|
return render_template('general/index.html')
|
|
|
|
|
|
@general.route('/logout/')
|
|
def logout():
|
|
if 'openid' in session:
|
|
flash(u'Logged out')
|
|
del session['openid']
|
|
return redirect(request.referrer or url_for('general.index'))
|
|
|
|
|
|
@general.route('/login/', methods=['GET', 'POST'])
|
|
def login():
|
|
if g.user is not None:
|
|
return redirect(url_for('general.index'))
|
|
rv = openid_auth.check_return_from_provider()
|
|
if rv is not None:
|
|
return rv
|
|
if request.method == 'POST':
|
|
openid = request.values.get('openid')
|
|
if openid:
|
|
return openid_auth.login(openid)
|
|
return render_template('general/login.html')
|
|
|
|
|
|
@general.route('/first-login/', methods=['GET', 'POST'])
|
|
def first_login():
|
|
if g.user is not None or 'openid' not in session:
|
|
return redirect(url_for('login'))
|
|
if request.method == 'POST':
|
|
if 'cancel' in request.form:
|
|
del session['openid']
|
|
flash(u'Login was aborted')
|
|
return redirect(url_for('general.login'))
|
|
db_session.add(User(request.form['name'], session['openid']))
|
|
db_session.commit()
|
|
flash(u'Successfully created profile and logged in')
|
|
return openid_auth.redirect_back()
|
|
return render_template('general/first_login.html',
|
|
openid=session['openid'])
|