|
| 1 | +from typing import Any |
| 2 | + |
1 | 3 | from aiohttp import web |
2 | 4 | from models_library.projects import ProjectID |
3 | | -from models_library.projects_nodes import Node |
| 5 | +from models_library.projects_nodes import Node, PartialNode |
4 | 6 | from models_library.projects_nodes_io import NodeID |
5 | 7 | from models_library.services_types import ServiceKey, ServiceVersion |
6 | 8 | from pydantic import TypeAdapter |
7 | 9 | from simcore_postgres_database.utils_projects_nodes import ProjectNodesRepo |
8 | | -from simcore_postgres_database.utils_repos import pass_or_acquire_connection |
| 10 | +from simcore_postgres_database.utils_repos import ( |
| 11 | + pass_or_acquire_connection, |
| 12 | + transaction_context, |
| 13 | +) |
9 | 14 | from simcore_service_webserver.db.plugin import get_asyncpg_engine |
10 | 15 |
|
11 | 16 |
|
@@ -35,3 +40,24 @@ async def get_project_nodes_map( |
35 | 40 | for project_node in project_nodes |
36 | 41 | } |
37 | 42 | return TypeAdapter(dict[NodeID, Node]).validate_python(workbench) |
| 43 | + |
| 44 | + |
| 45 | +async def update_project_nodes_map( |
| 46 | + app: web.Application, |
| 47 | + *, |
| 48 | + project_id: ProjectID, |
| 49 | + partial_nodes_map: dict[NodeID, PartialNode], |
| 50 | +) -> dict[NodeID, Node]: |
| 51 | + repo = ProjectNodesRepo(project_uuid=project_id) |
| 52 | + |
| 53 | + workbench: dict[NodeID, dict[str, Any]] = {} |
| 54 | + async with transaction_context(get_asyncpg_engine(app)) as conn: |
| 55 | + for node_id, node in partial_nodes_map.items(): |
| 56 | + project_node = await repo.update( |
| 57 | + conn, |
| 58 | + node_id=node_id, |
| 59 | + node=node, |
| 60 | + ) |
| 61 | + workbench[node_id] = project_node.model_dump_as_node() |
| 62 | + |
| 63 | + return TypeAdapter(dict[NodeID, Node]).validate_python(workbench) |
0 commit comments