blob: b2120680b66859baeecda65b240d68879965a259 [file] [log] [blame]
from rest_framework.decorators import api_view
from rest_framework.response import Response
from rest_framework.reverse import reverse
from rest_framework import serializers
from rest_framework import generics
from rest_framework.views import APIView
from core.models import *
from services.hpc.models import *
from services.requestrouter.models import *
from django.forms import widgets
from django.core.exceptions import PermissionDenied
from django.contrib.contenttypes.models import ContentType
import json
import socket
import time
import django.middleware.csrf
from xos.exceptions import *
from django.contrib.sessions.backends.db import SessionStore
from django.contrib.sessions.models import Session
class LoginView(APIView):
method_kind = "list"
method_name = "login"
def do_login(self, request, username, password):
if not username:
raise XOSMissingField("No username specified")
if not password:
raise XOSMissingField("No password specified")
u = User.objects.filter(email=username)
if not u:
raise XOSNotFound("User %s does not exist" % username)
u=u[0]
if not u.check_password(password):
raise PermissionDenied("Incorrect password")
auth = {"username": username, "password": password}
request.session["auth"] = auth
request.session.save()
return Response({"xoscsrftoken": django.middleware.csrf.get_token(request),
"xossessionid": request.session.session_key})
def get(self, request, format=None):
username = request.GET.get("username", None)
password = request.GET.get("password", None)
return self.do_login(request, username, password)
def post(self, request, format=None):
username = request.DATA.get("username", None)
password = request.DATA.get("password", None)
return self.do_login(request, username, password)
class LogoutView(APIView):
method_kind = "list"
method_name = "logout"
def do_logout(self, request, sessionid):
if not sessionid:
raise XOSMissingField("No xossessionid specified")
# Make sure the session exists. This prevents us from accidentally
# creating empty sessions with SessionStore()
session = Session.objects.filter(session_key=sessionid)
if not session:
# session doesn't exist
raise PermissionDenied("Session does not exist")
session = SessionStore(session_key=sessionid)
if "auth" in session:
del session["auth"]
session.save()
return Response("Logged Out")
def get(self, request, format=None):
sessionid = request.GET.get("xossessionid", None)
return self.do_logout(request, sessionid)
def post(self, request, format=None):
sessionid = request.DATA.get("xossessionid", None)
return self.do_logout(request, sessionid)