1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
# -*- coding: utf-8 -*-
import os
from flask import Flask, request, redirect, url_for, flash, session
from utils import templated, login_required, encrypt_password, decrypt_password, login_user, logout_user
from forms import RegisterForm, LoginForm
app = Flask(__name__)
app.config.from_object('default_settings')
if 'SPLINE_ACCOUNT_WEB_SETTINGS' in os.environ:
app.config.from_envvar('SPLINE_ACCOUNT_WEB_SETTINGS')
@app.route('/', methods=['GET', 'POST'])
@templated('index.html')
def index():
form = LoginForm(request.form)
if request.method == 'POST' and form.validate():
if login_user(form.username.data, form.password.data):
flash(u'Erfolgreich eingeloggt (%s)' % session['username'])
return redirect(url_for('index'))
else:
flash(u'Ungültiger Benutzername und/oder Passwort', 'error')
return {'form': form}
@app.route('/register', methods=['GET', 'POST'])
@templated('register.html')
def register():
form = RegisterForm(request.form)
if request.method == 'POST' and form.validate():
username = form.username.data
mail = form.mail.data
password = form.password.data
return '<h1>501 Not Implemented</h1>'
return {'form': form}
@app.route('/settings')
@templated('settings.html')
@login_required
def settings():
return {}
@app.route('/logout')
def logout():
logout_user()
return redirect(url_for('index'))
@app.route('/debug')
def debug():
raise Exception()
if __name__ == '__main__':
app.run(debug=True)
# wir brauchen:
# registrieren
# login
# passwort ändern (master-passwort, einzelne)
# email ändern
# später:
# account löschen
# openid-provider (ggf mehr Details: Realname, Zeitzone, ...)
|