From d5d5cab845bde1d2769291ea056ae746de8efedb Mon Sep 17 00:00:00 2001 From: Nicolas Pennec Date: Tue, 10 Sep 2024 12:45:28 +0200 Subject: [PATCH 1/2] [breakdown] fetch missing columns on get casting with shared assets --- zou/app/services/breakdown_service.py | 30 ++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/zou/app/services/breakdown_service.py b/zou/app/services/breakdown_service.py index 2c2d5a4924..7e41f799ad 100644 --- a/zou/app/services/breakdown_service.py +++ b/zou/app/services/breakdown_service.py @@ -99,11 +99,27 @@ def get_production_episodes_casting(project_id): .join(EntityType, Entity.entity_type_id == EntityType.id) .filter(Episode.project_id == project_id) .filter(Entity.canceled != True) - .add_columns(Entity.name, EntityType.name, Entity.preview_file_id) - .order_by(EntityType.name, Entity.name) + .add_columns( + Entity.name, + EntityType.name, + Entity.preview_file_id, + Entity.is_shared, + Entity.project_id, + ) + .order_by( + EntityType.name, + Entity.name, + ) ) - for link, entity_name, entity_type_name, entity_preview_file_id in links: + for ( + link, + entity_name, + entity_type_name, + entity_preview_file_id, + entity_is_shared, + entity_project_id, + ) in links: episode_id = str(link.entity_in_id) if episode_id not in castings: castings[episode_id] = [] @@ -118,6 +134,8 @@ def get_production_episodes_casting(project_id): ), "nb_occurences": link.nb_occurences, "label": link.label, + "is_shared": entity_is_shared, + "project_id": entity_project_id, } ) return castings @@ -145,6 +163,8 @@ def get_sequence_casting(sequence_id, project_id=None, episode_id=None): Entity.name, EntityType.name, Entity.preview_file_id, + Entity.is_shared, + Entity.project_id, Sequence.name, ) ) @@ -169,6 +189,8 @@ def get_sequence_casting(sequence_id, project_id=None, episode_id=None): entity_name, entity_type_name, entity_preview_file_id, + entity_is_shared, + entity_project_id, sequence_name, ) in links: shot_id = str(link.entity_in_id) @@ -186,6 +208,8 @@ def get_sequence_casting(sequence_id, project_id=None, episode_id=None): ), "nb_occurences": link.nb_occurences, "label": link.label, + "is_shared": entity_is_shared, + "project_id": entity_project_id, } ) return castings From 4a7d5a06d81c11cf9831c44e5f41fc2521f55528 Mon Sep 17 00:00:00 2001 From: Nicolas Pennec Date: Tue, 10 Sep 2024 13:33:20 +0200 Subject: [PATCH 2/2] [assets] allow to set as shared when creating an asset --- zou/app/blueprints/assets/resources.py | 13 ++++++++++++- zou/app/services/assets_service.py | 3 +++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/zou/app/blueprints/assets/resources.py b/zou/app/blueprints/assets/resources.py index d3c550c2a0..8d349d22aa 100644 --- a/zou/app/blueprints/assets/resources.py +++ b/zou/app/blueprints/assets/resources.py @@ -435,6 +435,7 @@ def post(self, project_id, asset_type_id): - name - description - data + - is_shared - source_id properties: name: @@ -443,6 +444,8 @@ def post(self, project_id, asset_type_id): type: string data: type: string + is_shared: + type: boolean source_id: type: string format: UUID @@ -451,7 +454,7 @@ def post(self, project_id, asset_type_id): 201: description: New asset resource created """ - (name, description, data, source_id) = self.get_arguments() + (name, description, data, is_shared, source_id) = self.get_arguments() user_service.check_manager_project_access(project_id) asset = assets_service.create_asset( @@ -460,6 +463,7 @@ def post(self, project_id, asset_type_id): name, description, data, + is_shared, source_id, created_by=persons_service.get_current_user()["id"], ) @@ -475,6 +479,12 @@ def get_arguments(self): }, "description", ("data", {}, False, dict), + ( + "is_shared", + True, + False, + bool, + ), "episode_id", ] ) @@ -483,6 +493,7 @@ def get_arguments(self): args["name"], args.get("description", ""), args["data"], + args["is_shared"], args["episode_id"], ) diff --git a/zou/app/services/assets_service.py b/zou/app/services/assets_service.py index 83b6444f92..4139dee6c0 100644 --- a/zou/app/services/assets_service.py +++ b/zou/app/services/assets_service.py @@ -306,6 +306,7 @@ def get_assets_and_tasks(criterions={}, page=1, with_episode_ids=False): "episode_id": source_id, "casting_episode_ids": cast_in_episode_ids.get(asset_id, []), "is_casting_standby": asset.is_casting_standby, + "is_shared": asset.is_shared, "data": data, "tasks": [], } @@ -571,6 +572,7 @@ def create_asset( name, description, data, + is_shared=False, source_id=None, created_by=None, ): @@ -587,6 +589,7 @@ def create_asset( name=name, description=description, data=data, + is_shared=is_shared, source_id=source_id, created_by=created_by, )