-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathviews.py
89 lines (73 loc) · 3.27 KB
/
views.py
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
from django.shortcuts import render, get_object_or_404, redirect
from django.views.generic import ListView
from app.form import LogForm,SkForm
from django.http import HttpResponseRedirect
from django.urls import reverse
from django.http import HttpResponse
from django.contrib.auth.hashers import make_password, check_password
from app.models import User,MyAdmin
class RepUsers(ListView):
queryset = User.objects.all().order_by('-zgloszono')
context_object_name = 'Users'
paginate_by = 15
template_name = 'skargi.html'
def get(self, request, *args, **kwargs):
# Sprawdzenie, czy ciasteczko 'Zalogowany' ma wartość '1'
if request.COOKIES.get('Zalogowany') != '1':
# Jeśli ciasteczko nie istnieje lub ma inną wartość, przekierowanie na stronę logowania
return redirect('app:logowanie')
# Jeśli ciasteczko jest poprawne, kontynuuj z renderowaniem widoku
return super().get(request, *args, **kwargs)
def logowanie(request):
if request.method == 'POST':
form = LogForm(request.POST)
if form.is_valid():
#Sprawdzenie danych logowania
for aadmin in MyAdmin.objects.all():
if (
form.cleaned_data['nickname'] == aadmin.nickname and
check_password(form.cleaned_data['password'], aadmin.password)
):
# Tworzenie odpowiedzi z przekierowaniem
response = HttpResponseRedirect('/base/') # lub reverse('app:info')
response.set_cookie("Zalogowany", '1') # Ustawienie ciasteczka
return response
#Jeśli dane logowania są niepoprawne, przekaż błąd
form.add_error(None, "Niepoprawne dane logowania")
else:
form = LogForm()
return render(request, 'logowanie.html', {'form': form})
def skarga(request):
if request.method == 'POST':
form = SkForm(request.POST)
if form.is_valid(): # sprawdzenie czy formularz jest wlasciwy
user = form.save(commit=False)
user.save()
return redirect('app:skarga')
else:
form = SkForm()
return render(request, 'napiszSkarge.html', {'form': form})
def reported(request, year, month, day,hour,minute,second):
rep = get_object_or_404(User,
zgloszono__year=year,
zgloszono__month=month,
zgloszono__day=day,
zgloszono__hour=hour,
zgloszono__minute=minute,
zgloszono__second=second,
)
return render(request, "dokladnyOpis.html",
{'rep': rep, })
def edit_note(request,year,month,day,hour,minute,second):
user = get_object_or_404(User,
zgloszono__year=year,
zgloszono__month=month,
zgloszono__day=day,
zgloszono__hour=hour,
zgloszono__minute=minute,
zgloszono__second=second,
)
user.status = 'ukryte'
user.save()
return redirect('app:rep')
# Create your views here.