Add login and sign up logic to the app

This commit is contained in:
Piotr Szkudlarek 2023-12-06 18:12:31 +01:00
parent b12baaf09b
commit a4118e2357
10 changed files with 234 additions and 59 deletions

View File

@ -1,8 +1,12 @@
from django.urls import path
from django.urls import path, include
from . import views
from django.conf.urls.static import static
from django.conf import settings
from django.contrib.auth import urls
urlpatterns = [path("detect/", views.view, name="detect")] + static(
settings.MEDIA_URL, document_root=settings.MEDIA_ROOT
)
urlpatterns = [
path("detect/", views.DetectView.as_view(), name="detect"),
path("login/", views.LoginView.as_view(), name="login"),
path("logout/", views.logout_view, name="logout"),
path("register/", views.SignupView.as_view(), name="signup"),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

View File

@ -1,19 +1,25 @@
from django.shortcuts import render
from django.shortcuts import render, redirect
from django.views import View
from .forms import DetectForm
from .models import DetectImage
from django.core.files.uploadedfile import SimpleUploadedFile
from django.conf import settings
from ultralytics import YOLO
from django.contrib.auth.forms import AuthenticationForm, UserCreationForm
from django.contrib.auth import authenticate, login, logout
# Create your views here.
MODEL = YOLO("best.pt")
def view(request):
if request.method == "GET":
form = DetectForm()
class DetectView(View):
form_class = DetectForm
template_name = "upload.html"
def get(self, request, *args, **kwargs):
form = self.form_class()
return render(request, "upload.html", {"form": form})
form = DetectForm(request.POST, request.FILES)
def post(self, request, *args, **kwargs):
form = self.form_class(request.POST, request.FILES)
if form.is_valid():
image = form.save()
MODEL.predict(
@ -23,7 +29,6 @@ def view(request):
name=f"{image.image.name}_predicted",
imgsz=[640, 640],
)
print(f"{settings.BASE_DIR}/predicted2/{image.image.name}")
saved = form.is_valid()
return render(
request,
@ -35,3 +40,46 @@ def view(request):
)
else:
return render(request, "upload.html", {"form": form})
class LoginView(View):
form_class = AuthenticationForm
template_name = "login_signup.html"
def get(self, request, *args, **kwargs):
form = self.form_class()
return render(request, self.template_name, {"form": form})
def post(self, request, *args, **kwargs):
form = self.form_class(data=request.POST)
if form.is_valid():
user = authenticate(
username=form.cleaned_data["username"],
password=form.cleaned_data["password"],
)
if user is not None:
login(request, user)
return redirect("detect")
return render(request, self.template_name, {"form": form})
class SignupView(View):
form_class = UserCreationForm
template_name = "login_signup.html"
def get(self, request, *args, **kwargs):
form = self.form_class()
return render(request, self.template_name, {"form": form, "signup": True})
def post(self, request, *args, **kwargs):
form = self.form_class(data=request.POST)
if form.is_valid():
user = form.save()
login(request, user)
return redirect("detect")
return render(request, self.template_name, {"form": form, "signup": True})
def logout_view(request):
logout(request)
return redirect("detect")

View File

@ -56,7 +56,7 @@ ROOT_URLCONF = "PlanktonDetector.urls"
TEMPLATES = [
{
"BACKEND": "django.template.backends.django.DjangoTemplates",
"DIRS": [os.path.join(BASE_DIR, 'templates')],
"DIRS": [os.path.join(BASE_DIR, "templates")],
"APP_DIRS": True,
"OPTIONS": {
"context_processors": [
@ -119,14 +119,16 @@ USE_TZ = True
STATIC_URL = "static/"
STATIC_ROOT = ''
STATIC_ROOT = ""
STATICFILES_DIRS = ('static',)
STATICFILES_DIRS = ("static",)
MEDIA_ROOT = BASE_DIR / "uploaded_media"
MEDIA_URL = "media/"
LOGOUT_REDIRECT_URL = "detect/"
# Default primary key field type
# https://docs.djangoproject.com/en/4.2/ref/settings/#default-auto-field

Binary file not shown.

View File

@ -0,0 +1,40 @@
body, html{
height:100%;
margin: 0px 0px 0px 0px;
display:flex;
justify-content: center;
flex-direction: column;
font-family:'Inter', sans-serif;
}
.top-menu a{
text-decoration: none;
margin-right: 2rem;
color:black;
}
.top-menu{
display: flex;
flex-direction: row;
height: 5%;
justify-content:flex-end;
align-items: center;
background-color:lightgray;
margin-bottom:5px;
border: grey solid;
border-width: 0px 2px 2px 2px;
}
.footer{
display:flex;
flex-direction: row;
justify-content: center;
align-items: center;
margin-top: 5px;
background-color: lightgray;
border: grey solid;
border-width: 2px 2px 0px 2px;
justify-content: space-evenly;
align-items: center;
}

View File

@ -0,0 +1,33 @@
.form_div{
height: 100%;
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
.form_div input,label, p{
font-size: 1.2rem;
margin-bottom: 5px;
}
.form{
display: flex;
flex-direction: column;
align-items: center;
justify-content: space-evenly;
border: grey solid;
border-width: 4px;
border-radius: 10%;
padding: 5%;
background-color: lightgray;
}
.form span{
display: none;
}
#submit{
background-color: chartreuse;
}

View File

@ -1,32 +1,34 @@
html, body, form{
form{
height:100%;
width: 100%;
width:100%;
display:flex;
flex-direction: row;
font-family:'Inter', sans-serif;
flex-direction:row;
margin:auto;
}
.side_menu{
display: flex;
justify-content: flex-start;
justify-content: center;
align-items:center;
flex-direction: column;
width: 25%;
background-color: lightgray;
border: grey solid;
border-width: 2px;
}
#description{
font-size: 40px;
margin-left: 10px;
margin-right: 10px;
text-align: center;
}
#submit{
margin-bottom: 40px;
background-color: chartreuse;
margin-top: auto;
justify-self: flex-end;
height: 50px;
width: 80%;
border-radius: 25px;
@ -44,7 +46,6 @@ html, body, form{
.upload_button{
justify-self: right;
display:flex;
justify-content: flex-start;
align-items: flex-start;

View File

@ -0,0 +1,30 @@
{% load static %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@300&display=swap" rel="stylesheet">
<link rel="stylesheet" href="{% static 'DetectionApp/css/base.css' %}">
{%block extracss%}{%endblock extracss%}
<title>Plankton Detector</title>
</head>
<body>
<div class="top-menu">
<a href="#">Placeholder</a>
<a href="{% url 'detect' %}">Predict</a>
{% if user.is_authenticated %}
<a href="{% url 'logout' %}">Logout {{user}}</a>
{%else%}
<a href="{% url 'login' %}">Login</a>
{%endif%}
</div>
{%block content%}{%endblock content%}
<div class="footer">
<p>Footer</p>
</div>
</body>
</html>

View File

@ -0,0 +1,25 @@
{% extends 'base.html' %}
{%load static%}
{%block extracss%}
<link rel="stylesheet" href="{% static 'DetectionApp/css/login_signup.css' %}">
{%endblock extracss%}
{%block content%}
<div class="form_div">
{%if signup is not None%}
<p class="top_label">Register</p>
{% else%}
<p class="top_label">Login</p>
{%endif%}
<form class="form" method="post">
{%csrf_token%}
{{form}}
{% if signup is None%}
<input type="submit" id="submit" value="Log in">
</form>
<p class="signup_label">Don't have an account? <a href="{%url 'signup'%}">Sign Up</a></p>
{%else%}
<input type="submit" id="submit" value="Sign Up">
</form>
{%endif%}
</div>
{%endblock content%}

View File

@ -1,16 +1,9 @@
<!DOCTYPE html>
<html lang="en">
{% load static %}
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Plankton Detector</title>
<link rel="stylesheet" href="{% static 'DetectionApp/css/styles.css' %}">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@300&display=swap" rel="stylesheet">
</head>
<body>
{% extends 'base.html' %}
{%load static%}
{%block extracss%}
<link rel="stylesheet" href="{%static 'DetectionApp/css/upload.css' %}">
{%endblock extracss%}
{%block content%}
<form method="POST" enctype="multipart/form-data">
{% csrf_token %}
<div class="side_menu">
@ -50,5 +43,4 @@
});
</script>
</form>
</body>
</html>
{%endblock content%}