66 lines
2.8 KiB
Python
66 lines
2.8 KiB
Python
from django.apps import apps
|
|
from django.contrib.auth.models import Permission
|
|
from django.contrib.contenttypes.models import ContentType
|
|
from django.db.models import Q
|
|
from django.dispatch import Signal
|
|
|
|
from ..utils.auth import has_perm
|
|
from ..utils.collection import Collection
|
|
from .models import ChatMessage
|
|
|
|
# This signal is send when the migrate command is done. That means it is sent
|
|
# after post_migrate sending and creating all Permission objects. Don't use it
|
|
# for other things than dealing with Permission objects.
|
|
post_permission_creation = Signal()
|
|
|
|
# This signal is sent if a permission is changed (e. g. a group gets a new
|
|
# permission). Connected receivers may yield Collections.
|
|
permission_change = Signal()
|
|
|
|
# This signal is sent if someone wants to see basic user data. Connected
|
|
# receivers may answer a set of user ids that are required for the request
|
|
# user (this can be anything that is allowd as argument for
|
|
# utils.auth.has_perm()) e. g. as motion submitter or assignment candidate.
|
|
user_data_required = Signal(providing_args=['request_user'])
|
|
|
|
|
|
def delete_django_app_permissions(sender, **kwargs):
|
|
"""
|
|
Deletes the permissions, Django creates by default. Only required
|
|
for auth, contenttypes and sessions.
|
|
"""
|
|
contenttypes = ContentType.objects.filter(
|
|
Q(app_label='auth') |
|
|
Q(app_label='contenttypes') |
|
|
Q(app_label='sessions'))
|
|
Permission.objects.filter(content_type__in=contenttypes).delete()
|
|
|
|
|
|
def get_permission_change_data(sender, permissions, **kwargs):
|
|
"""
|
|
Yields all necessary collections if the respective permissions change.
|
|
"""
|
|
core_app = apps.get_app_config(app_label='core')
|
|
for permission in permissions:
|
|
if permission.content_type.app_label == core_app.label:
|
|
if permission.codename == 'can_see_projector':
|
|
yield Collection(core_app.get_model('Projector').get_collection_string())
|
|
elif permission.codename == 'can_manage_projector':
|
|
yield Collection(core_app.get_model('ProjectorMessage').get_collection_string())
|
|
yield Collection(core_app.get_model('Countdown').get_collection_string())
|
|
elif permission.codename == 'can_use_chat':
|
|
yield Collection(core_app.get_model('ChatMessage').get_collection_string())
|
|
|
|
|
|
def required_users(sender, request_user, **kwargs):
|
|
"""
|
|
Returns all user ids that are displayed as chatters if request_user can
|
|
use the chat. This function may return an empty set.
|
|
"""
|
|
chatters = set()
|
|
if has_perm(request_user, 'core.can_use_chat'):
|
|
for chat_message_collection_element in Collection(ChatMessage.get_collection_string()).element_generator():
|
|
full_data = chat_message_collection_element.get_full_data()
|
|
chatters.add(full_data['user_id'])
|
|
return chatters
|