mirror of
https://github.com/trustgraph-ai/trustgraph.git
synced 2026-06-26 07:08:06 +02:00
Workspace identity is now determined by queue infrastructure instead of message body fields, closing a privilege-escalation vector where a caller could spoof workspace in the request payload. - Add WorkspaceProcessor base class: discovers workspaces from config at startup, creates per-workspace consumers (queue:workspace), and manages consumer lifecycle on workspace create/delete events - Roll out to librarian, flow-svc, knowledge cores, and config-svc - Config service gets a dual-queue regime: a system queue for cross-workspace ops (getvalues-all-ws, bootstrapper writes to __workspaces__) and per-workspace queues for tenant-scoped ops, with workspace discovery from its own Cassandra store - Remove workspace field from request schemas (FlowRequest, LibrarianRequest, KnowledgeRequest, CollectionManagementRequest) and from DocumentMetadata / ProcessingMetadata — table stores now accept workspace as an explicit parameter - Strip workspace encode/decode from all message translators and gateway serializers - Gateway enforces workspace existence: reject requests targeting non-existent workspaces instead of routing to queues with no consumer - Config service provisions new workspaces from __template__ on creation - Add workspace lifecycle hooks to AsyncProcessor so any processor can react to workspace create/delete without subclassing WorkspaceProcessor
67 lines
1.7 KiB
Python
67 lines
1.7 KiB
Python
|
|
from dataclasses import dataclass, field
|
|
|
|
from ..core.topic import queue
|
|
from ..core.primitives import Error
|
|
|
|
############################################################################
|
|
|
|
# Flow service:
|
|
# list_blueprints() -> (blueprintname[])
|
|
# get_blueprint(blueprintname) -> (blueprint)
|
|
# put_blueprint(blueprint) -> (blueprint)
|
|
# delete_blueprint(blueprintname) -> ()
|
|
#
|
|
# list_flows() -> (flowid[])
|
|
# get_flow(flowid) -> (flow)
|
|
# start_flow(flowid, blueprintname) -> ()
|
|
# stop_flow(flowid) -> ()
|
|
|
|
@dataclass
|
|
class FlowRequest:
|
|
operation: str = "" # list-blueprints, get-blueprint, put-blueprint, delete-blueprint
|
|
# list-flows, get-flow, start-flow, stop-flow
|
|
|
|
# get_blueprint, put_blueprint, delete_blueprint, start_flow
|
|
blueprint_name: str = ""
|
|
|
|
# put_blueprint
|
|
blueprint_definition: str = ""
|
|
|
|
# start_flow
|
|
description: str = ""
|
|
|
|
# get_flow, start_flow, stop_flow
|
|
flow_id: str = ""
|
|
|
|
# start_flow - optional parameters for flow customization
|
|
parameters: dict[str, str] = field(default_factory=dict)
|
|
|
|
@dataclass
|
|
class FlowResponse:
|
|
# list_blueprints
|
|
blueprint_names: list[str] = field(default_factory=list)
|
|
|
|
# list_flows
|
|
flow_ids: list[str] = field(default_factory=list)
|
|
|
|
# get_blueprint
|
|
blueprint_definition: str = ""
|
|
|
|
# get_flow
|
|
flow: str = ""
|
|
|
|
# get_flow
|
|
description: str = ""
|
|
|
|
# get_flow - parameters used when flow was started
|
|
parameters: dict[str, str] = field(default_factory=dict)
|
|
|
|
# Everything
|
|
error: Error | None = None
|
|
|
|
flow_request_queue = queue('flow', cls='request')
|
|
flow_response_queue = queue('flow', cls='response')
|
|
|
|
############################################################################
|
|
|