X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=motion.py;h=f6ddf1344004ee30bd5bbb40d096eadcd33cea90;hb=fd16e7d1b4090b8466997b98ce84e5a9d9ebc4d0;hp=51f21dee8070a233c553e3f8e45169b612e494f8;hpb=5cd320964ca249449fb08a68c4ca18e8bda1e98b;p=motion.git diff --git a/motion.py b/motion.py index 51f21de..f6ddf13 100644 --- a/motion.py +++ b/motion.py @@ -4,8 +4,8 @@ from flask import render_template, redirect from flask import request import postgresql import filters - -times=[3,5,14] +from flaskext.markdown import Markdown +from markdown.extensions import Extension def get_db(): db = getattr(g, '_database', None) @@ -17,17 +17,33 @@ def get_db(): app = Flask(__name__) app.register_blueprint(filters.blueprint) +class EscapeHtml(Extension): + def extendMarkdown(self, md, md_globals): + del md.preprocessors['html_block'] + del md.inlinePatterns['html'] + +md = Markdown(app, extensions=[EscapeHtml()]) + # Load config app.config.from_pyfile('config.py') prefix=app.config.get("GROUP_PREFIX") +times=app.config.get("DURATION") + +debuguser=app.config.get("DEBUGUSER") + @app.before_request def lookup_user(): global prefix env = request.environ user = None + if debuguser is not None: + parts =debuguser[request.host].split("/", 1) + user = parts[0] + roles = parts[1] + if "USER_ROLES" in env: parts = env.get("USER_ROLES").split("/", 1) user = parts[0] @@ -145,7 +161,7 @@ def main(): prev = rs[9][0] else: prev = -1 - return render_template('index.html', motions=rv[:10], more=rv[10]["id"] if len(rv) == 11 else None, times=times, prev=prev, + return render_template('index.html', motions=rv[:10], more=rv[10]["id"] if len(rv) == 11 else None, times=times[request.host], prev=prev, categories=get_allowed_cats("create")) def rel_redirect(loc): @@ -159,7 +175,7 @@ def put_motion(): if cat not in get_allowed_cats("create"): return "Forbidden", 403 time = int(request.form.get("days", "3")); - if time not in times: + if time not in times[request.host]: return "Error, invalid length", 500 db = get_db() with db.xact():