libemq - is an open source client library for the EagleMQ written in C.
It has been designed to be light on memory usage, high performance, and provide full access to server side methods.
Connect to the EagleMQ server via TCP protocol.
№ | Name | Description |
1 | addr | the server IP |
2 | port | the server port |
Return: emq_client on success, NULL on error.
Connect to the EagleMQ server via unix domain socket.
№ | Name | Description |
1 | path | the path to unix domain socket |
Return: emq_client on success, NULL on error.
Disconnects the client from the server and removes the connection context.
№ | Name | Description |
1 | client | the context of a client connection |
Enable noack mode.
When enabled, the server does not respond to commands status messages and the result is always EMQ_STATUS_OK. Using this option is useful for performance. Also, it should be used to send commands if you are subscribed to the queue.
№ | Name | Description |
1 | client | the context of a client connection |
Disable noack mode.
№ | Name | Description |
1 | client | the context of a client connection |
Processing of all server events.
№ | Name | Description |
1 | client | the context of a client connection |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Initialize the list iterator.
№ | Name | Direction | Description |
1 | list | in | the list |
2 | iter | out | the list iterator |
Gets the next value list.
№ | Name | Description |
1 | iter | the list iterator |
Return: emq_list_node.
Delete list.
№ | Name | Description |
1 | list | the list |
Description of the last error client.
№ | Name | Description |
1 | client | the context of a client connection |
Return: description of the error.
Returns the version libemq.
Return: version libemq.
Create a new message.
№ | Name | Description |
1 | data | the message data |
2 | size | the message size |
3 | zero_copy | flag to use zero copy (EMQ_ZEROCOPY_ON, EMQ_ZEROCOPY_OFF) |
Return: new message.
Copy the message.
№ | Name | Description |
1 | msg | the message |
Return: copy of the message.
Set expiration time for message.
№ | Name | Description |
1 | msg | the message |
2 | time | the time (in miliseconds) |
Get the message data.
№ | Name | Description |
1 | msg | the message |
Return: message data.
Get the message size.
№ | Name | Description |
1 | msg | the message |
Return: size of the message.
Get tag of the message.
№ | Name | Description |
1 | msg | the message |
Return: tag of the message.
Delete the message.
№ | Name | Description |
1 | msg | the message |
Client authentication on the server.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the user name |
3 | password | the user password |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Ping server. Used to check the server status.
№ | Name | Description |
1 | client | the context of a client connection |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Get server statistics.
№ | Name | Direction | Description |
1 | client | in | the context of a client connection |
2 | status | out | the server statistics |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Saving data to disk.
№ | Name | Description |
1 | client | the context of a client connection |
2 | async | Saving mode (0 - synchronously save, 1 - asynchronously save) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Deleting the data on the server.
№ | Name | Description |
1 | client | the context of a client connection |
2 | flags | flags to delete the data from the server (EMQ_FLUSH_ALL, EMQ_FLUSH_USER, EMQ_FLUSH_QUEUE, EMQ_FLUSH_CHANNEL) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Create a new user.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the user name |
3 | password | the user password |
4 | perm | the user permissions (see Table 1) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Get a list of all users.
№ | Name | Description |
1 | client | the context of a client connection |
Return: list of users.
Rename the user.
№ | Name | Description |
1 | client | the context of a client connection |
2 | from | the old user name |
3 | to | the new user name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Set permissions to the user.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the user name |
3 | perm | the user permissions (see Table 1) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Delete the user.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the user name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
№ | Name | Command | Description |
1 | EMQ_QUEUE_PERM |
.queue_create .queue_declare .queue_exist .queue_list .queue_rename .queue_size .queue_push .queue_get .queue_pop .queue_confirm .queue_subscribe .queue_unsubscribe .queue_purge .queue_delete |
The ability to perform all the commands associated with queues |
2 | EMQ_ROUTE_PERM |
.route_create .route_exist .route_list .route_keys .route_rename .route_bind .route_unbind .route_push .route_delete |
The ability to perform all the commands associated with routes |
3 | EMQ_CHANNEL_PERM |
.channel_create .channel_exist .channel_list .channel_rename .channel_publish .channel_subscribe .channel_psubscribe .channel_unsubscribe .channel_punsubscribe .channel_delete |
The ability to perform all the commands associated with channel |
4 | EMQ_ADMIN_PERM | - | The ability to perform all the commands on the server (including the commands for working with users) |
5 | EMQ_NOT_CHANGE_PERM | - | If a user is created with the flag, then it can not be removed |
6 | EMQ_QUEUE_CREATE_PERM | .queue_create | Permission to create queues |
7 | EMQ_QUEUE_DECLARE_PERM | .queue_declare | Permission to declare the queue |
8 | EMQ_QUEUE_EXIST_PERM | .queue_exist | Permission to check the existence of the queue |
9 | EMQ_QUEUE_LIST_PERM | .queue_list | Permission to get a list of queues |
10 | EMQ_QUEUE_RENAME_PERM | .queue_rename | Permission to rename the queue |
11 | EMQ_QUEUE_SIZE_PERM | .queue_size | Permission to get the size of the queue |
12 | EMQ_QUEUE_PUSH_PERM | .queue_push | Permission to push messages to the queue |
13 | EMQ_QUEUE_GET_PERM | .queue_get | Permission to get messages from the queue |
14 | EMQ_QUEUE_POP_PERM | .queue_pop | Permission to pop messages from the queue |
15 | EMQ_QUEUE_CONFIRM_PERM | .queue_confirm | Permission to confirm delivery for the message |
16 | EMQ_QUEUE_SUBSCRIBE_PERM | .queue_subscribe | Permission to subscribe to the queue |
17 | EMQ_QUEUE_UNSUBSCRIBE_PERM | .queue_unsubscribe | Permission to unsubscribe from the queue |
18 | EMQ_QUEUE_PURGE_PERM | .queue_purge | Permission to delete all messages from the queue |
19 | EMQ_QUEUE_DELETE_PERM | .queue_delete | Permission to delete queue |
20 | EMQ_ROUTE_CREATE_PERM | .route_create | Permission to create route |
21 | EMQ_ROUTE_EXIST_PERM | .route_exist | Permission to check the existence of the route |
22 | EMQ_ROUTE_LIST_PERM | .route_list | Permission to get a list of routes |
23 | EMQ_ROUTE_KEYS_PERM | .route_keys | Permission to get a list of route keys |
24 | EMQ_ROUTE_RENAME_PERM | .route_rename | Permission to rename the route |
25 | EMQ_ROUTE_BIND_PERM | .route_bind | Permission to bind route with the queue |
26 | EMQ_ROUTE_UNBIND_PERM | .route_unbind | Permission to unbind route from the queue |
27 | EMQ_ROUTE_PUSH_PERM | .route_push | Permission to push messages to the route |
28 | EMQ_ROUTE_DELETE_PERM | .route_delete | Permission to delete route |
29 | EMQ_CHANNEL_CREATE_PERM | .channel_create | Permission to create channel |
30 | EMQ_CHANNEL_EXIST_PERM | .channel_exist | Permission to check the existence of the channel |
31 | EMQ_CHANNEL_LIST_PERM | .channel_list | Permission to get a list of channels |
32 | EMQ_CHANNEL_RENAME_PERM | .channel_rename | Permission to rename the channel |
33 | EMQ_CHANNEL_PUBLISH_PERM | .channel_publish | Permission to publish message to the channel |
34 | EMQ_CHANNEL_SUBSCRIBE_PERM | .channel_subscribe | Permission to subscribe to the channel by topic |
35 | EMQ_CHANNEL_PSUBSCRIBE_PERM | .channel_psubscribe | Permission to subscribe to the channel by pattern |
36 | EMQ_CHANNEL_UNSUBSCRIBE_PERM | .channel_unsubscribe | Permission to unsubscribe from channel by topic |
37 | EMQ_CHANNEL_PUNSUBSCRIBE_PERM | .channel_punsubscribe | Permission to unsubscribe from channel by pattern |
38 | EMQ_CHANNEL_DELETE_PERM | .channel_delete | Permission to delete channel |
int emq_queue_create(emq_client *client, const char *name, uint32_t max_msg, uint32_t max_msg_size, uint32_t flags);
Create the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
3 | max_msg | the maximum number of messages |
4 | max_msg_size | the maximum message size |
5 | flags | flags to create a queue (EMQ_QUEUE_NONE, EMQ_QUEUE_AUTODELETE, EMQ_QUEUE_FORCE_PUSH, EMQ_QUEUE_ROUND_ROBIN, EMQ_QUEUE_DURABLE) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Declare the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Check the queue of existence.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: Value greater than 0 if the queue exists.
Get a list of queues.
№ | Name | Description |
1 | client | the context of a client connection |
Return: list of queues.
Rename the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | from | the old queue name |
3 | to | the new queue name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Get the number of elements in the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: number of elements in the queue.
Push a message to the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
3 | msg | the message |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Get a message from the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: message on success, NULL on error.
Pop a message from the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
3 | timeout | the timeout for wait confirm delivery |
Return: message on success, NULL on error.
Confirm delivery message.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
3 | tag | the message tag |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
int emq_queue_subscribe(emq_client *client, const char *name, uint32_t flags, emq_msg_callback *callback);
Subscribe to the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
3 | flags | flags subscription (EMQ_QUEUE_SUBSCRIBE_MSG, EMQ_QUEUE_SUBSCRIBE_NOTIFY) |
4 | callback | callback to the event subscription |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Unsubscribe from the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Purge the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Delete the queue.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the queue name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Create the route.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
3 | flags | flags to create a route (EMQ_ROUTE_NONE, EMQ_ROUTE_AUTODELETE, EMQ_ROUTE_ROUND_ROBIN, EMQ_ROUTE_DURABLE) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Check the route of existence.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
Return: Value greater than 0 if the route exists.
Get a list of route.
№ | Name | Description |
1 | client | the context of a client connection |
Return: list of routes.
Rename the route.
№ | Name | Description |
1 | client | the context of a client connection |
2 | from | the old route name |
3 | to | the new route name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Get a list of route keys.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
Return: list of route keys.
Bind the route with queue by key.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
3 | queue | the queue name |
4 | key | the key |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Unbind the route from queue by a key.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
3 | queue | the queue name |
4 | key | the key |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Push a message to the route.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
3 | key | the key |
4 | msg | the message |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Delete the route.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the route name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Create the channel.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
3 | flags | flags to create a channel (EMQ_CHANNEL_NONE, EMQ_CHANNEL_AUTODELETE, EMQ_CHANNEL_ROUND_ROBIN, EMQ_CHANNEL_DURABLE) |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Check the channel of existence.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
Return: Value greater than 0 if the channel exists.
Get a list of channels.
№ | Name | Description |
1 | client | the context of a client connection |
Return: list of channels.
Rename the channel.
№ | Name | Description |
1 | client | the context of a client connection |
2 | from | the old channel name |
3 | to | the new channel name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Publish a message to the channel.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
3 | topic | the channel topic |
4 | msg | the message |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
int emq_channel_subscribe(emq_client *client, const char *name, const char *topic, emq_msg_callback *callback);
Subscribe to the channel by topic.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
3 | topic | the channel topic |
4 | callback | callback to the event subscription |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
int emq_channel_psubscribe(emq_client *client, const char *name, const char *pattern, emq_msg_callback *callback);
Subscribe to the channel by pattern.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
3 | pattern | the channel pattern |
4 | callback | callback to the event subscription |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Unsubscribe from the channel by topic.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
3 | topic | the channel topic |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Unsubscribe from the channel by pattern.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
3 | pattern | the channel pattern |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
Delete the channel.
№ | Name | Description |
1 | client | the context of a client connection |
2 | name | the channel name |
Return: EMQ_STATUS_OK on success, EMQ_STATUS_ERR on error.
libemq has written by Stanislav Yakush(st.yakush@yandex.ru) and is released under the BSD license.