]> ToastFreeware Gitweb - philipp/winterrodeln/wradmin.git/blob - wradmin/__init__.py
Require login for bericht.
[philipp/winterrodeln/wradmin.git] / wradmin / __init__.py
1 from flask import Flask, send_from_directory, abort, g, render_template, request, redirect, url_for, flash
2 from sqlalchemy.engine import create_engine
3 import wradmin.model
4 import wradmin.template_helper
5 from wradmin.controllers.rodelbahn import RodelbahnController
6 from wradmin.controllers.gasthaus import GasthausController
7 from wradmin.controllers.bericht import BerichtController
8 from wradmin.controllers.coordtool import CoordtoolController
9 from wradmin.auth import password_is_correct
10 from wradmin.auth.forms import LoginForm
11 from flask_login import LoginManager, current_user, login_required, login_user, logout_user
12
13
14 app = Flask(__name__)
15 app.config.from_envvar('WRADMIN_SETTINGS')
16 wradmin.model.init_model(create_engine(app.config['DATABASE_URI']))
17 app.jinja_env.globals.update(h=wradmin.template_helper.PylonsHelper())
18 login_manager = LoginManager(app)
19 login_manager.login_view = "login"
20
21
22 @app.before_request
23 def _before_request():
24     g.user = current_user
25
26
27 @app.teardown_appcontext
28 def remove_db_session(error):
29     """Removes the database session at the end of the request."""
30     wradmin.model.meta.Session.remove()
31
32
33 @app.route("/")
34 def index():
35     return render_template('index.html')
36
37
38 @app.route("/rodelbahn/list")
39 def rodelbahn_list():
40     return RodelbahnController().list()
41
42
43 @app.route("/rodelbahn/view/<int:id>")
44 def rodelbahn_view(id):
45     return RodelbahnController().view(id)
46
47
48 @app.route("/rodelbahn/update")
49 def rodelbahn_update():
50     return RodelbahnController().update()
51
52
53 @app.route("/rodelbahn/update_regioncache")
54 def rodelbahn_update_regioncache():
55     return RodelbahnController().update_regioncache()
56
57 @app.route("/rodelbahn/update_mapcache")
58 def rodelbahn_update_mapcache():
59     return RodelbahnController().update_mapcache()
60
61 @app.route("/bericht/list")
62 @login_required
63 def bericht_list():
64     return BerichtController().list()
65
66
67 @app.route("/bericht/view/<int:id>")
68 @login_required
69 def bericht_view(id):
70     return BerichtController().view(id)
71
72
73 @app.route("/bericht/change_date_invalid/<int:id>", methods=['POST'])
74 @login_required
75 def bericht_change_date_invalid(id):
76     return BerichtController().change_date_invalid(id)
77
78
79 @app.route("/bericht/update_reportcache")
80 def bericht_update_reportcache():
81     return BerichtController().update_reportcache()
82
83
84 @app.route("/gasthaus/list")
85 def gasthaus_list():
86     return GasthausController().list()
87
88
89 @app.route("/gasthaus/view/<int:id>")
90 def gasthaus_view(id):
91     return GasthausController().view(id)
92
93
94 @app.route("/gasthaus/update")
95 def gasthaus_update():
96     return GasthausController().update()
97
98
99 @app.route("/coordtool/index")
100 def coordtool_index():
101     return CoordtoolController().index()
102
103
104 @app.route("/coordtool/convert", methods=['POST'])
105 def coordtool_convert():
106     return CoordtoolController().convert()
107
108
109 @app.route("/login", methods=['GET', 'POST'])
110 def login():
111     form = LoginForm()
112     if form.validate_on_submit():
113         user = wradmin.model.meta.Session.query(wradmin.model.MwUser).filter_by(user_name=form.user_name.data).first()
114         if user is not None and password_is_correct(form.password.data, user.user_password.decode()):
115             login_user(user, form.remember_me.data)
116             next = request.args.get('next')
117             if next is None or not next.startswith('/'):
118                 next = url_for('index')
119             flash('Sie sind nun angemeldet.')
120             return redirect(next)
121         flash('Ungülter Benutzername oder ungültiges Passwort.')
122     return render_template('auth/login.html', form=form)
123
124
125 @app.route("/logout")
126 def logout():
127     logout_user()
128     flash('Sie wurden ausgeloggt.')
129     return redirect(url_for('index'))
130
131
132 @login_manager.user_loader
133 def user_loader(user_id):
134     return wradmin.model.meta.Session.query(wradmin.model.MwUser).get(user_id)