From 45ae11a1b0e5a27efd3017d42e347ad9b382b5fb Mon Sep 17 00:00:00 2001 From: "M. Rehan" Date: Fri, 2 Aug 2024 10:15:55 +0500 Subject: [PATCH] Separately report images being used by apps --- src/middlewared/middlewared/plugins/apps/crud.py | 4 ++-- src/middlewared/middlewared/plugins/apps/ix_apps/query.py | 8 +++++++- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/src/middlewared/middlewared/plugins/apps/crud.py b/src/middlewared/middlewared/plugins/apps/crud.py index 09dd55e234839..635dfd6f588a2 100644 --- a/src/middlewared/middlewared/plugins/apps/crud.py +++ b/src/middlewared/middlewared/plugins/apps/crud.py @@ -29,7 +29,7 @@ class Config: 'app_query', Str('name'), Str('id'), - Str('state'), + Str('state', enum=['STOPPED', 'DEPLOYING', 'RUNNING']), Bool('upgrade_available'), Str('human_version'), Str('version'), @@ -52,7 +52,7 @@ class Config: Str('service_name'), Str('image'), List('port_config'), - Str('state'), + Str('state', enum=['running', 'starting', 'exited']), List('volume_mounts'), )]), List('volumes', items=[Dict( diff --git a/src/middlewared/middlewared/plugins/apps/ix_apps/query.py b/src/middlewared/middlewared/plugins/apps/ix_apps/query.py index 8d33c9cfc384e..c20c78ff8a6d5 100644 --- a/src/middlewared/middlewared/plugins/apps/ix_apps/query.py +++ b/src/middlewared/middlewared/plugins/apps/ix_apps/query.py @@ -128,6 +128,7 @@ def get_default_workload_values() -> dict: 'used_ports': [], 'container_details': [], # This would contain service name and image in use 'volumes': [], # This would be docker volumes + 'images': [], } @@ -140,10 +141,12 @@ def translate_resources_to_desired_workflow(app_resources: dict) -> dict: # Container mounts workloads = get_default_workload_values() volumes = set() + images = set() workloads['containers'] = len(app_resources['containers']) for container in app_resources['containers']: service_name = container['Config']['Labels'][COMPOSE_SERVICE_KEY] container_ports_config = [] + images.add(container['Config']['Image']) for container_port, host_config in container.get('NetworkSettings', {}).get('Ports', {}).items(): if not host_config: # This will happen for ports which are not exposed on the host side @@ -186,5 +189,8 @@ def translate_resources_to_desired_workflow(app_resources: dict) -> dict: workloads['used_ports'].extend(container_ports_config) volumes.update(volume_mounts) - workloads['volumes'] = [v.__dict__ for v in volumes] + workloads.update({ + 'images': list(images), + 'volumes': [v.__dict__ for v in volumes], + }) return workloads