Move container_relations to cart service for cross-service ownership
container_relations is a generic parent/child graph used by blog (menu_nodes), market (marketplaces), and events (calendars). Move it to cart as shared infrastructure. All services now call cart actions (attach-child/detach-child) instead of querying the table directly. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -4,7 +4,7 @@ from sqlalchemy.ext.asyncio import AsyncSession
|
||||
from sqlalchemy import select, func
|
||||
from shared.models.menu_node import MenuNode
|
||||
from models.ghost_content import Post
|
||||
from shared.services.relationships import attach_child, detach_child
|
||||
from shared.infrastructure.actions import call_action
|
||||
|
||||
|
||||
class MenuItemError(ValueError):
|
||||
@@ -80,7 +80,10 @@ async def create_menu_item(
|
||||
)
|
||||
session.add(menu_node)
|
||||
await session.flush()
|
||||
await attach_child(session, "page", post_id, "menu_node", menu_node.id)
|
||||
await call_action("cart", "attach-child", payload={
|
||||
"parent_type": "page", "parent_id": post_id,
|
||||
"child_type": "menu_node", "child_id": menu_node.id,
|
||||
})
|
||||
|
||||
return menu_node
|
||||
|
||||
@@ -131,8 +134,14 @@ async def update_menu_item(
|
||||
await session.flush()
|
||||
|
||||
if post_id is not None and post_id != old_post_id:
|
||||
await detach_child(session, "page", old_post_id, "menu_node", menu_node.id)
|
||||
await attach_child(session, "page", post_id, "menu_node", menu_node.id)
|
||||
await call_action("cart", "detach-child", payload={
|
||||
"parent_type": "page", "parent_id": old_post_id,
|
||||
"child_type": "menu_node", "child_id": menu_node.id,
|
||||
})
|
||||
await call_action("cart", "attach-child", payload={
|
||||
"parent_type": "page", "parent_id": post_id,
|
||||
"child_type": "menu_node", "child_id": menu_node.id,
|
||||
})
|
||||
|
||||
return menu_node
|
||||
|
||||
@@ -145,7 +154,10 @@ async def delete_menu_item(session: AsyncSession, item_id: int) -> bool:
|
||||
|
||||
menu_node.deleted_at = func.now()
|
||||
await session.flush()
|
||||
await detach_child(session, "page", menu_node.container_id, "menu_node", menu_node.id)
|
||||
await call_action("cart", "detach-child", payload={
|
||||
"parent_type": "page", "parent_id": menu_node.container_id,
|
||||
"child_type": "menu_node", "child_id": menu_node.id,
|
||||
})
|
||||
|
||||
return True
|
||||
|
||||
|
||||
Reference in New Issue
Block a user