2026-04-08 11:52:49 -04:00
|
|
|
from django.conf import settings
|
2026-01-30 21:33:30 -05:00
|
|
|
from django.contrib import auth, messages
|
2026-04-08 11:52:49 -04:00
|
|
|
from django.http import Http404
|
2026-01-30 16:21:32 -05:00
|
|
|
from django.shortcuts import redirect
|
2026-01-30 17:52:44 -05:00
|
|
|
from django.urls import reverse
|
2026-02-21 21:35:15 -05:00
|
|
|
|
2026-03-08 15:14:41 -04:00
|
|
|
from .models import LoginToken
|
2026-02-21 21:35:15 -05:00
|
|
|
from .tasks import send_login_email_task
|
|
|
|
|
|
2026-01-29 15:21:54 -05:00
|
|
|
|
2026-01-30 16:21:32 -05:00
|
|
|
def send_login_email(request):
|
|
|
|
|
email = request.POST["email"]
|
2026-03-08 15:14:41 -04:00
|
|
|
login_token = LoginToken.objects.create(email=email)
|
2026-01-30 17:52:44 -05:00
|
|
|
url = request.build_absolute_uri(
|
2026-03-08 15:14:41 -04:00
|
|
|
reverse("login") + "?token=" + str(login_token.uid),
|
2026-01-30 17:52:44 -05:00
|
|
|
)
|
2026-02-07 18:58:17 -05:00
|
|
|
|
2026-02-21 21:35:15 -05:00
|
|
|
send_login_email_task.delay(email, url)
|
2026-01-30 17:23:07 -05:00
|
|
|
messages.success(
|
|
|
|
|
request,
|
|
|
|
|
"Check your email!—there you'll find a magic login link. But hurry… it's only temporary!",
|
|
|
|
|
)
|
2026-02-21 21:35:15 -05:00
|
|
|
|
2026-01-30 16:21:32 -05:00
|
|
|
return redirect("/")
|
2026-01-30 17:36:48 -05:00
|
|
|
|
|
|
|
|
def login(request):
|
2026-01-31 15:16:34 -05:00
|
|
|
if user := auth.authenticate(uid=request.GET["token"]):
|
2026-01-30 21:33:30 -05:00
|
|
|
auth.login(request, user)
|
2026-01-30 21:51:06 -05:00
|
|
|
else:
|
2026-01-31 15:16:34 -05:00
|
|
|
messages.error(request, "Invalid login link!—please request another")
|
2026-01-30 17:36:48 -05:00
|
|
|
return redirect("/")
|
2026-04-08 11:52:49 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def dev_login(request, session_key):
|
|
|
|
|
"""DEBUG-only: set session cookie and redirect. Used by setup_sig_session command."""
|
|
|
|
|
if not settings.DEBUG:
|
|
|
|
|
raise Http404
|
|
|
|
|
next_url = request.GET.get("next", "/")
|
|
|
|
|
response = redirect(next_url)
|
|
|
|
|
response.set_cookie(settings.SESSION_COOKIE_NAME, session_key, httponly=True)
|
|
|
|
|
return response
|