X-Git-Url: https://git.toastfreeware.priv.at/philipp/winterrodeln/wradmin.git/blobdiff_plain/77018b126585ddf1de7231c2d8a6def5086180c6..32d339dfffa7356a9d1aad0fbec62d400e86ba8f:/wradmin/controllers/rodelbahn.py diff --git a/wradmin/controllers/rodelbahn.py b/wradmin/controllers/rodelbahn.py index 647687b..f6bd26d 100644 --- a/wradmin/controllers/rodelbahn.py +++ b/wradmin/controllers/rodelbahn.py @@ -1,5 +1,5 @@ #!/usr/bin/python3.4 -from flask import request, abort, redirect, session, url_for +from flask import request, abort, redirect, url_for, flash, render_template import paginate import sqlalchemy as sa @@ -8,7 +8,6 @@ import wrpylib.wrmwcache import wrpylib.mwmarkup import wradmin.model as model -from wradmin.genshi import render_genshi_template, TemplateContext class RodelbahnController: @@ -17,25 +16,23 @@ class RodelbahnController: """Lists all sled runs""" q = model.meta.Session.query(model.WrSledrunCache) q = q.order_by(model.WrSledrunCache.page_title) - c = TemplateContext() - c.paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)), - url_maker=lambda page: url_for('rodelbahn_list', page=page), - items_per_page=25) - return render_genshi_template('rodelbahn_list.html', c=c) + paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)), + url_maker=lambda page: url_for('rodelbahn_list', page=page), + items_per_page=25) + return render_template('rodelbahn_list.html', paginator=paginator) def view(self, id): """Displays a sled run""" q = model.meta.Session.query(model.WrSledrunCache) - c = TemplateContext() - c.sledding = q.get(id) - if c.sledding is None: + sledding = q.get(id) + if sledding is None: abort(404) q = model.meta.Session.query(model.WrReport) q = q.filter_by(page_id=id).order_by(sa.sql.expression.desc(model.WrReport.id)) - c.paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)), - url_maker=lambda page: url_for('rodelbahn_view', id=id, page=page), - items_per_page=25) - return render_genshi_template('rodelbahn_view.html', c=c) + paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)), + url_maker=lambda page: url_for('rodelbahn_view', id=id, page=page), + items_per_page=25) + return render_template('rodelbahn_view.html', sledding=sledding, paginator=paginator) def update(self): """Updates the wrsledruncache table from the wiki""" @@ -43,25 +40,39 @@ class RodelbahnController: try: wrpylib.wrmwcache.update_wrsledruncache(c) model.meta.Session.commit() - session['flash'] = 'Die Rodelbahnliste wurde erfolgreich aktualisiert.' + flash('Die Rodelbahnliste wurde erfolgreich aktualisiert.', 'info') except wrpylib.wrmwcache.UpdateCacheError as e: title = str(e.args[1]) - title = wrpylib.mwmarkup.to_title(title) + title = wrpylib.mwmarkup.dbkey_to_title(title) msg = str(e.args[2]) msg = msg.replace('\n', '; ') - if len(e.args) == 3: session['flash'] = "Fehler bei Rodelbahn '{0}': {1}".format(title, msg) - else: session['flash'] = str(e) + if len(e.args) == 3: + flash("Fehler bei Rodelbahn '{0}': {1}".format(title, msg), 'error') + else: + flash(str(e), 'error') # Redirect to result page return redirect(url_for('rodelbahn_list')) def update_regioncache(self): - "Updates the wrregioncache table from the wiki" + """Updates the wrregioncache table from the wiki""" c = model.meta.Session.connection() try: wrpylib.wrmwcache.update_wrregioncache(c) model.meta.Session.commit() - session['flash'] = 'Die Rodelbahneinträge in den Regionslisten wurden erfolgreich aktualisiert.' + flash('Die Rodelbahneinträge in den Regionslisten wurden erfolgreich aktualisiert.', 'info') except wrpylib.wrmwcache.UpdateCacheError as e: - session['flash'] = str(e) + flash(str(e), 'error') + # Redirect to result page + return redirect(url_for('rodelbahn_list')) + + def update_mapcache(self): + """Updates the wrmappointcache and wrmappathcache tables from the wiki.""" + c = model.meta.Session.connection() + try: + wrpylib.wrmwcache.update_wrmapcache(c) + model.meta.Session.commit() + flash('Die Landkarteninformationen aus dem Wiki wurden erfolgreich aktualisiesrt.', 'info') + except wrpylib.wrmwcache.UpdateCacheError as e: + flash(str(e), 'error') # Redirect to result page return redirect(url_for('rodelbahn_list'))