mahos.node.client.NodeClient#

class mahos.node.client.NodeClient(gconf: dict, name: NodeName, context: Context | None = None, prefix: str | None = None)#

Client to use Node’s function.

Parameters:
  • gconf – global config dict.

  • name – name of target node.

  • context – communication context.

  • prefix – name prefix for logger.

Variables:
  • conf – target node’s local config.

  • ctx – communication context.

  • logger – configured logger.

Important methods

add_req(gconf: dict, endpoint: str = 'rep_endpoint', rep_type: Type[Reply] | None = None) Requester#

Add and return a Requester for endpoint.

Request timeout (req_timeout_ms) is searched from self.conf or gconf.

add_sub(topic_handler_types: list[tuple[bytes | str, SubHandler | None, Type[Message] | None]], endpoint: str = 'pub_endpoint') list[MessageGetter]#

Subscribe to topics from endpoint registering the handlers.

To do so, add and start a SubWorker for this client.

Parameters:

topic_handler_types – List of (topic, handler, msg_type), (topic, handler) or topic. In second case, msg_type is considered None. In the last case, handler and msg_type are considered None.

Returns:

List of MessageGetters. Length is same as topic_handler_types.

Other methods

__init__(gconf, name[, context, prefix])

close([close_ctx])

Close this client.

full_name()

Get full name: (prefix->)ClientClassName(target_node.joined_name())

get_status()

Get status of node: default implementation is void and raises NotImplementedError.

is_up()

Check if the target is up.

joined_name()

Get target node name as single string 'hostname::nodename'.

name()

Get target node name as a tuple (hostname, nodename).

start_subworker(subw)

Start a thread for a SubWorker.

wait()

Wait until the target is ready.

Attributes

M

The module that defines message types for target node.