aboutsummaryrefslogtreecommitdiff
path: root/uploader/authorisation.py
blob: 8ab83f8a920dfee82a437b9e6a0e303b8af81091 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
"""Authorisation utilities."""
from functools import wraps

from flask import flash, redirect

from uploader import session

def require_login(function):
    """Check that the user is logged in before executing `func`."""
    @wraps(function)
    def __is_session_valid__(*args, **kwargs):
        """Check that the user is logged in and their token is valid."""
        def __clear_session__(_no_token):
            session.clear_session_info()
            flash("You need to be logged in.", "alert-danger")
            return redirect("/")

        return session.user_token().either(
            __clear_session__,
            lambda token: function(*args, **kwargs))
    return __is_session_valid__