Skip to content

Latest commit

 

History

History
503 lines (390 loc) · 23 KB

api-msg-broker.md

File metadata and controls

503 lines (390 loc) · 23 KB

Message Broker API Reference

Message Broker objects wrap around NVIDIA's Message Broker Interface (nv_msgbroker) which in turn wraps around the message protocol adapter libraries listed below.

Important Note: The Message Broker API implementation and documentation are in a very preliminary state - released so that others can contribute on more testing and setup documentation for the various protocol adapter libraries.

See Also:

Important: refer to the DeepStream Plugin Guide for information on the Message Converter and Message Broker, and for information on configuration and use of the different Protocol Adapters.

Message Broker Construction and Destruction

Message Brokers are created by calling dsl_message_broker_new with one of the protocol adapter libraries defined below. As with all DSL Components, Broker objects must be uniquely named from all other DSL components created. Broker objects are destroyed by calling either dsl_message_broker_delete or dsl_message_broker_delete_all

Connection Management.

Message Brokers are connected to a remote entity by calling dsl_message_broker_connect and disconnected by calling dsl_message_broker_disconnect. The current connection state can be uptrained by calling dsl_message_broker_is_connected. Clients can listen for connection events by calling dsl_message_broker_connection_listener_add with a callback of type dsl_message_broker_connection_listener_cb. Note: the particular cases for when the callback is called by each of the protocol adapter libraries is still to be determined.

Sending Asynchronous Messages

Clients can send messages with a specific topic to a remote entity by calling dsl_message_broker_message_send_async, while passing in a callback of type dsl_message_broker_send_result_listener_cb to receive the asynchronous notification of the send operation's success or failure.

Subscribing to Messages

Clients can subscribe to incoming messages for one or more topics sent from a remote entity. A callback of type of dsl_message_broker_subscriber_cb can be added to a Message Broker by calling dsl_message_broker_subscriber_add and removed by calling dsl_message_broker_subscriber_remove.

Note: the protocol adapter library used must support bidirectional messaging. The Azure Module Client library libnvds_azure_edge_proto.so for example.


DeepStream Installed Protocol Adapter Libraries

There are five implementations of the Message API Protocol Adapter Interface(nvds-msgapi) installed with DeepStream under the folder /opt/nvidia/deepstream/deepstream/libs.

Azure MQTT Protocol Adapter Libraries

There are two Azure adapter libraries, one for device clients to send messages to a remote entity, and one for module clients that can send and receive messages as a deployed IoT Edge Module.

Complete setup and usage instructions for both adapter libraries can be found here

AMQP Protocol Adapter Library

still to be tested.

REDIS Protocol Adapter Library

still to be tested.

Kafka Protocol Adapter Library

still to be tested.


Applicable examples

  • message_broker_azure_device_client.py a simple example that sends a "hello world" string to an Azure Hub Instance. How to send more complex payloads in Python is still to be determined. C/C++ is more straight forward.
  • message_broker_azure_module_client.py a simple example that sends "hello world" strings from two different threads, each with their own result callback and unique topic. The same example subscribes to both topics as a way to test the bidirectional messaging. The messages sent to the Azure Hub instance will be sent back to the module client as a simple loop-back test.

Message Broker API

Callback Types:

Constructors:

Destructors:

Methods:

Constants

The following status values are used by the Message Broker API

#define DSL_STATUS_BROKER_OK                                        0
#define DSL_STATUS_BROKER_ERROR                                     1
#define DSL_STATUS_BROKER_RECONNECTING                              2
#define DSL_STATUS_BROKER_NOT_SUPPORTED                             3

Return Values

The following return codes are used by the Message Broker API

