aboutsummaryrefslogtreecommitdiff
path: root/authentication/views.py
blob: 4c672a5692a8b6d6952c598fa1a71b19e3a9c146 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import datetime
from django.http import HttpResponseRedirect
from django.contrib.auth import login, logout
from django.urls import reverse
from authentication.utils import exchange_code, authenticate_user, exchange_mal_code, get_redirect_uri
from django.shortcuts import redirect, render

def index(request):
    if request.user.is_authenticated:
        return redirect("home:index")

    return redirect(get_redirect_uri())

def callback(request):
    if request.user.is_authenticated:
        return redirect("home:index")

    code = request.GET.get("code")
    if not code:
        return render(request, "messages/unauthorized.html", {"error": "You can't access the site if you keep cancelling the login!", "redirect_uri": get_redirect_uri()})

    response = exchange_code(code=code)

    if "error" in response:
        return render(request, "messages/unauthorized.html", {"error": "You did something crazy, didn't you?", "redirect_uri": get_redirect_uri()})

    user = authenticate_user(exchange_response=response)

    if not user:
        return redirect("auth:unauthorized")

    next_url = request.session.pop("next", None)
    # login the user and redirect to the referrer
    login(request, user)
    return redirect(next_url if next_url else "home:index")

def MALSync(request):
    if not request.user.is_authenticated:
        return redirect("auth:unauthorized")
    
    code = request.GET.get("code")
    state = request.GET.get("state")
    if not code or not state:
        return redirect(reverse("user_profile:user_profile") + "?category=anime_list")
    
    response = exchange_mal_code(code=code, code_verifier=state)

    if "error" in response:
        return redirect(reverse("user_profile:user_profile") + "?category=anime_list")
    
    user = request.user
    user.mal_token_type = response.get("token_type")
    user.mal_access_token = response.get("access_token")
    user.mal_refresh_token = response.get("refresh_token")
    user.mal_token_expires_in = datetime.datetime.now() + datetime.timedelta(seconds=response.get("expires_in"))

    user.save()

    return redirect(reverse("user_profile:user_profile") + "?category=anime_list")


def logout_user(request):
    logout(request)
    return HttpResponseRedirect(request.META.get("HTTP_REFERER"))

def unauthorized(request):
    if request.user.is_authenticated:
        return redirect("home:index")

    return render(request, "messages/unauthorized.html", {"redirect_uri": get_redirect_uri(), "error": "You are not part of our elite cult!"})