X-Git-Url: https://git.toastfreeware.priv.at/philipp/winterrodeln/wradmin.git/blobdiff_plain/8a94227460e3e5dedb3afb71c1093f32644bed5b..731f87ca567597759fe7935f5e3cf42b8e7c3c03:/wradmin/controllers/rodelbahn.py diff --git a/wradmin/controllers/rodelbahn.py b/wradmin/controllers/rodelbahn.py index 142c6b5..0b166fe 100644 --- a/wradmin/controllers/rodelbahn.py +++ b/wradmin/controllers/rodelbahn.py @@ -1,7 +1,5 @@ #!/usr/bin/python3.4 -#from pylons import request, response, session, url, tmpl_context as c -#from pylons.controllers.util import abort, redirect -from flask import request +from flask import request, abort, redirect, url_for, flash, render_template import paginate import sqlalchemy as sa @@ -10,11 +8,6 @@ import wrpylib.wrmwcache import wrpylib.mwmarkup import wradmin.model as model -from wradmin.genshi import render_genshi_template - - -class TemplateContext: - pass class RodelbahnController: @@ -23,51 +16,51 @@ 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)), 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" + """Displays a sled run""" q = model.meta.Session.query(model.WrSledrunCache) - c.sledding = q.get(id) - if c.sledding is None: abort(404) + 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, page=int(request.params.get('page', 1)), items_per_page = 25) - return render('rodelbahn_view.html') - - + 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" + """Updates the wrsledruncache table from the wiki""" c = model.meta.Session.connection() 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) - session.save() + 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(controller='rodelbahn', action='list')) - + 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) - session.save() + flash(str(e), 'error') # Redirect to result page - return redirect(url(controller='rodelbahn', action='list')) - + return redirect(url_for('rodelbahn_list'))