#define DSL_RESULT_BROKER_RESULT                                    0x00800000
#define DSL_RESULT_BROKER_NAME_NOT_UNIQUE                           0x00800001
#define DSL_RESULT_BROKER_NAME_NOT_FOUND                            0x00800002
#define DSL_RESULT_BROKER_THREW_EXCEPTION                           0x00800003
#define DSL_RESULT_BROKER_IN_USE                                    0x00800004
#define DSL_RESULT_BROKER_SET_FAILED                                0x00800005
#define DSL_RESULT_BROKER_PARAMETER_INVALID                         0x00800006
#define DSL_RESULT_BROKER_SUBSCRIBER_ADD_FAILED                     0x00800007
#define DSL_RESULT_BROKER_SUBSCRIBER_REMOVE_FAILED                  0x00800008
#define DSL_RESULT_BROKER_LISTENER_ADD_FAILED                       0x00800009
#define DSL_RESULT_BROKER_LISTENER_REMOVE_FAILED                    0x0080000A
#define DSL_RESULT_BROKER_CONFIG_FILE_NOT_FOUND                     0x0080000B
#define DSL_RESULT_BROKER_PROTOCOL_LIB_NOT_FOUND                    0x0080000C
#define DSL_RESULT_BROKER_CONNECT_FAILED                            0x0080000D
#define DSL_RESULT_BROKER_DISCONNECT_FAILED                         0x0080000E
#define DSL_RESULT_BROKER_MESSAGE_SEND_FAILED                       0x0080000F

Callback Types:

dsl_message_broker_connection_listener_cb

typedef void (*dsl_message_broker_connection_listener_cb)(void* client_data, uint status);

Callback typedef for a client to listen for connection events.

Parameters

  • client_data [in] opaque pointer to client's user data, provided by the client.
  • status [in] connection status. One of the DSL_STATUS_BROKER constants defined above.

dsl_message_broker_send_result_listener_cb

typedef void (*dsl_message_broker_send_result_listener_cb)(void* client_data, uint status);

Callback typedef for a client to listen for the asynchronous result when calling dsl_message_broker_message_send_async.

Parameters

  • client_data [in] opaque pointer to client's user data, provided by the client.
  • status [in] result status. One of the DSL_STATUS_BROKER constants defined above.

dsl_message_broker_subscriber_cb

typedef void (*dsl_message_broker_subscriber_cb)(void* client_data, uint status, void* message, 
    uint length, const wchar_t* topic);

Callback typedef for a client to listen for messages received from a remote entity.

Parameters

  • client_data [in] opaque pointer to the client's user data, provided by the client.
  • status [in] message status. One of the DSL_STATUS_BROKER constants defined above.
  • message [in] opaque pointer to the message received.
  • size [in] size of the message in bytes.
  • topic [in] topic for the received message.


Constructors

dsl_message_broker_new

DslReturnType dsl_message_broker_new(const wchar_t* name,
    const wchar_t* broker_config_file, const wchar_t* protocol_lib,
    const wchar_t* connection_string);

The constructor creates a uniquely named Message Broker.

Refer to the nvmsgbroker plugin documentation along with the README files located under the NVIDIA DeepStream installation folders /opt/nvidia/deepstream/deepstream/sources/libs/<protocol-lib-adapter> for information on Broker config settings and connection string syntax for each of the provided protocol adapter libraries.

Parameters

  • name - [in] unique name for the Message Broker to create.
  • broker_config_file - [in] absolute or relative path to a configuration file specific to the protocol-adapter used.
  • protocol_lib - [in] absolute or relative path to the protocol-adapter library to use.
  • connection_string - [in] (optional) full device connection string if not provided in the config file.

