HimoolERP/apps/system/serializers.py

81 lines
2.4 KiB
Python
Raw Normal View History

2021-11-08 17:27:57 +08:00
from django.contrib.auth.hashers import make_password
2021-12-16 17:54:31 +08:00
from extensions.common.base import *
2021-11-04 23:49:56 +08:00
from extensions.serializers import *
from extensions.exceptions import *
2021-11-08 17:27:57 +08:00
from apps.system.models import *
2021-11-04 23:49:56 +08:00
2021-12-12 15:44:39 +08:00
class PermissionGroupSerializer(BaseSerializer):
2021-11-08 17:27:57 +08:00
2021-12-15 17:40:14 +08:00
class PermissionItemSerializer(BaseSerializer):
2021-11-08 17:27:57 +08:00
2021-12-12 15:44:39 +08:00
class Meta:
model = Permission
fields = ['id', 'name', 'code']
2021-11-08 17:27:57 +08:00
2021-12-15 17:40:14 +08:00
permission_items = PermissionItemSerializer(source='permissions', many=True, label='权限')
2021-11-08 17:27:57 +08:00
class Meta:
2021-12-12 15:44:39 +08:00
model = PermissionGroup
2021-11-08 17:27:57 +08:00
fields = ['id', 'name', 'permission_items']
2021-12-15 17:40:14 +08:00
class SystemConfigSerializer(BaseSerializer):
class Meta:
model = Team
fields = ['enable_auto_stock_in', 'enable_auto_stock_out']
2021-11-08 17:27:57 +08:00
class RoleSerializer(BaseSerializer):
class Meta:
model = Role
read_only_fields = ['id']
fields = ['name', 'remark', 'permissions', *read_only_fields]
2021-11-04 23:49:56 +08:00
2021-11-08 17:27:57 +08:00
class UserSerializer(BaseSerializer):
2021-12-12 15:44:39 +08:00
2021-12-15 17:40:14 +08:00
class RoleItemSerializer(BaseSerializer):
2021-12-12 15:44:39 +08:00
class Meta:
model = Role
fields = ['id', 'name']
2021-11-11 00:23:25 +08:00
sex_display = CharField(source='get_sex_display', read_only=True, label='性别')
2021-12-15 17:40:14 +08:00
role_items = RoleItemSerializer(source='roles', many=True, read_only=True, label='角色Item')
2021-11-08 17:27:57 +08:00
class Meta:
model = User
2021-12-12 15:44:39 +08:00
read_only_fields = ['id', 'sex_display', 'is_manager', 'role_items', 'permissions', 'create_time']
2021-11-08 17:27:57 +08:00
fields = ['username', 'name', 'phone', 'email', 'sex', 'roles', 'is_active', *read_only_fields]
def validate_username(self, value):
self.validate_unique({'username': value}, message=f'用户名[{value}]已存在')
return value
def validate_roles(self, instances):
2021-11-12 01:03:17 +08:00
instances = self.validate_foreign_key_set(Role, instances, message='角色不存在')
2021-11-08 17:27:57 +08:00
return instances
def create(self, validated_data):
2021-12-13 02:14:00 +08:00
validated_data['password'] = make_password(validated_data['username'])
2021-11-08 17:27:57 +08:00
return super().create(validated_data)
2021-12-12 15:44:39 +08:00
def save(self, **kwargs):
permissions = []
if roles := self.validated_data.get('roles'):
permissions = {permission.code for role in roles.prefetch_related('permissions').all()
for permission in role.permissions.all()}
kwargs['permissions'] = list(permissions)
return super().save(**kwargs)
2021-11-08 17:27:57 +08:00
__all__ = [
2021-12-12 15:44:39 +08:00
'PermissionGroupSerializer',
2021-12-15 17:40:14 +08:00
'SystemConfigSerializer',
2021-12-12 15:44:39 +08:00
'RoleSerializer', 'UserSerializer',
2021-11-04 23:49:56 +08:00
]