diff options
author | 2022-01-23 16:38:03 +0100 | |
---|---|---|
committer | 2022-01-23 16:38:03 +0100 | |
commit | 605d9a0266a9a967f051fa244bf1c2d31776c119 (patch) | |
tree | a9f3218e355c8f6a106ba2604334ce8a34823715 /pydis_site/apps/api/signals.py | |
parent | Link icons belong close together. (diff) | |
parent | Merge pull request #640 from Krish-bhardwaj/main (diff) |
Merge branch 'main' into swfarnsworth/smarter-resources/merge-with-main
Diffstat (limited to 'pydis_site/apps/api/signals.py')
-rw-r--r-- | pydis_site/apps/api/signals.py | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/pydis_site/apps/api/signals.py b/pydis_site/apps/api/signals.py new file mode 100644 index 00000000..5c26bfb6 --- /dev/null +++ b/pydis_site/apps/api/signals.py @@ -0,0 +1,12 @@ +from django.db.models.signals import post_delete +from django.dispatch import receiver + +from pydis_site.apps.api.models.bot import Role, User + + +@receiver(signal=post_delete, sender=Role) +def delete_role_from_user(sender: Role, instance: Role, **kwargs) -> None: + """Unassigns the Role (instance) that is being deleted from every user that has it.""" + for user in User.objects.filter(roles__contains=[instance.id]): + del user.roles[user.roles.index(instance.id)] + user.save() |