OnlineJudge/account/decorators.py

53 lines
1.5 KiB
Python
Raw Normal View History

# coding=utf-8
from __future__ import unicode_literals
2015-10-20 12:07:35 +00:00
import urllib
2016-10-29 18:17:35 +00:00
import json
import functools
2016-10-29 18:17:35 +00:00
from django.http import HttpResponse
from django.utils.translation import ugettext as _
2016-10-29 18:17:35 +00:00
from utils.shortcuts import JSONResponse
from .models import AdminType
class BasePermissionDecorator(object):
def __init__(self, func):
self.func = func
def __get__(self, obj, obj_type):
return functools.partial(self.__call__, obj)
2016-10-29 18:17:35 +00:00
def error(self, data):
return JSONResponse({"error": "permission-denied", "data": data})
def __call__(self, *args, **kwargs):
2016-10-29 18:17:35 +00:00
self.request = args[1]
if self.check_permission():
if self.request.user.is_disabled:
2016-10-29 18:17:35 +00:00
return self.error(_("Your account is disabled"))
return self.func(*args, **kwargs)
else:
2016-10-29 18:17:35 +00:00
return self.error(_("Please login in first"))
def check_permission(self):
raise NotImplementedError()
class login_required(BasePermissionDecorator):
def check_permission(self):
return self.request.user.is_authenticated()
class super_admin_required(BasePermissionDecorator):
def check_permission(self):
2016-07-31 12:26:11 +00:00
return self.request.user.is_authenticated() and \
self.request.user.admin_type == AdminType.SUPER_ADMIN
class admin_required(BasePermissionDecorator):
def check_permission(self):
2016-07-31 12:26:11 +00:00
return self.request.user.is_authenticated() and \
self.request.user.admin_type in [AdminType.SUPER_ADMIN, AdminType.ADMIN]