MADSci node client implementations.
Sub-modules¶
madsci.client.node.abstract_node_client
madsci.client.node.rest_node_client
Classes¶
AbstractNodeClient(url: pydantic.networks.AnyUrl)Base Node Client, protocol agnostic, all node clients should inherit from or be based on this.
Initialize the client.
Descendants¶
madsci.client.node.rest_node_client.RestNodeClient
Class variables¶
supported_capabilities: ClassVar[madsci.common.types.node_types.NodeClientCapabilities]- The capabilities supported by this node client.
url_protocols: ClassVar[list[str]]- The protocol(s) to use for node URL’s using this client.
Static methods¶
validate_url(url: pydantic.networks.AnyUrl) ‑> bool- check if a url matches this node type
Methods¶
await_action_result(self, action_id: str, timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResult- Wait for an action to complete and return the result. Optionally, specify a timeout in seconds.
get_action_history(self) ‑> dict[str, list[madsci.common.types.action_types.ActionResult]]- Get the history of a specific action, or all actions run by the node.
get_action_result(self, action_id: str) ‑> madsci.common.types.action_types.ActionResult- Get the result of an action on the node.
get_action_status(self, action_id: str) ‑> madsci.common.types.action_types.ActionStatus- Get the status of an action on the node.
get_info(self) ‑> madsci.common.types.node_types.NodeInfo- Get information about the node.
get_log(self) ‑> dict[str, madsci.common.types.event_types.Event]- Get the log of the node.
get_resources(self) ‑> dict[str, madsci.common.types.resource_types.Resource | madsci.common.types.resource_types.Asset | madsci.common.types.resource_types.Consumable | madsci.common.types.resource_types.DiscreteConsumable | madsci.common.types.resource_types.ContinuousConsumable | madsci.common.types.resource_types.Container | madsci.common.types.resource_types.Collection | madsci.common.types.resource_types.Row | madsci.common.types.resource_types.Grid | madsci.common.types.resource_types.VoxelGrid | madsci.common.types.resource_types.Stack | madsci.common.types.resource_types.Queue | madsci.common.types.resource_types.Pool | madsci.common.types.resource_types.Slot]- Get the resources of the node.
get_state(self) ‑> dict[str, typing.Any]- Get the state of the node.
get_status(self) ‑> madsci.common.types.node_types.NodeStatus- Get the status of the node.
send_action(self, action_request: madsci.common.types.action_types.ActionRequest, await_result: bool = True, timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResult- Perform an action on the node.
send_admin_command(self, admin_command: madsci.common.types.admin_command_types.AdminCommands) ‑> madsci.common.types.admin_command_types.AdminCommandResponse- Perform an administrative command on the node.
set_config(self, config_dict: dict[str, typing.Any]) ‑> madsci.common.types.node_types.NodeSetConfigResponse- Set configuration values of the node.
RestNodeClient(url: pydantic.networks.AnyUrl, config: madsci.common.types.client_types.RestNodeClientConfig | None = None)REST-based node client.
Initialize the client.
Args: url: The URL of the node to connect to. config: Client configuration for retry and timeout settings. If not provided, uses default NodeClientConfig.
Ancestors (in MRO)¶
madsci.client.node.abstract_node_client.AbstractNodeClient
Methods¶
await_action_result(self, action_id: str, timeout: float | None = None, request_timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResultWait for an action to complete and return the result. Optionally, specify a timeout in seconds.
Args: action_id: The ID of the action. timeout: Optional timeout in seconds for waiting for the action to complete. request_timeout: Optional timeout override for individual HTTP requests. If None, uses config defaults.
await_action_result_by_name(self, action_name: str, action_id: str, timeout: float | None = None, request_timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResultWait for an action to complete and return the result. Optionally, specify a timeout in seconds. REST-implementation specific.
Args: action_name: The name of the action. action_id: The ID of the action. timeout: Optional timeout in seconds for waiting for the action to complete. request_timeout: Optional timeout override for individual HTTP requests. If None, uses config defaults.
get_action_history(self, action_id: str | None = None, timeout: float | None = None) ‑> dict[str, list[madsci.common.types.action_types.ActionResult]]Get the history of a single action performed on the node, or every action, if no action_id is specified.
Args: action_id: Optional action ID to filter by. timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_action_result(self, action_id: str, timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResultGet the result of an action on the node.
Note: This method uses the legacy API endpoint and cannot fetch files since it lacks the action_name needed for file download URLs.
Args: action_id: The ID of the action. timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_action_result_by_name(self, action_name: str, action_id: str, include_files: bool = True, timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResultGet the result of an action by name. REST-implementation specific.
Args: action_name: The name of the action. action_id: The ID of the action. include_files: Whether to include files in the result. timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_action_status(self, action_id: str, timeout: float | None = None) ‑> madsci.common.types.action_types.ActionStatusGet the status of an action on the node.
Args: action_id: The ID of the action. timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_action_status_by_name(self, action_name: str, action_id: str, timeout: float | None = None) ‑> madsci.common.types.action_types.ActionStatusGet the status of an action by action name.
Args: action_name: The name of the action. action_id: The ID of the action. timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_info(self, timeout: float | None = None) ‑> madsci.common.types.node_types.NodeInfoGet information about the node.
Args: timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_log(self, timeout: float | None = None) ‑> dict[str, madsci.common.types.event_types.Event]Get the log from the node.
Args: timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_state(self, timeout: float | None = None) ‑> dict[str, typing.Any]Get the state of the node.
Args: timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
get_status(self, timeout: float | None = None) ‑> madsci.common.types.node_types.NodeStatusGet the status of the node.
Args: timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
send_action(self, action_request: madsci.common.types.action_types.ActionRequest, await_result: bool = True, timeout: float | None = None, request_timeout: float | None = None) ‑> madsci.common.types.action_types.ActionResultPerform the action defined by action_request on the specified node.
Args: action_request: The action request to send. await_result: Whether to wait for the action to complete. timeout: Optional timeout in seconds for waiting for the action to complete. request_timeout: Optional timeout override for individual HTTP requests. If None, uses config defaults.
send_admin_command(self, admin_command: madsci.common.types.admin_command_types.AdminCommands, timeout: float | None = None) ‑> madsci.common.types.admin_command_types.AdminCommandResponsePerform an administrative command on the node.
Args: admin_command: The administrative command to send. timeout: Optional timeout override in seconds. If None, uses config.timeout_default.
set_config(self, new_config: dict[str, typing.Any], timeout: float | None = None) ‑> madsci.common.types.node_types.NodeSetConfigResponseUpdate configuration values of the node.
Args: new_config: Dictionary of configuration values to update. timeout: Optional timeout override in seconds. If None, uses config.timeout_data_operations.