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