summaryrefslogtreecommitdiff
path: root/sbhs_server/account
diff options
context:
space:
mode:
authorttt2017-05-13 00:29:47 +0530
committerttt2017-05-13 00:29:47 +0530
commit4336f5f06f61de30ae3fa54650fce63a9d5ef5be (patch)
tree23b4ee9b8e8f24bf732acf2f7ad22ed50cdd5670 /sbhs_server/account
downloadSBHS-2018-Rpi-4336f5f06f61de30ae3fa54650fce63a9d5ef5be.tar.gz
SBHS-2018-Rpi-4336f5f06f61de30ae3fa54650fce63a9d5ef5be.tar.bz2
SBHS-2018-Rpi-4336f5f06f61de30ae3fa54650fce63a9d5ef5be.zip
added all server files
Diffstat (limited to 'sbhs_server/account')
-rw-r--r--sbhs_server/account/__init__.py0
-rw-r--r--sbhs_server/account/__init__.pycbin0 -> 146 bytes
-rw-r--r--sbhs_server/account/admin.py3
-rw-r--r--sbhs_server/account/models.py3
-rw-r--r--sbhs_server/account/models.pycbin0 -> 200 bytes
-rw-r--r--sbhs_server/account/tests.py3
-rw-r--r--sbhs_server/account/views.py111
7 files changed, 120 insertions, 0 deletions
diff --git a/sbhs_server/account/__init__.py b/sbhs_server/account/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/sbhs_server/account/__init__.py
diff --git a/sbhs_server/account/__init__.pyc b/sbhs_server/account/__init__.pyc
new file mode 100644
index 0000000..229f2e0
--- /dev/null
+++ b/sbhs_server/account/__init__.pyc
Binary files differ
diff --git a/sbhs_server/account/admin.py b/sbhs_server/account/admin.py
new file mode 100644
index 0000000..8c38f3f
--- /dev/null
+++ b/sbhs_server/account/admin.py
@@ -0,0 +1,3 @@
+from django.contrib import admin
+
+# Register your models here.
diff --git a/sbhs_server/account/models.py b/sbhs_server/account/models.py
new file mode 100644
index 0000000..71a8362
--- /dev/null
+++ b/sbhs_server/account/models.py
@@ -0,0 +1,3 @@
+from django.db import models
+
+# Create your models here.
diff --git a/sbhs_server/account/models.pyc b/sbhs_server/account/models.pyc
new file mode 100644
index 0000000..782790e
--- /dev/null
+++ b/sbhs_server/account/models.pyc
Binary files differ
diff --git a/sbhs_server/account/tests.py b/sbhs_server/account/tests.py
new file mode 100644
index 0000000..7ce503c
--- /dev/null
+++ b/sbhs_server/account/tests.py
@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/sbhs_server/account/views.py b/sbhs_server/account/views.py
new file mode 100644
index 0000000..306b318
--- /dev/null
+++ b/sbhs_server/account/views.py
@@ -0,0 +1,111 @@
+from django.shortcuts import render, redirect
+from sbhs_server.tables.models import Account, Board
+from django.core.exceptions import ValidationError
+from django.core.validators import validate_email
+from django.contrib import messages
+from sbhs_server.helpers import simple_encrypt
+from django.contrib.auth import authenticate
+from django.contrib.auth import login as LOGIN
+from django.contrib.auth import logout as LOGOUT
+from django.contrib.auth.decorators import login_required
+# Create your views here.
+
+def index(req):
+ if req.user.is_authenticated():
+ return redirect(home)
+ return render(req, "account/index.html")
+
+def new():
+ pass
+
+def create(req):
+ error = []
+
+ name = req.POST.get("name").strip()
+ email = req.POST.get("email").strip()
+ username = req.POST.get("username").strip()
+ roll_number = req.POST.get("roll_number").strip()
+ password = req.POST.get("password")
+ confirm = req.POST.get("confirm")
+ institute = req.POST.get("institute").strip()
+ department = req.POST.get("department").strip()
+ position = req.POST.get("position").strip()
+
+ error = error + (["Please enter a name."] if name == "" else [])
+ error = error + (["Please enter an email."] if email == "" else [])
+ error = error + (["Please enter an username."] if username == "" else [])
+ error = error + (["Please enter a roll_number."] if roll_number == "" else [])
+
+ error = error + (["Please enter a password."] if password == "" else [])
+ error = error + (["Password confirmation does not match."] if password != confirm else [])
+
+ error = error + (["Please enter an institute."] if institute == "" else [])
+ error = error + (["Please enter a department."] if department == "" else [])
+ error = error + (["Please enter a position."] if position == "" else [])
+
+ try:
+ validate_email(email)
+ except ValidationError:
+ error = error + ["Please enter a valid email."]
+
+ email_exists = Account.objects.filter(email=email).count()
+ error = error + (["Account with given email already exists."] if email_exists > 0 else [])
+
+ username_exists = Account.objects.filter(username=username).count()
+ error = error + (["Account with given username already exists."] if username_exists > 0 else [])
+
+ if error != []:
+ messages.add_message(req, messages.ERROR, "<br>".join(error))
+ return redirect(index)
+
+ # try:
+ account = Account(
+ name=name,
+ username=username,
+ email=email,
+ board_id=Board.allot_board()
+ )
+ account.set_password(password)
+ account.save()
+ account.send_confirmation()
+ print "Done"
+ messages.add_message(req, messages.SUCCESS, "You have been registered successfully. Please check your email for confirmation.")
+ return redirect(index)
+ # except:
+ # messages.add_message(req, messages.ERROR, "Invalid information. Please try again.")
+ # return redirect(index)
+
+def confirm(req, token):
+ try:
+ email = simple_encrypt.decrypt(token)
+ account = Account.objects.get(email=email)
+ account.is_active = True
+ account.save()
+ messages.add_message(req, messages.SUCCESS, "Your email has been confirmed. You can login now.")
+ except:
+ messages.add_message(req, messages.ERROR, "Invalid confirmation token.")
+
+ return redirect(index)
+
+def login(req):
+ username = req.POST.get('username')
+ password = req.POST.get('password')
+ user = authenticate(username=username, password=password)
+ if user is not None:
+ if user.is_active:
+ LOGIN(req, user)
+ return redirect(index)
+ else:
+ messages.add_message(req, messages.ERROR, "Your account is not activated yet. Please check your email for activation link.")
+ return redirect(index)
+ else:
+ messages.add_message(req, messages.ERROR, "Invalid username or password.")
+ return redirect(index)
+
+def logout(req):
+ LOGOUT(req)
+ return redirect(index)
+
+@login_required(redirect_field_name=None)
+def home(req):
+ return render(req, "account/home.html")