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!"})
|