fix role & role pernissions for user
This commit is contained in:
@@ -139,17 +139,17 @@ class UserRelationSerializer(serializers.ModelSerializer):
|
||||
# set permissions by a default structure like:
|
||||
# 'page permission':[element permissions]
|
||||
permissions = instance.permissions.filter(is_active=True)
|
||||
representation['permissions'] = PermissionSerializer().permissions_structure_output(permissions)
|
||||
representation['permissions'] = (
|
||||
PermissionSerializer().permissions_structure_output(permissions) +
|
||||
PermissionSerializer().permissions_structure_output(instance.role.permissions.all())
|
||||
)
|
||||
|
||||
return representation
|
||||
|
||||
def update(self, instance, validated_data):
|
||||
""" update user relation object """
|
||||
|
||||
# if role of user changed, clear all permissions and set new role permissions for user
|
||||
if not instance.role == validated_data.get('role', instance.role):
|
||||
instance.role = validated_data.get('role', instance.role)
|
||||
instance.permissions.clear()
|
||||
instance.permissions.add(*instance.role.permissions.all())
|
||||
|
||||
instance.organization = validated_data.get('organization', instance.organization)
|
||||
instance.save()
|
||||
|
||||
@@ -4,21 +4,21 @@ from django.db.models.signals import post_save, post_delete
|
||||
from django.dispatch import receiver
|
||||
|
||||
|
||||
@receiver([post_save], sender=UserRelations)
|
||||
def sync_role_permissions(sender, instance, **kwargs):
|
||||
""" add role permissions to user relation permissions in is null """
|
||||
|
||||
# if _from_signal=True prevent from maximum recursion loop
|
||||
if getattr(instance, '_from_signal', False):
|
||||
return
|
||||
|
||||
if instance.role:
|
||||
permissions = instance.role.permissions.all()
|
||||
if not instance.permissions.exists():
|
||||
instance.permissions.add(*permissions) # noqa
|
||||
|
||||
instance._from_signal = True
|
||||
instance.save()
|
||||
# @receiver([post_save], sender=UserRelations)
|
||||
# def sync_role_permissions(sender, instance, **kwargs):
|
||||
# """ add role permissions to user relation permissions in is null """
|
||||
#
|
||||
# # if _from_signal=True prevent from maximum recursion loop
|
||||
# if getattr(instance, '_from_signal', False):
|
||||
# return
|
||||
#
|
||||
# if instance.role:
|
||||
# permissions = instance.role.permissions.all()
|
||||
# if not instance.permissions.exists():
|
||||
# instance.permissions.add(*permissions) # noqa
|
||||
#
|
||||
# instance._from_signal = True
|
||||
# instance.save()
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user