|
@@ -3,6 +3,7 @@
|
|
|
|
|
|
from flask import Flask, request, session, g, redirect, url_for, abort, \
|
|
|
render_template, flash
|
|
|
+from flaskext.openid import OpenID
|
|
|
import sqlite3
|
|
|
from datetime import date, time, timedelta, datetime
|
|
|
import time
|
|
@@ -21,12 +22,14 @@ DEBUG = True
|
|
|
TITLE = u"Cavote FFDN"
|
|
|
EMAIL = '"' + TITLE + '"' + ' <' + u"cavote@ffdn.org" + '>'
|
|
|
VERSION = "cavote 0.1.1"
|
|
|
-SMTP_SERVER = "10.33.33.30"
|
|
|
+SMTP_SERVER = "127.0.0.1"
|
|
|
PATTERNS = {u'Oui/Non': [u'Oui', u'Non'], u'Oui/Non/Blanc': [u'Oui', u'Non', u'Blanc'], u'Oui/Non/Peut-être': [u'Oui', u'Non', u'Peut-être']}
|
|
|
|
|
|
app = Flask(__name__)
|
|
|
app.config.from_object(__name__)
|
|
|
|
|
|
+oid = OpenID(app)
|
|
|
+
|
|
|
def connect_db():
|
|
|
return sqlite3.connect(app.config['DATABASE'])
|
|
|
|
|
@@ -98,11 +101,15 @@ def get_userid():
|
|
|
return user.get('id')
|
|
|
|
|
|
@app.route('/login', methods=['GET', 'POST'])
|
|
|
+@oid.loginhandler
|
|
|
def login():
|
|
|
if request.method == 'POST':
|
|
|
user = valid_login(request.form['username'], request.form['password'])
|
|
|
if user is None:
|
|
|
- flash(u'Email ou mot de passe invalide.', 'error')
|
|
|
+ if request.form['openid']:
|
|
|
+ return oid.try_login(request.form['openid'], ask_for=['email', 'fullname', 'nickname'])
|
|
|
+ else:
|
|
|
+ flash(u'Email ou mot de passe invalide.', 'error')
|
|
|
else:
|
|
|
connect_user(user)
|
|
|
flash(u'Vous êtes connecté. Bienvenue, %s !' % user['name'], 'success')
|
|
@@ -111,6 +118,16 @@ def login():
|
|
|
return redirect(url_for('home'))
|
|
|
return render_template('login.html')
|
|
|
|
|
|
+@oid.after_login
|
|
|
+def create_or_login(resp):
|
|
|
+ openid_url = resp.identity_url
|
|
|
+ user = query_db('select * from users where openid = ?', [openid_url], one=True)
|
|
|
+ if user is not None:
|
|
|
+ flash(u'Successfully signed in')
|
|
|
+ connect_user(user)
|
|
|
+ return redirect(oid.get_next_url())
|
|
|
+ return redirect(url_for('home'))
|
|
|
+
|
|
|
@app.route('/logout')
|
|
|
def logout():
|
|
|
disconnect_user()
|
|
@@ -252,8 +269,9 @@ def admin_user_add():
|
|
|
if 'admin' in request.form.keys():
|
|
|
admin = 1
|
|
|
key = 'v%s' % keygen()
|
|
|
- g.db.execute('insert into users (email, name, organization, password, is_admin, key) values (?, ?, ?, ?, ?, ?)',
|
|
|
+ g.db.execute('insert into users (email, openid, name, organization, password, is_admin, key) values (?, ?, ?, ?, ?, ?, ?)',
|
|
|
[request.form['email'],
|
|
|
+ request.form['openid'],
|
|
|
request.form['username'],
|
|
|
request.form['organization'],
|
|
|
'', admin, key])
|