Returns

  • DSL_RESULT_SUCCESS on successful creation. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_new('my-message-broker', broker_config_file,
  protocol_lib, None')


Destructors

dsl_message_broker_delete

DslReturnType dsl_message_broker_delete(const wchar_t* name);

This destructor deletes a single named Message Broker. If connected, the broker will be disconnected from the remote entity before deletion.

Parameters

  • name - [in] unique name for the Message Broker to delete.

Returns

  • DSL_RESULT_SUCCESS on successful deletion. One of the Return Values defined above on failure

Python Example

retval = dsl_message_broker_delete('my-message-broker')

dsl_message_broker_delete_all

DslReturnType dsl_message_broker_delete_all();

This destructor deletes all Message Brokers currently in memory. All connected Brokers will be disconnected from the entity before deletion.

Returns

  • DSL_RESULT_SUCCESS on successful deletion. One of the Return Values defined above on failure

Python Example

retval = dsl_message_broker_delete_all()


Methods

dsl_message_broker_connect

DslReturnType dsl_message_broker_connect(const wchar_t* name);

This service attempts to connect the Message Broker to a remote entity. Clients can listen for connection events by adding a callback of type dsl_message_broker_connection_listener_cb by calling dsl_message_broker_connection_listener_add

Parameters

  • name - [in] unique name of the Message Broker to connect.

Returns

  • DSL_RESULT_SUCCESS on successful connection. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_connect('my-message-broker')

dsl_message_broker_disconnect

DslReturnType dsl_message_broker_disconnect(const wchar_t* name);

This service disconnects the Message Broker from a remote entity.

Parameters

  • name - [in] unique name of the Message Broker to disconnect.

Returns

  • DSL_RESULT_SUCCESS on successful disconnection. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_disconnect('my-message-broker')

dsl_message_broker_is_connected

DslReturnType dsl_message_broker_is_connected(const wchar_t* name, boolean* connected);

This service returns the current connected state for the named Message Broker.

Parameters

  • name - [in] unique name of the Message Broker to query.
  • connected - [out] true if the Message Broker is connected, false otherwise.

Returns

  • DSL_RESULT_SUCCESS on successful query. One of the Return Values defined above on failure.

Python Example

retval, connected = dsl_message_broker_is_connected('my-message-broker')

dsl_message_broker_connection_listener_add

DslReturnType dsl_message_broker_connection_listener_add(const wchar_t* name,
    dsl_message_broker_connection_listener_cb listener, void* client_data);

This service adds a callback function of type dsl_message_broker_connection_listener_cb to a named Message Broker. Once added, the client will be called on each connection event that occurs.

Parameters

  • name - [in] unique name of the Action to update.
  • listener - [in] connection listener callback function to add.
  • client_data - [in] opaque pointer to user data returned to the listener when the callback is called.

Returns

  • DSL_RESULT_SUCCESS on successful add. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_connection_listener_add('my-message-broker', connection_listener, None)

dsl_message_broker_connection_listener_remove

DslReturnType dsl_message_broker_connection_listener_remove(const wchar_t* name,
    dsl_message_broker_connection_listener_cb listener);

This service removes a callback function of type dsl_message_broker_connection_listener_cb from a named Message Broker, previously added with dsl_message_broker_connection_listener_add

Parameters

  • name - [in] unique name of the Message Broker to update.
  • listener - [in] connection listener callback function to remove.

Returns

  • DSL_RESULT_SUCCESS on successful removal. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_connection_listener_remove('my-message-broker', connection_listener)

dsl_message_broker_message_send_async

DslReturnType dsl_message_broker_message_send_async(const wchar_t* name,
    const wchar_t* topic, void* message, size_t size,
    dsl_message_broker_send_result_listener_cb result_listener, void* user_data);

This service sends a message with an optional topic to a remote entity asynchronously. A callback function of type dsl_message_broker_send_result_listener_cb is used to signal the client with the asynchronous send result.

Parameters

  • name - [in] unique name of the Message Broker to update.
  • topic - [in] (optional) topic for the message.
  • message - [in] opaque pointer to the message to send.
  • size - [in] size of the message in bytes.
  • client_data - [in] opaque pointer to user data returned to the listener when the callback is called.

Returns

  • DSL_RESULT_SUCCESS on successful add. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_message_send_async('my-message-broker',
  topic, message_body, result_listener, None)

dsl_message_broker_subscriber_add

DslReturnType dsl_message_broker_subscriber_add(const wchar_t* name,
    dsl_message_broker_subscriber_cb subscriber, const wchar_t** topics,
    void* client_data);

This service adds a callback function of type dsl_message_broker_subscriber_cb to a named Message Broker. Once added, the client will be called with each message the Broker receives for one or more specified topics.

Note: Topics must be unique to each Subscriber.

Parameters

  • name - [in] unique name of the Message Broker to update.
  • subscriber - [in] message subscriber callback function to add.
  • topics - [in] NULL terminated list of topics to subscribe to.
  • client_data - [in] opaque pointer to user data returned to the listener when the callback is called.

Returns

  • DSL_RESULT_SUCCESS on successful add. One of the Return Values defined above on failure.

Python Example

topics = ['/dsl/topic1', '/dsl/topic2', '/dsl/topic3', None]

retval = dsl_message_broker_connection_listener_add('my-message-broker',
  message_subscriber, topics, None)

dsl_message_broker_subscriber_remove

DslReturnType dsl_message_broker_subscriber_remove(const wchar_t* name,
    dsl_message_broker_subscriber_cb subscriber);

This service removes a callback function of type dsl_message_broker_subscriber_cb from a named Message Broker, previously added with dsl_message_broker_subscriber_add

Parameters

  • name - [in] unique name of the Message Broker to update.
  • listener - [in] message subscriber callback function to remove.

Returns

  • DSL_RESULT_SUCCESS on successful removal. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_subscriber_remove('my-message-broker', message_subscriber)

dsl_message_broker_settings_get

DslReturnType dsl_message_broker_settings_get(const wchar_t* name,
    const wchar_t** broker_config_file, const wchar_t** protocol_lib,
    const wchar_t** connection_string);

This service gets the current broker setttings in use for a named Message Broker.

Refer to the nvmsgbroker plugin documentation along with the README files located under the NVIDIA DeepStream installation folders /opt/nvidia/deepstream/deepstream/sources/libs/<protocol-lib-adapter> for information on Broker config settings and connection string syntax for each of the provided protocol adapter libraries.

Parameters

  • name - [out] unique name for the Message Broker to query.
  • broker_config_file - [out] absolute path to the configuration file currently in use.
  • protocol_lib - [out] absolute path to the protocol-adapter library in use.
  • connection_string - [out] device connection string, an empty if not defined.

Returns

  • DSL_RESULT_SUCCESS on successful query. One of the Return Values defined above on failure.

Python Example

retval, broker_config_file, protocol_lib, connection_string = dsl_message_broker_settings_get('my-message-broker')

dsl_message_broker_settings_set

DslReturnType dsl_message_broker_settings_set(const wchar_t* name,
    const wchar_t* broker_config_file, const wchar_t* protocol_lib,
    const wchar_t* connection_string);

This service sets new broker setttings for a named Message Broker to use. Note: this service will fail of the Message Broker is currently connected.

Refer to the nvmsgbroker plugin documentation along with the README files located under the NVIDIA DeepStream installation folders /opt/nvidia/deepstream/deepstream/sources/libs/<protocol-lib-adapter> for information on Broker config settings and connection string syntax for each of the provided protocol adapter libraries.

Parameters

  • name - [in] unique name for the Message Broker to update.
  • broker_config_file - [in] absolute or relative path to a configuration file specific to the protocol-adapter used.
  • protocol_lib - [in] absolute or relative path to the protocol-adapter library to use.
  • connection_string - [in] (optional) full device connection string if not provided in the config file.

Returns

  • DSL_RESULT_SUCCESS on successful query. One of the Return Values defined above on failure.

Python Example

retval = dsl_message_broker_settings_set('my-message-broker',
  broker_config_file, protocol_lib, None)

dsl_message_broker_list_size

uint dsl_message_broker_list_size();

This service returns the size of the Message Broker container, i.e. the number of Message Brokers currently in memory.

Returns

  • The size of the Message Broker container

Python Example

size = dsl_message_broker_list_size()


API Reference