mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2024-11-22 19:33:11 +00:00
Merge branch 'Fix_139' into 'master'
Use m2m_changed signal to resync LDAP after a user's group has changed Closes #139 See merge request federez/re2o!183
This commit is contained in:
commit
b0de7f2611
1 changed files with 15 additions and 2 deletions
|
@ -52,7 +52,7 @@ import datetime
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
from django import forms
|
from django import forms
|
||||||
from django.db.models.signals import post_save, post_delete
|
from django.db.models.signals import post_save, post_delete, m2m_changed
|
||||||
from django.dispatch import receiver
|
from django.dispatch import receiver
|
||||||
from django.utils.functional import cached_property
|
from django.utils.functional import cached_property
|
||||||
from django.template import Context, loader
|
from django.template import Context, loader
|
||||||
|
@ -538,7 +538,10 @@ class User(RevMixin, FieldPermissionModelMixin, AbstractBaseUser,
|
||||||
machine__user=self
|
machine__user=self
|
||||||
).values_list('mac_address', flat=True).distinct()]
|
).values_list('mac_address', flat=True).distinct()]
|
||||||
if group_refresh:
|
if group_refresh:
|
||||||
for group in self.groups.all():
|
# Need to refresh all groups because we don't know which groups
|
||||||
|
# were updated during edition of groups and the user may no longer
|
||||||
|
# be part of the updated group (case of group removal)
|
||||||
|
for group in Group.objects.all():
|
||||||
if hasattr(group, 'listright'):
|
if hasattr(group, 'listright'):
|
||||||
group.listright.ldap_sync()
|
group.listright.ldap_sync()
|
||||||
user_ldap.save()
|
user_ldap.save()
|
||||||
|
@ -1018,6 +1021,16 @@ def user_post_save(**kwargs):
|
||||||
regen('mailing')
|
regen('mailing')
|
||||||
|
|
||||||
|
|
||||||
|
@receiver(m2m_changed, sender=User.groups.through)
|
||||||
|
def user_group_relation_changed(**kwargs):
|
||||||
|
action = kwargs['action']
|
||||||
|
if action in ('post_add', 'post_remove', 'post_clear'):
|
||||||
|
user = kwargs['instance']
|
||||||
|
user.ldap_sync(base=False,
|
||||||
|
access_refresh=False,
|
||||||
|
mac_refresh=False,
|
||||||
|
group_refresh=True)
|
||||||
|
|
||||||
@receiver(post_delete, sender=Adherent)
|
@receiver(post_delete, sender=Adherent)
|
||||||
@receiver(post_delete, sender=Club)
|
@receiver(post_delete, sender=Club)
|
||||||
@receiver(post_delete, sender=User)
|
@receiver(post_delete, sender=User)
|
||||||
|
|
Loading…
Reference in a new issue