2018-11-01 17:30:18 +01:00
|
|
|
from typing import Any, Dict, Set
|
|
|
|
|
2014-11-13 22:23:16 +01:00
|
|
|
from django.apps import AppConfig
|
2019-06-28 07:24:28 +02:00
|
|
|
from django.conf import settings
|
|
|
|
from django.core.exceptions import ImproperlyConfigured
|
2014-11-13 22:23:16 +01:00
|
|
|
|
|
|
|
|
2015-07-01 17:48:41 +02:00
|
|
|
class MediafilesAppConfig(AppConfig):
|
2019-01-06 16:22:33 +01:00
|
|
|
name = "openslides.mediafiles"
|
|
|
|
verbose_name = "OpenSlides Mediafiles"
|
2014-11-13 22:23:16 +01:00
|
|
|
|
|
|
|
def ready(self):
|
|
|
|
# Import all required stuff.
|
2018-11-01 17:30:18 +01:00
|
|
|
from openslides.core.signals import permission_change
|
2015-01-24 16:35:50 +01:00
|
|
|
from openslides.utils.rest_api import router
|
2019-01-27 13:17:17 +01:00
|
|
|
from .projector import register_projector_slides
|
2018-11-01 17:30:18 +01:00
|
|
|
from .signals import get_permission_change_data
|
2015-01-24 16:35:50 +01:00
|
|
|
from .views import MediafileViewSet
|
2018-11-05 09:04:41 +01:00
|
|
|
from . import serializers # noqa
|
2018-11-01 17:30:18 +01:00
|
|
|
from ..utils.access_permissions import required_user
|
2014-11-13 22:23:16 +01:00
|
|
|
|
2019-06-28 07:24:28 +02:00
|
|
|
# Validate, that the media_url is correct formatted:
|
|
|
|
# Must begin and end with a slash. It has to be at least "/".
|
|
|
|
media_url = settings.MEDIA_URL
|
|
|
|
if not media_url.startswith("/") or not media_url.endswith("/"):
|
|
|
|
raise ImproperlyConfigured(
|
|
|
|
"The MEDIA_URL setting must start and end with a slash"
|
|
|
|
)
|
|
|
|
|
2017-08-30 00:07:54 +02:00
|
|
|
# Define projector elements.
|
2019-01-27 13:17:17 +01:00
|
|
|
register_projector_slides()
|
2017-08-30 00:07:54 +02:00
|
|
|
|
2017-02-21 09:34:24 +01:00
|
|
|
# Connect signals.
|
|
|
|
permission_change.connect(
|
|
|
|
get_permission_change_data,
|
2019-01-06 16:22:33 +01:00
|
|
|
dispatch_uid="mediafiles_get_permission_change_data",
|
|
|
|
)
|
2017-02-21 09:34:24 +01:00
|
|
|
|
2015-01-24 16:35:50 +01:00
|
|
|
# Register viewsets.
|
2019-01-06 16:22:33 +01:00
|
|
|
router.register(
|
|
|
|
self.get_model("Mediafile").get_collection_string(), MediafileViewSet
|
|
|
|
)
|
2017-01-14 12:29:42 +01:00
|
|
|
|
2018-11-01 17:30:18 +01:00
|
|
|
# register required_users
|
2019-01-06 16:22:33 +01:00
|
|
|
required_user.add_collection_string(
|
|
|
|
self.get_model("Mediafile").get_collection_string(), required_users
|
|
|
|
)
|
2018-11-01 17:30:18 +01:00
|
|
|
|
2017-01-14 12:29:42 +01:00
|
|
|
def get_startup_elements(self):
|
2017-03-06 16:34:20 +01:00
|
|
|
"""
|
2018-07-09 23:22:26 +02:00
|
|
|
Yields all Cachables required on startup i. e. opening the websocket
|
2017-03-06 16:34:20 +01:00
|
|
|
connection.
|
|
|
|
"""
|
2019-01-06 16:22:33 +01:00
|
|
|
yield self.get_model("Mediafile")
|
2018-11-01 17:30:18 +01:00
|
|
|
|
|
|
|
|
|
|
|
def required_users(element: Dict[str, Any]) -> Set[int]:
|
|
|
|
"""
|
|
|
|
Returns all user ids that are displayed as uploaders in any mediafile
|
|
|
|
if request_user can see mediafiles. This function may return an empty
|
|
|
|
set.
|
|
|
|
"""
|
2019-02-05 20:50:22 +01:00
|
|
|
return set((element["uploader_id"],))
|