OpenSlides/openslides/mediafiles/access_permissions.py

38 lines
1.3 KiB
Python
Raw Normal View History

2019-07-12 17:48:16 +02:00
from typing import Any, Dict, List
2018-08-22 22:00:08 +02:00
from ..utils.access_permissions import BaseAccessPermissions
2019-07-12 17:48:16 +02:00
from ..utils.auth import async_has_perm, async_in_some_groups, async_is_superadmin
class MediafileAccessPermissions(BaseAccessPermissions):
"""
Access permissions container for Mediafile and MediafileViewSet.
"""
2019-01-06 16:22:33 +01:00
base_permission = "mediafiles.can_see"
async def get_restricted_data(
2019-01-06 16:22:33 +01:00
self, full_data: List[Dict[str, Any]], user_id: int
) -> List[Dict[str, Any]]:
"""
Returns the restricted serialized data for the instance prepared
for the user. Removes hidden mediafiles for some users.
"""
if not await async_has_perm(user_id, "mediafiles.can_see"):
return []
2019-07-12 17:48:16 +02:00
# This allows to see everything, which is important for inherited_access_groups=False.
if await async_is_superadmin(user_id):
return full_data
data = []
for full in full_data:
access_groups = full["inherited_access_groups_id"]
2019-07-12 17:48:16 +02:00
if (isinstance(access_groups, bool) and access_groups) or (
isinstance(access_groups, list)
and await async_in_some_groups(user_id, access_groups)
):
data.append(full)
return data