55 lines
1.6 KiB
Python
55 lines
1.6 KiB
Python
# Create your views here.
|
|
from django.shortcuts import render, redirect
|
|
from django.contrib.auth import authenticate, login
|
|
from .forms import LoginForm, SignUpForm
|
|
|
|
|
|
def login_view(request):
|
|
if request.user.is_authenticated:
|
|
# User is already logged in, redirect them to the home page
|
|
return redirect('/')
|
|
|
|
form = LoginForm(request.POST or None)
|
|
|
|
msg = None
|
|
|
|
if request.method == "POST":
|
|
|
|
if form.is_valid():
|
|
username = form.cleaned_data.get("username")
|
|
password = form.cleaned_data.get("password")
|
|
user = authenticate(username=username, password=password)
|
|
if user is not None:
|
|
login(request, user)
|
|
return redirect("/")
|
|
else:
|
|
msg = 'Invalid credentials'
|
|
else:
|
|
msg = 'Error validating the form'
|
|
|
|
return render(request, "accounts/login.html", {"form": form, "msg": msg})
|
|
|
|
|
|
def register_user(request):
|
|
msg = None
|
|
success = False
|
|
|
|
if request.method == "POST":
|
|
form = SignUpForm(request.POST)
|
|
if form.is_valid():
|
|
form.save()
|
|
username = form.cleaned_data.get("username")
|
|
raw_password = form.cleaned_data.get("password1")
|
|
user = authenticate(username=username, password=raw_password)
|
|
|
|
msg = 'User created - please <a href="/login">login</a>.'
|
|
success = True
|
|
|
|
# return redirect("/login/")
|
|
|
|
else:
|
|
msg = 'Form is not valid'
|
|
else:
|
|
form = SignUpForm()
|
|
|
|
return render(request, "accounts/register.html", {"form": form, "msg": msg, "success": success})
|