from pretor.core.protocol.runnable_object import RunnableObject from pretor.core.workflow_manager.workflow import PretorWorkflow from pretor.adapter_plugin.model_adapter.modelbase import ModelBase import ray from typing import Any,Dict from pretor.individual_plugin.control_node.control_register import ControlRegister from pretor.utils.inspector import inspector #control_node 管控节点,掌管系统的全局状态 @ray.remote class ControlNode(RunnableObject): def __init__(self, **kwargs: Dict[str: Any]) -> None: self.model_adapter : ModelBase = kwargs.get("model_adapter") self.model : str = kwargs.get("model") self.name : str = kwargs.get("name", "管控节点") self.control_register = ControlRegister() def _load_control_register(self) : pass @inspector("individual","control_node") async def run(self, workflow : PretorWorkflow) -> None: control_register = self.control_register.model_dump_json() demand = workflow.status.content.demand.model_dump_json()