Previous
Machine management
When you connect to a machine using an SDK, the SDK connects to the machine’s viam-server instance as a client.
The period of time during which a client is connected to a machine is called a session.
Session management is a safety precaution that allows you to manage the clients that are authenticated and communicating with a machine’s viam-server instance.
The default session management configuration checks for presence to ensure that a machine only moves when a client is actively connected and stops any components that remain running when a client disconnects.
This is especially important for machines that physically move.
For example, imagine a wheeled rover gets a SetPower() command as the last input from a client before the connection to the machine is interrupted.
Without session management, the API request from the client would cause the rover’s motors to move, causing the machine to continue driving forever and potentially colliding with objects and people.
For more information, see Client Sessions and Machine Network Connectivity.
If you want to manage operations differently, you can manage your machine’s client sessions yourself. The Session Management API provides functionality for:
SessionsClientA client of a Viam machine can be a program using an SDK to control the machine, or all the different resources on the machine, including all parts and sub-parts, like an input controller and a base, communicating.
For example, if you use Viam’s module registry to add modular resources to your machine, the clients of your machine will include the model servers you instantiate on your machine for individual resources, as well as the SDKs you are using to program the modular resources.
Viam’s session management API’s SessionsClient is a built-in solution that manages the connection between your machine’s clients and your machine.
If you connect to your machine using one of Viam’s SDKs, the resulting client will automatically maintain the session by sending a heartbeat notifying the machine’s viam-server instance of its continued presence.
The SessionsClient on the machine maintains an overview of all sessions based on the clients’ heartbeat messages.
If the machine does not receive a signal from the client in the expected interval, the machine ends the session and stop all resources that are marked for safety monitoring and have been last used by that session. That means if a client sends a command to a machine to move the motors and then loses the connection, the machine will stop moving.
If a resource was used by client A and then by client B, and client A disconnects, the resource will not be stopped, regardless of possibly ongoing commands initiated by client A.
A disconnected client will attempt to establish a new session immediately prior to the next operation it performs.
The default session timeout length is 20 seconds.
To change this, pass the timeout parameter to the DialOptions object:
opts = RobotClient.Options(dial_options=DialOptions(timeout=10)).with_api_key(
  # TODO: Replace "<API-KEY>" (including brackets) with your machine's
  # API key
  api_key='<API-KEY>',
  # TODO: Replace "<API-KEY-ID>" (including brackets) with your machine's
  # API key ID
  api_key_id='<API-KEY-ID>'
)
await RobotClient.at_address('<machine address>', opts)
// Import the time package in addition to the other imports:
import (
  ...
  "time"
  ...
)
// Configure a timeoutContext, then pass this context to the client:
func main() {
  ctx := context.Background()
  timeoutContext, cancel := context.WithTimeout(ctx, 10*time.Second)
  logger := logging.NewDebugLogger("client")
  machine, err := client.New(
    timeoutContext,
    "<machine address>",
    logger,
    client.WithDialOptions(rpc.WithEntityCredentials(
      // Replace "<API-KEY-ID>" (including brackets) with your machine's
      // API key ID
      "<API-KEY-ID>",
      rpc.Credentials{
        Type:    rpc.CredentialsTypeAPIKey,
        // Replace "<API-KEY>" (including brackets) with your machine's API key
        Payload: "<API-KEY>",
      })),
  )
  ...
}
const machine = await VIAM.createRobotClient({
  host,
  credentials: {
    type: "api-key",
    /* Replace "<API-KEY>" (including brackets) with your machine's API key */
    payload: "<API-KEY>",
    authEntity: "<API-KEY-ID>",
    /* Replace "<API-KEY-ID>" (including brackets) with your machine's API key ID */
  },
  signalingAddress: "https://app.viam.com:443",
  dialTimeout: 1000,
});
std::string host("guardian-main.vw3iu72d8n.viam.cloud");
DialOptions dial_opts;
dial_opts.set_entity(std::string("<API-KEY-ID>"));
/* Replace "<API-KEY-ID>" (including brackets) with your machine's API key ID */
Credentials credentials("api-key", "<API-KEY>");
/* Replace "<API-KEY>" (including brackets) with your machine's API key */
dial_opts.set_credentials(credentials);
dial_opts.set_timeout(std::chrono::duration<float>(10));
boost::optional<DialOptions> opts(dial_opts);
Options options(0, opts);
auto machine = RobotClient::at_address(host, options);
Future<void> connectToViam() async {
  const host = '<machine-address>';
  /* Replace "<API-KEY-ID>" (including brackets) with your machine's API key ID */
  const apiKeyID = '<API-KEY-ID>';
  /* Replace "<API-KEY>" (including brackets) with your machine's API key */
  const apiKey = '<API-KEY>';
  final machine = await RobotClient.atAddress(
    host,
    RobotClientOptions.withApiKey(apiKeyID, apiKey)
      ..dialOptions.timeout = Duration(seconds: 10)
  );
  print(machine.resourceNames);
}
The Session Management API is not currently provided in the Python or TypeScript SDKs. Use the Go Client SDK instead.
If you are looking to implement session management yourself only to increase the session window, you can increase the session window instead, by increasing the heartbeat_window in the network configuration.
To manage your session with the session management API:
The SessionsClient that serves the session management API is automatically enabled on your machine.
It is instantiated as part of your RobotClient instance (client of the Machine API).
If you want to disable it, you can pass the option to your machine, as demonstrated in the following code snippets:
async def main():
    opts = RobotClient.Options(disable_sessions=True)
    await RobotClient.at_address("my-machine-address", opts)
    robot = await connect()
For more information, see the Python SDK Docs.
robot, err := client.New(
  ctx, "my-machine-address",
  logger,
  client.WithDisableSessions(),
  ...)
For more information, see the Go SDK Docs
const robot = await VIAM.createRobotClient({
  // ...
  disableSessions: true,
  // ...
});
For more information, see the TypeScript SDK Docs.
This option allows you to have full control over sessions management. After disabling the client, you must now manage each of your sessions manually with the session management API. You can do this with Viam’s client SDKs.
Use your RobotClient() instance to access the SessionsClient within your client SDK program.
This is a gRPC client that viam-server instantiates at robot runtime.
Then, define your own SessionsClient.
Was this page helpful?
Glad to hear it! If you have any other feedback please let us know:
We're sorry about that. To help us improve, please tell us what we can do better:
Thank you!