Co-authored-by: Eve832 <eve.meelan@grafana.com>
Co-authored-by: Francisco Montes de Oca <nevermind89x@gmail.com>
Co-authored-by: Ildar Iskhakov <ildar.iskhakov@grafana.com>
Co-authored-by: Innokentii Konstantinov <innokenty.konstantinov@grafana.com>
Co-authored-by: Julia <ferril.darkdiver@gmail.com>
Co-authored-by: maskin25 <kengurek@gmail.com>
Co-authored-by: Matias Bordese <mbordese@gmail.com>
Co-authored-by: Matvey Kukuy <motakuk@gmail.com>
Co-authored-by: Michael Derynck <michael.derynck@grafana.com>
Co-authored-by: Richard Hartmann <richih@richih.org>
Co-authored-by: Robby Milo <robbymilo@fastmail.com>
Co-authored-by: Timur Olzhabayev <timur.olzhabayev@grafana.com>
Co-authored-by: Vadim Stepanov <vadimkerr@gmail.com>
Co-authored-by: Yulia Shanyrova <yulia.shanyrova@grafana.com>
49 lines
1.4 KiB
Python
49 lines
1.4 KiB
Python
from typing import Any
|
|
|
|
from rest_framework import permissions
|
|
from rest_framework.authentication import BasicAuthentication, SessionAuthentication
|
|
from rest_framework.request import Request
|
|
from rest_framework.viewsets import ViewSet
|
|
|
|
from common.constants.role import Role
|
|
|
|
|
|
class RolePermission(permissions.BasePermission):
|
|
ROLE = None
|
|
|
|
def has_permission(self, request: Request, view: ViewSet) -> bool:
|
|
return request.user.role == type(self).ROLE
|
|
|
|
def has_object_permission(self, request: Request, view: ViewSet, obj: Any) -> bool:
|
|
return self.has_permission(request, view)
|
|
|
|
|
|
class IsAdmin(RolePermission):
|
|
ROLE = Role.ADMIN
|
|
|
|
|
|
class IsEditor(RolePermission):
|
|
ROLE = Role.EDITOR
|
|
|
|
|
|
class IsViewer(RolePermission):
|
|
ROLE = Role.VIEWER
|
|
|
|
|
|
IsAdminOrEditor = IsAdmin | IsEditor
|
|
AnyRole = IsAdmin | IsEditor | IsViewer
|
|
|
|
|
|
class IsStaff(permissions.BasePermission):
|
|
STAFF_AUTH_CLASSES = [BasicAuthentication, SessionAuthentication]
|
|
|
|
def has_permission(self, request: Request, view: ViewSet) -> bool:
|
|
user = request.user
|
|
if not any(isinstance(request._authenticator, x) for x in self.STAFF_AUTH_CLASSES):
|
|
return False
|
|
if user and user.is_authenticated:
|
|
return user.is_staff
|
|
return False
|
|
|
|
def has_object_permission(self, request: Request, view: ViewSet, obj: Any) -> bool:
|
|
return self.has_permission(request, view)
|