2016-02-11 22:58:32 +01:00
|
|
|
from ..utils.access_permissions import BaseAccessPermissions
|
2016-12-17 09:30:20 +01:00
|
|
|
from ..utils.auth import has_perm
|
2016-02-11 22:58:32 +01:00
|
|
|
|
|
|
|
|
|
|
|
class MediafileAccessPermissions(BaseAccessPermissions):
|
|
|
|
"""
|
|
|
|
Access permissions container for Mediafile and MediafileViewSet.
|
|
|
|
"""
|
2016-09-17 22:26:23 +02:00
|
|
|
def check_permissions(self, user):
|
2016-02-11 22:58:32 +01:00
|
|
|
"""
|
|
|
|
Returns True if the user has read access model instances.
|
|
|
|
"""
|
2016-12-17 09:30:20 +01:00
|
|
|
return has_perm(user, 'mediafiles.can_see')
|
2016-02-11 22:58:32 +01:00
|
|
|
|
2016-03-02 00:46:19 +01:00
|
|
|
def get_serializer_class(self, user=None):
|
2016-02-11 22:58:32 +01:00
|
|
|
"""
|
|
|
|
Returns serializer class.
|
|
|
|
"""
|
|
|
|
from .serializers import MediafileSerializer
|
|
|
|
|
|
|
|
return MediafileSerializer
|
2016-05-14 14:49:24 +02:00
|
|
|
|
|
|
|
def get_restricted_data(self, full_data, user):
|
|
|
|
"""
|
|
|
|
Returns the restricted serialized data for the instance prepared
|
|
|
|
for the user.
|
|
|
|
"""
|
2017-02-15 16:51:44 +01:00
|
|
|
data = None
|
2017-04-28 00:50:37 +02:00
|
|
|
if has_perm(user, 'mediafiles.can_see') and has_perm(user, 'mediafiles.can_see_hidden'):
|
|
|
|
data = full_data
|
|
|
|
elif has_perm(user, 'mediafiles.can_see'):
|
|
|
|
many_items = not isinstance(full_data, dict)
|
|
|
|
full_data_list = full_data if many_items else [full_data]
|
|
|
|
data = [full_data for full_data in full_data_list if not full_data['hidden']]
|
|
|
|
data = data if many_items else data[0]
|
|
|
|
else:
|
|
|
|
data = None
|
2016-05-14 14:49:24 +02:00
|
|
|
return data
|