modify process_groups_list so it can process any group path, not just the root

process_groups_list now takes an optional group path
This commit is contained in:
mike cullerton 2022-11-11 08:05:38 -05:00
parent f116aed598
commit 2c4b8f5ab2
3 changed files with 19 additions and 6 deletions

View File

@ -141,6 +141,12 @@ paths:
/process-groups: /process-groups:
parameters: parameters:
- name: process_group_identifier
in: query
required: false
description: Optional parameter to filter by a single group
schema:
type: string
- name: page - name: page
in: query in: query
required: false required: false

View File

@ -178,8 +178,11 @@ def process_group_update(
return make_response(jsonify(process_group), 200) return make_response(jsonify(process_group), 200)
def process_groups_list(page: int = 1, per_page: int = 100) -> flask.wrappers.Response: def process_groups_list(process_group_identifier: str = None, page: int = 1, per_page: int = 100) -> flask.wrappers.Response:
"""Process_groups_list.""" """Process_groups_list."""
if process_group_identifier is not None:
process_groups = ProcessModelService().get_process_groups(process_group_identifier)
else:
process_groups = ProcessModelService().get_process_groups() process_groups = ProcessModelService().get_process_groups()
batch = ProcessModelService().get_batch( batch = ProcessModelService().get_batch(
items=process_groups, page=page, per_page=per_page items=process_groups, page=page, per_page=per_page

View File

@ -160,9 +160,9 @@ class ProcessModelService(FileSystemService):
process_models.sort() process_models.sort()
return process_models return process_models
def get_process_groups(self) -> list[ProcessGroup]: def get_process_groups(self, process_group_id: str = None) -> list[ProcessGroup]:
"""Returns the process_groups as a list in display order.""" """Returns the process_groups as a list in display order."""
process_groups = self.__scan_process_groups() process_groups = self.__scan_process_groups(process_group_id)
process_groups.sort() process_groups.sort()
return process_groups return process_groups
@ -254,12 +254,16 @@ class ProcessModelService(FileSystemService):
index += 1 index += 1
return process_groups return process_groups
def __scan_process_groups(self) -> list[ProcessGroup]: def __scan_process_groups(self, process_group_id: str = None) -> list[ProcessGroup]:
"""__scan_process_groups.""" """__scan_process_groups."""
if not os.path.exists(FileSystemService.root_path()): if not os.path.exists(FileSystemService.root_path()):
return [] # Nothing to scan yet. There are no files. return [] # Nothing to scan yet. There are no files.
if process_group_id is not None:
scan_path = os.path.join(FileSystemService.root_path(), process_group_id)
else:
scan_path = FileSystemService.root_path()
with os.scandir(FileSystemService.root_path()) as directory_items: with os.scandir(scan_path) as directory_items:
process_groups = [] process_groups = []
for item in directory_items: for item in directory_items:
# if item.is_dir() and not item.name[0] == ".": # if item.is_dir() and not item.name[0] == ".":