1 from urllib.parse import quote_plus
4 import sqlalchemy as sa
5 from flask import request, abort, redirect, url_for, flash, render_template, current_app
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
15 class RodelbahnController:
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),
24 return render_template('rodelbahn_list.html', paginator=paginator)
27 """Displays a sled run"""
28 q = db.session.query(WrSledrunCache)
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),
37 return render_template('rodelbahn_view.html', sledding=sledrun, paginator=paginator)
39 def json_edit(self, sledrun_id):
40 q = db.session.query(WrSledrunCache)
41 sledrun = q.get(sledrun_id)
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)
50 """Updates the wrsledruncache table from the wiki"""
51 c = db.session.connection()
53 wrpylib.wrmwcache.update_wrsledruncache(c)
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)
60 msg = msg.replace('\n', '; ')
62 flash("Fehler bei Rodelbahn '{0}': {1}".format(title, msg), 'error')
64 flash(str(e), 'error')
65 # Redirect to result page
66 return redirect(url_for('rodelbahn_list'))
68 def update_regioncache(self):
69 """Updates the wrregioncache table from the wiki"""
70 c = db.session.connection()
72 wrpylib.wrmwcache.update_wrregioncache(c)
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'))
80 def update_mapcache(self):
81 """Updates the wrmappointcache and wrmappathcache tables from the wiki."""
82 c = db.session.connection()
84 wrpylib.wrmwcache.update_wrmapcache(c)
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'))