]> ToastFreeware Gitweb - philipp/winterrodeln/wradmin.git/blob - wradmin/controllers/rodelbahn.py
Allow to JSON-edit a sledrun.
[philipp/winterrodeln/wradmin.git] / wradmin / controllers / rodelbahn.py
1 from flask import request, abort, redirect, url_for, flash, render_template
2 import paginate
3 import sqlalchemy as sa
4
5 import wrpylib.wrmwmarkup
6 import wrpylib.wrmwcache
7 import wrpylib.mwmarkup
8
9 from wradmin.app import db
10 from wradmin.model import WrSledrunCache, WrReport
11 from wradmin.template_helper import PylonsHelper
12
13
14 class RodelbahnController:
15
16     def list(self):
17         """Lists all sled runs"""
18         q = db.session.query(WrSledrunCache)
19         q = q.order_by(WrSledrunCache.page_title)
20         paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)),
21                                   url_maker=lambda page: url_for('rodelbahn_list', page=page),
22                                   items_per_page=25)
23         return render_template('rodelbahn_list.html', paginator=paginator)
24
25     def view(self, id):
26         """Displays a sled run"""
27         q = db.session.query(WrSledrunCache)
28         sledrun = q.get(id)
29         if sledrun is None:
30             abort(404)
31         q = db.session.query(WrReport)
32         q = q.filter_by(page_id=id).order_by(sa.sql.expression.desc(WrReport.id))
33         paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)),
34                                   url_maker=lambda page: url_for('rodelbahn_view', id=id, page=page),
35                                   items_per_page=25)
36         return render_template('rodelbahn_view.html', sledding=sledrun, paginator=paginator)
37
38     def json_edit(self, sledrun_id):
39         q = db.session.query(WrSledrunCache)
40         sledrun = q.get(sledrun_id)
41         if sledrun is None:
42             abort(404)
43         h = PylonsHelper()
44         return render_template('json_editor.html',
45                                schema_url=url_for('static', filename='schema_v1.json'),
46                                #json_url=url_for('static', filename='latschenhuette.json')
47                                json_url=h.wiki(sledrun.page_title)
48                                )
49
50     def update(self):
51         """Updates the wrsledruncache table from the wiki"""
52         c = db.session.connection()
53         try:
54             wrpylib.wrmwcache.update_wrsledruncache(c)
55             db.session.commit()
56             flash('Die Rodelbahnliste wurde erfolgreich aktualisiert.', 'info')
57         except wrpylib.wrmwcache.UpdateCacheError as e:
58             title = str(e.args[1])
59             title = wrpylib.mwmarkup.dbkey_to_title(title)
60             msg = str(e.args[2])
61             msg = msg.replace('\n', '; ')
62             if len(e.args) == 3:
63                 flash("Fehler bei Rodelbahn '{0}': {1}".format(title, msg), 'error')
64             else:
65                 flash(str(e), 'error')
66         # Redirect to result page
67         return redirect(url_for('rodelbahn_list'))
68
69     def update_regioncache(self):
70         """Updates the wrregioncache table from the wiki"""
71         c = db.session.connection()
72         try:
73             wrpylib.wrmwcache.update_wrregioncache(c)
74             db.session.commit()
75             flash('Die Rodelbahneinträge in den Regionslisten wurden erfolgreich aktualisiert.', 'info')
76         except wrpylib.wrmwcache.UpdateCacheError as e:
77             flash(str(e), 'error')
78         # Redirect to result page
79         return redirect(url_for('rodelbahn_list'))
80
81     def update_mapcache(self):
82         """Updates the wrmappointcache and wrmappathcache tables from the wiki."""
83         c = db.session.connection()
84         try:
85             wrpylib.wrmwcache.update_wrmapcache(c)
86             db.session.commit()
87             flash('Die Landkarteninformationen aus dem Wiki wurden erfolgreich aktualisiesrt.', 'info')
88         except wrpylib.wrmwcache.UpdateCacheError as e:
89             flash(str(e), 'error')
90         # Redirect to result page
91         return redirect(url_for('rodelbahn_list'))