mirror of
https://github.com/ansible/awx.git
synced 2024-11-02 09:51:09 +03:00
160 lines
5.0 KiB
Python
160 lines
5.0 KiB
Python
from django.http import HttpResponse
|
|
from django.views.decorators.csrf import csrf_exempt
|
|
from lib.main.models import *
|
|
from lib.main.serializers import *
|
|
from lib.main.rbac import *
|
|
from django.contrib.auth.models import AnonymousUser
|
|
from django.core.exceptions import PermissionDenied
|
|
from rest_framework import mixins
|
|
from rest_framework import generics
|
|
from rest_framework import permissions
|
|
import exceptions
|
|
import datetime
|
|
|
|
# FIXME: machinery for auto-adding audit trail logs to all CREATE/EDITS
|
|
|
|
class BaseList(generics.ListCreateAPIView):
|
|
|
|
def list_permissions_check(self, request, obj=None):
|
|
if request.method == 'GET':
|
|
# everybody can call get, but it's filtered
|
|
return True
|
|
if request.method == 'POST':
|
|
# superusers have already been cleared, so deny regular users
|
|
return False
|
|
raise exceptions.NotImplementedError
|
|
|
|
def get_queryset(self):
|
|
|
|
return self._get_queryset().filter(active=True)
|
|
|
|
class BaseDetail(generics.RetrieveUpdateDestroyAPIView):
|
|
|
|
def destroy(self, request, *args, **kwargs):
|
|
# somewhat lame that delete has to call it's own permissions check
|
|
obj = self.model.objects.get(pk=kwargs['pk'])
|
|
if not request.user.is_superuser and not self.delete_permissions_check(request, obj):
|
|
raise PermissionDenied()
|
|
obj.name = "_deleted_%s_%s" % (str(datetime.time()), obj.name)
|
|
obj.active = False
|
|
obj.save()
|
|
return HttpResponse(status=204)
|
|
|
|
class OrganizationsList(BaseList):
|
|
|
|
model = Organization
|
|
serializer_class = OrganizationSerializer
|
|
permission_classes = (CustomRbac,)
|
|
|
|
# I can see the organizations if:
|
|
# I am a superuser
|
|
# I am an admin of the organization
|
|
# I am a member of the organization
|
|
|
|
def _get_queryset(self):
|
|
if self.request.user.is_superuser:
|
|
return Organization.objects.all()
|
|
return Organization.objects.filter(
|
|
admins__in = [ self.request.user.application_user ]
|
|
).distinct() | Organization.objects.filter(
|
|
users__in = [ self.request.user.application_user ]
|
|
).distinct()
|
|
|
|
class OrganizationsDetail(BaseDetail):
|
|
|
|
model = Organization
|
|
serializer_class = OrganizationSerializer
|
|
permission_classes = (CustomRbac,)
|
|
|
|
# FIXME: use this for the audit trail hook, ideally in base class.
|
|
#def pre_save(self, obj):
|
|
# obj.owner = self.request.user
|
|
|
|
def item_permissions_check(self, request, obj):
|
|
is_admin = request.user.application_user in obj.admins.all()
|
|
is_user = request.user.application_user in obj.users.all()
|
|
|
|
if request.method == 'GET':
|
|
return is_admin or is_user
|
|
elif request.method in [ 'PUT' ]:
|
|
return is_admin
|
|
return False
|
|
|
|
def delete_permissions_check(self, request, obj):
|
|
return request.user.application_user in obj.admins.all()
|
|
|
|
class OrganizationsAuditTrailList(BaseList):
|
|
|
|
model = AuditTrail
|
|
serializer_class = AuditTrailSerializer
|
|
permission_classes = (CustomRbac,)
|
|
|
|
# FIXME: guts & tests
|
|
pass
|
|
|
|
class OrganizationsUsersList(BaseList):
|
|
|
|
model = User
|
|
serializer_class = UserSerializer
|
|
permission_classes = (CustomRbac,)
|
|
|
|
# I can see the users in the organization if:
|
|
# I am a super user
|
|
# I am an admin of the organization
|
|
|
|
def _get_queryset(self):
|
|
# FIXME:
|
|
base = Users.objects.all(organizations__pk__in = [ 'FIXME' ])
|
|
if self.request.user.is_superuser:
|
|
return base.all()
|
|
return base.objects.filter(
|
|
organizations__organization__admins__in = [ self.request.user.application_user ]
|
|
).distinct()
|
|
|
|
|
|
class OrganizationsAdminsList(BaseList):
|
|
|
|
model = User
|
|
serializer_class = UserSerializer
|
|
permission_classes = (CustomRbac,)
|
|
|
|
# I can see the admins in the organization if:
|
|
# I am a super user
|
|
# I am an admin of the organization
|
|
|
|
def _get_queryset(self):
|
|
|
|
# FIXME
|
|
base = Users.objects.all(admin_of_organizations__pk__in = [ 'FIXME' ])
|
|
|
|
if self.request.user.is_superuser:
|
|
return base.all()
|
|
return base.filter(
|
|
organizations__organization__admins__in = [ self.request.user.application_user ]
|
|
).distinct()
|
|
|
|
|
|
class OrganizationsProjectsList(BaseList):
|
|
|
|
# I can see the projects from the organization if:
|
|
# I'm the superuser
|
|
# I am a member of the project
|
|
# I am a an administrator of the organization
|
|
|
|
def _get_queryset(self):
|
|
# FIXME:
|
|
base = Projects.objects.filter(organizations__in = [ 'FIXME' ])
|
|
if self.request.user.is_superuser:
|
|
return base.all()
|
|
return base.filter(
|
|
organizations__organization__admins__in = [ self.request.user.application_user ]
|
|
).distinct() | base.filter(
|
|
users__in = [ self.request.user.application_user ]
|
|
).distinct()
|
|
|
|
class OrganizationsTagsList(BaseList):
|
|
# FIXME: guts & tests
|
|
pass
|
|
|
|
|