diff options
| author | Gertjan van den Burg <gertjanvandenburg@gmail.com> | 2019-03-26 16:17:11 +0000 |
|---|---|---|
| committer | Gertjan van den Burg <gertjanvandenburg@gmail.com> | 2019-03-26 16:17:11 +0000 |
| commit | 98f0fcdcbdbbd91a2a4da6b44229a178ddb38d31 (patch) | |
| tree | ec6f1254bab7e65954694704a20c947fa268649e /app/decorators.py | |
| parent | Add email confirmation field (diff) | |
| download | AnnotateChange-98f0fcdcbdbbd91a2a4da6b44229a178ddb38d31.tar.gz AnnotateChange-98f0fcdcbdbbd91a2a4da6b44229a178ddb38d31.zip | |
Add support for email confirmation
Diffstat (limited to 'app/decorators.py')
| -rw-r--r-- | app/decorators.py | 40 |
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 |
