add index and login page (not yet good)
This commit is contained in:
parent
44036e57e9
commit
cd8e918890
|
@ -0,0 +1,20 @@
|
|||
from django import forms
|
||||
|
||||
from accounts.models import Accounts
|
||||
from accounts.utils import LoginHelper
|
||||
|
||||
|
||||
class LoginForm(forms.Form):
|
||||
account_name = forms.CharField()
|
||||
password = forms.CharField(widget=forms.PasswordInput)
|
||||
|
||||
def is_valid(self):
|
||||
if not super(LoginForm, self).is_valid():
|
||||
return False
|
||||
|
||||
account = Accounts.objects.get(name=self.cleaned_data['account_name'])
|
||||
hashed_password = LoginHelper.hash_password(self.cleaned_data['password'])
|
||||
if account.password == hashed_password:
|
||||
return True
|
||||
else:
|
||||
return False
|
|
@ -5,18 +5,27 @@
|
|||
<title>Highscore</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>Highscore</h1>
|
||||
|
||||
{% if best_players %}
|
||||
<ul>
|
||||
<table style="width:50%">
|
||||
<tr>
|
||||
<th style="text-align: center;">Name</th>
|
||||
<th style="text-align: center;">Level</th>
|
||||
</tr>
|
||||
{% for player in best_players %}
|
||||
<li>{{ player.name }} - {{ player.level }}</li>
|
||||
<tr>
|
||||
<td>{{ player.name }}</td>
|
||||
<td style="text-align: right; width: 10%">{{ player.level }}</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
</table>
|
||||
{% else %}
|
||||
<p>No players registered.</p>
|
||||
{% endif %}
|
||||
|
||||
<a href="{% url 'accounts:register' %}">Register now!</a>
|
||||
<a href="{% url 'accounts:login' %}">Login</a>
|
||||
|
||||
</body>
|
||||
</html>
|
|
@ -0,0 +1,17 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Login</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>Login</h1>
|
||||
|
||||
<form method="post">
|
||||
{% csrf_token %}
|
||||
{{ form.as_p }}
|
||||
<button type="submit">Login</button>
|
||||
</form>
|
||||
|
||||
</body>
|
||||
</html>
|
|
@ -8,4 +8,5 @@ app_name = 'accounts'
|
|||
urlpatterns = [
|
||||
path('', views.IndexView.as_view(), name='index'),
|
||||
path('register/', views.RegisterAccountView.as_view(), name='register'),
|
||||
path('login/', views.LoginView.as_view(), name='login'),
|
||||
]
|
|
@ -0,0 +1,9 @@
|
|||
import hashlib
|
||||
|
||||
class LoginHelper(object):
|
||||
|
||||
@staticmethod
|
||||
def hash_password(password):
|
||||
hashed_password = hashlib.sha1(password.encode('utf-8'))\
|
||||
.hexdigest()
|
||||
return hashed_password
|
|
@ -1,8 +1,10 @@
|
|||
from django.shortcuts import render, render_to_response
|
||||
from django.views import generic
|
||||
from django.views.generic.edit import CreateView
|
||||
from django.views.generic.edit import CreateView, FormView
|
||||
# Create your views here.
|
||||
from accounts.forms import LoginForm
|
||||
from accounts.models import Accounts, Players
|
||||
from accounts.utils import LoginHelper
|
||||
|
||||
|
||||
class RegisterAccountView(CreateView):
|
||||
|
@ -11,17 +13,21 @@ class RegisterAccountView(CreateView):
|
|||
template_name = 'register_account.html'
|
||||
|
||||
def form_valid(self, form):
|
||||
import hashlib
|
||||
self.object = form.save(commit=False)
|
||||
hashed_password = hashlib.sha1(self.object.password.encode('utf-8')).hexdigest()
|
||||
hashed_password = LoginHelper.hash_password(self.object.password)
|
||||
self.object.password = hashed_password
|
||||
self.object.save()
|
||||
|
||||
return render_to_response(self.template_name, self.get_context_data())
|
||||
|
||||
class LoginView(FormView):
|
||||
template_name = 'login.html'
|
||||
form_class = LoginForm
|
||||
success_url = '/loginarea/'
|
||||
|
||||
class IndexView(generic.ListView):
|
||||
template_name = 'index.html'
|
||||
context_object_name = 'best_players'
|
||||
|
||||
def get_queryset(self):
|
||||
return Players.objects.order_by('-level')[:10]
|
||||
return Players.objects.filter(group_id=1).order_by('-level')[:10]
|
Loading…
Reference in New Issue