Source code for interfaces/csp_if_zmqhub.h

/****************************************************************************
 * **File:** csp/interfaces/csp_if_zmqhub.h
 *
 * **Description:** ZMQ (ZeroMQ) interface.
 *
 * The ZMQ interface is designed to connect to a ZMQ hub, also refered to as
 * zmqproxy. The zmqproxy can be found under examples, and is based on
 * zmq_proxy() - provided by the ZMQ API.
 *
 * For further details on ZMQ, see http://www.zeromq.org.
 ****************************************************************************/
#pragma once

#include <csp/csp_interface.h>

#ifdef __cplusplus
extern "C" {
#endif

[docs]/** max payload data, see documentation */ #define CSP_ZMQ_MTU 2048
[docs]/** * zmqproxy default subscribe (rx) port. * The client must connect it's publish endpoint to the zmqproxy's subscribe port. */ #define CSP_ZMQPROXY_SUBSCRIBE_PORT 6000
[docs]/** * zmqproxy default publish (tx) port. * The client must connect it's subscribe endpoint to the zmqproxy's publish port. */ #define CSP_ZMQPROXY_PUBLISH_PORT 7000
[docs]/** * Default ZMQ interface name. */ #define CSP_ZMQHUB_IF_NAME "ZMQHUB"
[docs]/** * Format endpoint connection string for ZMQ. * * @param[in] host host name of IP. * @param[in] port IP port. * @param[out] buf user allocated buffer for receiving formatted string. * @param[in] buf_size size of buf. * @return #CSP_ERR_NONE on succcess. #CSP_ERR_NOMEM if supplied buffer too small. */ int csp_zmqhub_make_endpoint(const char * host, uint16_t port, char * buf, size_t buf_size);
[docs]/** * Setup ZMQ interface. * * @param[in] addr only receive messages matching this address (255 means all). * This is set as rx_filter in call to * @param[in] host host name or IP of zmqproxy host. Endpoints are * created using the host and the default subscribe/publish ports. * @param[in] flags flags for controlling features on the connection. * @param[out] return_interface created CSP interface. * @return #CSP_ERR_NONE on succcess - else assert. */ int csp_zmqhub_init(uint16_t addr, const char * host, uint32_t flags, csp_iface_t ** return_interface);
[docs]/** * Setup ZMQ interface. * * @param[in] addr only receive messages matching this address (255 means all). * This is set as a \a rx_filter. * @param[in] publish_endpoint publish (tx) endpoint -> connect to * zmqproxy's subscribe port #CSP_ZMQPROXY_SUBSCRIBE_PORT. * @param[in] subscribe_endpoint subscribe (rx) endpoint -> connect * to zmqproxy's publish port #CSP_ZMQPROXY_PUBLISH_PORT. * @param[in] flags flags for controlling features on the connection. * @param[out] return_interface created CSP interface. * @return #CSP_ERR_NONE on succcess - else assert. */ int csp_zmqhub_init_w_endpoints(uint16_t addr, const char * publish_endpoint, const char * subscribe_endpoint, uint32_t flags, csp_iface_t ** return_interface);
[docs]/** * Setup ZMQ interface. * * @param[in] ifname Name of CSP interface, use NULL for default * name #CSP_ZMQHUB_IF_NAME. * @param[in] addr Address assigned to the CSP interface. * rx_filter (const uint16_t) [in]: Rx filters, use NULL for no filters - receive all messages. * rx_filter_count (unsigned int) [in]: Number of Rx filters in \a rx_filter. * @param[in] publish_endpoint publish (tx) endpoint -> connect to * zmqproxy's subscribe port #CSP_ZMQPROXY_SUBSCRIBE_PORT. * @param[in] subscribe_endpoint subscribe (rx) endpoint -> connect to zmqproxy's * publish port #CSP_ZMQPROXY_PUBLISH_PORT. * @param[in] flags flags for controlling features on the connection. * @param[out] return_interface created CSP interface. * @return #CSP_ERR_NONE on succcess - else assert. */ int csp_zmqhub_init_w_name_endpoints_rxfilter(const char * ifname, uint16_t addr, const uint16_t rx_filter[], unsigned int rx_filter_count, const char * publish_endpoint, const char * subscribe_endpoint, uint32_t flags, csp_iface_t ** return_interface);
[docs]/** * Setup filtered ZMQ interface. * The filter can be enabled with promisc = 0, or disabled with promisc = 1. * * The filter only works with CSP 2.0 protocol, because the first two bytes are the * priority and the destination address. ZMQ does not support masking, so the code * actually subscribes to the address once for each priority. It also calculates * the broadcast address and subscribes to that, aagin for each priority. Finally the * global broadcast address is also subscribed to. meaning a total of 3 * 4 filters. * * If a secret key curve zmq is enabled */ int csp_zmqhub_init_filter2(const char * ifname, const char * host, uint16_t addr, uint16_t netmask, int promisc, csp_iface_t ** return_interface, char * sec_key, uint16_t subport, uint16_t pubport);
void csp_zmqhub_fixup_cspv1_add_dest_addr(csp_packet_t * packet);
void * csp_zmqhub_fixup_cspv1_del_dest_addr(uint8_t * rx_data, size_t * datalen);
#ifdef __cplusplus } #endif