1 from flask import request, abort, redirect, url_for, flash, render_template
3 import sqlalchemy as sa
5 import wrpylib.wrmwmarkup
6 import wrpylib.wrmwcache
7 import wrpylib.mwmarkup
9 from wradmin.app import db
10 from wradmin.model import WrSledrunCache, WrReport
11 from wradmin.template_helper import PylonsHelper
14 class RodelbahnController:
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),
23 return render_template('rodelbahn_list.html', paginator=paginator)
26 """Displays a sled run"""
27 q = db.session.query(WrSledrunCache)
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),
36 return render_template('rodelbahn_view.html', sledding=sledrun, paginator=paginator)
38 def json_edit(self, sledrun_id):
39 q = db.session.query(WrSledrunCache)
40 sledrun = q.get(sledrun_id)
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)
51 """Updates the wrsledruncache table from the wiki"""
52 c = db.session.connection()
54 wrpylib.wrmwcache.update_wrsledruncache(c)
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)
61 msg = msg.replace('\n', '; ')
63 flash("Fehler bei Rodelbahn '{0}': {1}".format(title, msg), 'error')
65 flash(str(e), 'error')
66 # Redirect to result page
67 return redirect(url_for('rodelbahn_list'))
69 def update_regioncache(self):
70 """Updates the wrregioncache table from the wiki"""
71 c = db.session.connection()
73 wrpylib.wrmwcache.update_wrregioncache(c)
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'))
81 def update_mapcache(self):
82 """Updates the wrmappointcache and wrmappathcache tables from the wiki."""
83 c = db.session.connection()
85 wrpylib.wrmwcache.update_wrmapcache(c)
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'))