aboutsummaryrefslogtreecommitdiff
path: root/app/decorators.py
diff options
context:
space:
mode:
authorGertjan van den Burg <gertjanvandenburg@gmail.com>2019-03-26 16:17:11 +0000
committerGertjan van den Burg <gertjanvandenburg@gmail.com>2019-03-26 16:17:11 +0000
commit98f0fcdcbdbbd91a2a4da6b44229a178ddb38d31 (patch)
treeec6f1254bab7e65954694704a20c947fa268649e /app/decorators.py
parentAdd email confirmation field (diff)
downloadAnnotateChange-98f0fcdcbdbbd91a2a4da6b44229a178ddb38d31.tar.gz
AnnotateChange-98f0fcdcbdbbd91a2a4da6b44229a178ddb38d31.zip
Add support for email confirmation
Diffstat (limited to 'app/decorators.py')
-rw-r--r--app/decorators.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/app/decorators.py b/app/decorators.py
new file mode 100644
index 0000000..d5b8821
--- /dev/null
+++ b/app/decorators.py
@@ -0,0 +1,40 @@
+# -*- coding: utf-8 -*-
+
+from functools import wraps
+
+from flask import current_app, request, redirect, flash, url_for
+from flask_login import current_user
+from flask_login.config import EXEMPT_METHODS
+
+
+def admin_required(func):
+ @wraps(func)
+ def decorated_view(*args, **kwargs):
+ if request.method in EXEMPT_METHODS:
+ return func(*args, **kwargs)
+ elif current_app.config.get("LOGIN_DISABLED"):
+ return func(*args, **kwargs)
+ elif not current_user.is_authenticated:
+ return current_app.login_manager.unauthorized()
+ elif not current_user.is_admin:
+ return current_app.login_manager.unauthorized()
+ return func(*args, **kwargs)
+
+ return decorated_view
+
+
+def login_required(func):
+ @wraps(func)
+ def decorated_view(*args, **kwargs):
+ if request.method in EXEMPT_METHODS:
+ return func(*args, **kwargs)
+ elif current_app.config.get("LOGIN_DISABLED"):
+ return func(*args, **kwargs)
+ elif not current_user.is_authenticated:
+ return current_app.login_manager.unauthorized()
+ elif not current_user.is_confirmed:
+ flash("hello world")
+ return redirect(url_for("auth.not_confirmed"))
+ return func(*args, **kwargs)
+
+ return decorated_view