mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2024-12-26 08:53:46 +00:00
Fix #126
This commit is contained in:
parent
cfa6fe097d
commit
11a59ee553
2 changed files with 12 additions and 12 deletions
|
@ -479,16 +479,19 @@ class User(RevMixin, FieldPermissionModelMixin, AbstractBaseUser,
|
|||
interface.save()
|
||||
|
||||
def archive(self):
|
||||
""" Archive l'user : appelle unassign_ips() puis passe state à
|
||||
ARCHIVE"""
|
||||
""" Archive l'user"""
|
||||
self.unassign_ips()
|
||||
self.state = User.STATE_ARCHIVE
|
||||
|
||||
def unarchive(self):
|
||||
""" Désarchive l'user : réassigne ses ip et le passe en state
|
||||
ACTIVE"""
|
||||
""" Désarchive l'user"""
|
||||
self.assign_ips()
|
||||
self.state = User.STATE_ACTIVE
|
||||
|
||||
def state_sync(self):
|
||||
"""Archive, or unarchive, if the user was not active/or archived before"""
|
||||
if self.__original_state != self.STATE_ACTIVE and self.state == self.STATE_ACTIVE:
|
||||
self.unarchive()
|
||||
elif self.__original_state != self.STATE_ARCHIVE and self.state == self.STATE_ARCHIVE:
|
||||
self.archive()
|
||||
|
||||
def ldap_sync(self, base=True, access_refresh=True, mac_refresh=True,
|
||||
group_refresh=False):
|
||||
|
@ -879,6 +882,7 @@ class User(RevMixin, FieldPermissionModelMixin, AbstractBaseUser,
|
|||
'force': self.can_change_force,
|
||||
'selfpasswd': self.check_selfpasswd,
|
||||
}
|
||||
self.__original_state = self.state
|
||||
|
||||
def __str__(self):
|
||||
return self.pseudo
|
||||
|
@ -1007,6 +1011,7 @@ def user_post_save(**kwargs):
|
|||
user = kwargs['instance']
|
||||
if is_created:
|
||||
user.notif_inscription()
|
||||
user.state_sync()
|
||||
user.ldap_sync(
|
||||
base=True,
|
||||
access_refresh=True,
|
||||
|
|
|
@ -221,15 +221,10 @@ def edit_info(request, user, userid):
|
|||
@login_required
|
||||
@can_edit(User, 'state')
|
||||
def state(request, user, userid):
|
||||
""" Changer l'etat actif/desactivé/archivé d'un user,
|
||||
need droit bureau """
|
||||
""" Changer l'etat actif/desactivé/archivé d'un user"""
|
||||
state_form = StateForm(request.POST or None, instance=user)
|
||||
if state_form.is_valid():
|
||||
if state_form.changed_data:
|
||||
if state_form.cleaned_data['state'] == User.STATE_ARCHIVE:
|
||||
user.archive()
|
||||
elif state_form.cleaned_data['state'] == User.STATE_ACTIVE:
|
||||
user.unarchive()
|
||||
state_form.save()
|
||||
messages.success(request, "Etat changé avec succès")
|
||||
return redirect(reverse(
|
||||
|
|
Loading…
Reference in a new issue