summaryrefslogtreecommitdiffstats
path: root/app.py
blob: 46ca6822315da3af6b9a222bd312c47f6d767eac (plain)
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
72
73
74
75
76
77
78
79
80
81
# -*- coding: utf-8 -*-

import flaskext_compat
flaskext_compat.activate()

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, SettingsForm


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', methods=['GET', 'POST'])
@templated('settings.html')
@login_required
def settings():
    form = SettingsForm(request.form, mail='mail aus ldap #TODO')
    if request.method == 'POST' and form.validate():
        flash(u'Gespeichert. Nicht.')
        return redirect(url_for('index'))

    return {'form': form}


@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, ...)