mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-04-05 01:51:28 -04:00
Add a user method to check folder permission
User model is the most natural place for a permission check method, however this means that we need to pass the full user object to service model methods and TemplateList instead of user_id.
This commit is contained in:
@@ -52,7 +52,7 @@ def conversation_reply(
|
||||
templates_and_folders=TemplateList(
|
||||
current_service,
|
||||
template_folder_id=from_folder,
|
||||
user_id=current_user.id,
|
||||
user=current_user,
|
||||
template_type='sms'
|
||||
),
|
||||
template_folder_path=current_service.get_template_folder_path(from_folder),
|
||||
|
||||
@@ -100,7 +100,7 @@ def edit_user_permissions(service_id, user_id):
|
||||
service_id,
|
||||
folder_permissions=[
|
||||
f['id'] for f in current_service.all_template_folders
|
||||
if user_id in f.get('users_with_permission', [])
|
||||
if user.has_template_folder_permission(f)
|
||||
],
|
||||
all_template_folders=current_service.all_template_folders
|
||||
)
|
||||
|
||||
@@ -111,10 +111,10 @@ def start_tour(service_id, template_id):
|
||||
@user_has_permissions()
|
||||
def choose_template(service_id, template_type='all', template_folder_id=None):
|
||||
|
||||
template_list = TemplateList(current_service, template_type, template_folder_id, current_user.id)
|
||||
template_list = TemplateList(current_service, template_type, template_folder_id, current_user)
|
||||
|
||||
templates_and_folders_form = TemplateAndFoldersSelectionForm(
|
||||
all_template_folders=current_service.get_user_template_folders(current_user.id),
|
||||
all_template_folders=current_service.get_user_template_folders(current_user),
|
||||
template_list=template_list,
|
||||
template_type=template_type,
|
||||
allow_adding_letter_template=current_service.has_permission('letter'),
|
||||
@@ -348,7 +348,7 @@ def choose_template_to_copy(
|
||||
services_templates_and_folders=TemplateList(
|
||||
service,
|
||||
template_folder_id=from_folder,
|
||||
user_id=current_user.id
|
||||
user=current_user
|
||||
),
|
||||
template_folder_path=service.get_template_folder_path(from_folder),
|
||||
from_service=service,
|
||||
@@ -361,7 +361,7 @@ def choose_template_to_copy(
|
||||
services_templates_and_folders=TemplateLists([
|
||||
Service(service) for service in
|
||||
user_api_client.get_services_for_user(current_user)
|
||||
], user_id=current_user.id),
|
||||
], user=current_user),
|
||||
search_form=SearchByNameForm(),
|
||||
)
|
||||
|
||||
|
||||
@@ -155,10 +155,10 @@ class Service():
|
||||
def all_template_ids(self):
|
||||
return {template['id'] for template in self.all_templates}
|
||||
|
||||
def get_templates(self, template_type='all', template_folder_id=None, user_id=None):
|
||||
if user_id and template_folder_id and self.has_permission('edit_folder_permissions'):
|
||||
def get_templates(self, template_type='all', template_folder_id=None, user=None):
|
||||
if user and template_folder_id and self.has_permission('edit_folder_permissions'):
|
||||
folder = self.get_template_folder(template_folder_id)
|
||||
if user_id not in folder.get("users_with_permission", []):
|
||||
if not user.has_template_folder_permission(folder):
|
||||
return []
|
||||
|
||||
if isinstance(template_type, str):
|
||||
@@ -403,7 +403,7 @@ class Service():
|
||||
def all_template_folder_ids(self):
|
||||
return {folder['id'] for folder in self.all_template_folders}
|
||||
|
||||
def get_user_template_folders(self, user_id):
|
||||
def get_user_template_folders(self, user):
|
||||
"""Returns a modified list of folders a user has permission to view
|
||||
|
||||
For each folder, we do the following:
|
||||
@@ -422,10 +422,10 @@ class Service():
|
||||
|
||||
user_folders = []
|
||||
for folder in self.all_template_folders:
|
||||
if user_id not in folder.get("users_with_permission", []):
|
||||
if not user.has_template_folder_permission(folder):
|
||||
continue
|
||||
parent = self.get_template_folder(folder["parent_id"])
|
||||
if user_id in parent.get("users_with_permission", []):
|
||||
if user.has_template_folder_permission(parent):
|
||||
user_folders.append(folder)
|
||||
else:
|
||||
folder_attrs = {
|
||||
@@ -439,14 +439,14 @@ class Service():
|
||||
else:
|
||||
parent = self.get_template_folder(parent["parent_id"])
|
||||
folder_attrs["parent_id"] = parent.get("id", None)
|
||||
if user_id in parent.get("users_with_permission", []):
|
||||
if user.has_template_folder_permission(parent):
|
||||
break
|
||||
user_folders.append(folder_attrs)
|
||||
return user_folders
|
||||
|
||||
def get_template_folders(self, template_type='all', parent_folder_id=None, user_id=None):
|
||||
if user_id:
|
||||
folders = self.get_user_template_folders(user_id)
|
||||
def get_template_folders(self, template_type='all', parent_folder_id=None, user=None):
|
||||
if user:
|
||||
folders = self.get_user_template_folders(user)
|
||||
else:
|
||||
folders = self.all_template_folders
|
||||
if parent_folder_id:
|
||||
@@ -456,7 +456,7 @@ class Service():
|
||||
folder for folder in folders
|
||||
if (
|
||||
folder['parent_id'] == parent_folder_id
|
||||
and self.is_folder_visible(folder['id'], template_type, user_id)
|
||||
and self.is_folder_visible(folder['id'], template_type, user)
|
||||
)
|
||||
]
|
||||
|
||||
@@ -469,7 +469,7 @@ class Service():
|
||||
}
|
||||
return self._get_by_id(self.all_template_folders, folder_id)
|
||||
|
||||
def is_folder_visible(self, template_folder_id, template_type='all', user_id=None):
|
||||
def is_folder_visible(self, template_folder_id, template_type='all', user=None):
|
||||
|
||||
if template_type == 'all':
|
||||
return True
|
||||
@@ -478,8 +478,8 @@ class Service():
|
||||
return True
|
||||
|
||||
if any(
|
||||
self.is_folder_visible(child_folder['id'], template_type, user_id)
|
||||
for child_folder in self.get_template_folders(template_type, template_folder_id, user_id)
|
||||
self.is_folder_visible(child_folder['id'], template_type, user)
|
||||
for child_folder in self.get_template_folders(template_type, template_folder_id, user)
|
||||
):
|
||||
return True
|
||||
|
||||
|
||||
@@ -5,28 +5,28 @@ class TemplateList():
|
||||
service,
|
||||
template_type='all',
|
||||
template_folder_id=None,
|
||||
user_id=None,
|
||||
user=None,
|
||||
):
|
||||
self.service = service
|
||||
self.template_type = template_type
|
||||
self.template_folder_id = template_folder_id
|
||||
self.user_id = user_id
|
||||
self.user = user
|
||||
|
||||
def __iter__(self):
|
||||
for item in self.get_templates_and_folders(
|
||||
self.template_type, self.template_folder_id, self.user_id, ancestors=[]
|
||||
self.template_type, self.template_folder_id, self.user, ancestors=[]
|
||||
):
|
||||
yield item
|
||||
|
||||
def get_templates_and_folders(self, template_type, template_folder_id, user_id, ancestors):
|
||||
def get_templates_and_folders(self, template_type, template_folder_id, user, ancestors):
|
||||
|
||||
for item in self.service.get_template_folders(
|
||||
template_type, template_folder_id, user_id,
|
||||
template_type, template_folder_id, user,
|
||||
):
|
||||
yield TemplateListFolder(
|
||||
item,
|
||||
folders=self.service.get_template_folders(
|
||||
template_type, item['id'], user_id
|
||||
template_type, item['id'], user
|
||||
),
|
||||
templates=self.service.get_templates(
|
||||
template_type, item['id']
|
||||
@@ -35,12 +35,12 @@ class TemplateList():
|
||||
service_id=self.service.id,
|
||||
)
|
||||
for sub_item in self.get_templates_and_folders(
|
||||
template_type, item['id'], user_id, ancestors + [item]
|
||||
template_type, item['id'], user, ancestors + [item]
|
||||
):
|
||||
yield sub_item
|
||||
|
||||
for item in self.service.get_templates(
|
||||
template_type, template_folder_id, user_id
|
||||
template_type, template_folder_id, user
|
||||
):
|
||||
yield TemplateListTemplate(
|
||||
item,
|
||||
@@ -59,24 +59,24 @@ class TemplateList():
|
||||
@property
|
||||
def folder_is_empty(self):
|
||||
return not any(self.get_templates_and_folders(
|
||||
'all', self.template_folder_id, self.user_id, []
|
||||
'all', self.template_folder_id, self.user, []
|
||||
))
|
||||
|
||||
|
||||
class TemplateLists():
|
||||
|
||||
def __init__(self, services, user_id=None):
|
||||
def __init__(self, services, user=None):
|
||||
self.services = sorted(
|
||||
services,
|
||||
key=lambda service: service.name.lower(),
|
||||
)
|
||||
self.user_id = user_id
|
||||
self.user = user
|
||||
|
||||
def __iter__(self):
|
||||
|
||||
if len(self.services) == 1:
|
||||
|
||||
for template_or_folder in TemplateList(self.services[0], user_id=self.user_id):
|
||||
for template_or_folder in TemplateList(self.services[0], user=self.user):
|
||||
yield template_or_folder
|
||||
|
||||
return
|
||||
@@ -88,11 +88,11 @@ class TemplateLists():
|
||||
yield template_list_service
|
||||
|
||||
for service_templates_and_folders in TemplateList(
|
||||
service, user_id=self.user_id
|
||||
service, user=self.user
|
||||
).get_templates_and_folders(
|
||||
template_type='all',
|
||||
template_folder_id=None,
|
||||
user_id=self.user_id,
|
||||
user=self.user,
|
||||
ancestors=[template_list_service],
|
||||
):
|
||||
yield service_templates_and_folders
|
||||
|
||||
@@ -151,6 +151,12 @@ class User(UserMixin):
|
||||
def has_permission_for_service(self, service_id, permission):
|
||||
return permission in self._permissions.get(service_id, [])
|
||||
|
||||
def has_template_folder_permission(self, template_folder):
|
||||
if self.platform_admin:
|
||||
return True
|
||||
|
||||
return self.id in template_folder.get("users_with_permission", [])
|
||||
|
||||
def belongs_to_service(self, service_id):
|
||||
return str(service_id) in self.services
|
||||
|
||||
|
||||
@@ -76,7 +76,7 @@ def test_get_user_template_folders_only_returns_folders_visible_to_user(
|
||||
mock_get_template_folders.return_value = _get_all_folders(active_user_with_permissions)
|
||||
service_one['permissions'] = ['edit_folder_permissions']
|
||||
service = Service(service_one)
|
||||
result = service.get_user_template_folders(active_user_with_permissions.id)
|
||||
result = service.get_user_template_folders(active_user_with_permissions)
|
||||
assert result == [
|
||||
{
|
||||
'name': "Parent 1 - invisible / 1's Visible child",
|
||||
@@ -120,7 +120,7 @@ def test_get_template_folders_shows_user_folders_when_user_id_passed_in(
|
||||
mock_get_template_folders.return_value = _get_all_folders(active_user_with_permissions)
|
||||
service_one['permissions'] = ['edit_folder_permissions']
|
||||
service = Service(service_one)
|
||||
result = service.get_template_folders(user_id=active_user_with_permissions.id)
|
||||
result = service.get_template_folders(user=active_user_with_permissions)
|
||||
assert result == [
|
||||
{
|
||||
'name': "Parent 1 - invisible / 1's Visible child",
|
||||
|
||||
Reference in New Issue
Block a user