mirror of https://github.com/jumpserver/jumpserver
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
78 lines
2.8 KiB
78 lines
2.8 KiB
from django.db.models import F
|
|
from rest_framework.serializers import ModelSerializer
|
|
from rest_framework import serializers
|
|
|
|
from users.models.user import User
|
|
from common.serializers import AdaptedBulkListSerializer
|
|
from common.drf.serializers import BulkModelSerializer
|
|
from common.db.models import concated_display as display
|
|
from .models import Organization, OrganizationMember, ROLE as ORG_ROLE
|
|
|
|
|
|
class OrgSerializer(ModelSerializer):
|
|
users = serializers.PrimaryKeyRelatedField(many=True, queryset=User.objects.all(), write_only=True)
|
|
admins = serializers.PrimaryKeyRelatedField(many=True, queryset=User.objects.all(), write_only=True)
|
|
auditors = serializers.PrimaryKeyRelatedField(many=True, queryset=User.objects.all(), write_only=True)
|
|
|
|
class Meta:
|
|
model = Organization
|
|
list_serializer_class = AdaptedBulkListSerializer
|
|
fields_mini = ['id', 'name']
|
|
fields_small = fields_mini + [
|
|
'created_by', 'date_created', 'comment'
|
|
]
|
|
fields_m2m = ['users', 'admins', 'auditors']
|
|
fields = fields_small + fields_m2m
|
|
read_only_fields = ['created_by', 'date_created']
|
|
|
|
def create(self, validated_data):
|
|
members = self._pop_memebers(validated_data)
|
|
instance = Organization.objects.create(**validated_data)
|
|
OrganizationMember.objects.add_users_by_role(instance, *members)
|
|
return instance
|
|
|
|
def _pop_memebers(self, validated_data):
|
|
return (
|
|
validated_data.pop('users', None),
|
|
validated_data.pop('admins', None),
|
|
validated_data.pop('auditors', None)
|
|
)
|
|
|
|
def update(self, instance, validated_data):
|
|
members = self._pop_memebers(validated_data)
|
|
for attr, value in validated_data.items():
|
|
setattr(instance, attr, value)
|
|
instance.save()
|
|
OrganizationMember.objects.set_users_by_role(instance, *members)
|
|
return instance
|
|
|
|
|
|
class OrgReadSerializer(OrgSerializer):
|
|
pass
|
|
|
|
|
|
class OrgMemberSerializer(BulkModelSerializer):
|
|
org_display = serializers.CharField()
|
|
user_display = serializers.CharField()
|
|
role_display = serializers.CharField(source='get_role_display')
|
|
|
|
class Meta:
|
|
model = OrganizationMember
|
|
fields = ('id', 'org', 'user', 'role', 'org_display', 'user_display', 'role_display')
|
|
|
|
@classmethod
|
|
def setup_eager_loading(cls, queryset):
|
|
return queryset.annotate(
|
|
org_display=F('org__name'),
|
|
user_display=display('user__name', 'user__username')
|
|
).distinct()
|
|
|
|
|
|
class OrgRetrieveSerializer(OrgReadSerializer):
|
|
admins = serializers.PrimaryKeyRelatedField(many=True, read_only=True)
|
|
auditors = serializers.PrimaryKeyRelatedField(many=True, read_only=True)
|
|
users = serializers.PrimaryKeyRelatedField(many=True, read_only=True)
|
|
|
|
class Meta(OrgReadSerializer.Meta):
|
|
pass
|