slug | title | name | status | tags | editor | contributors |
---|---|---|---|---|---|---|
Go-Waku v2 C Bindings | draft | go-waku | Richard Ramos <richard@status.im> |
This specification describes the API for consuming go-waku when built as a dynamic or static library
libgowaku.h
General
JSONResponse
All the API functions return a JSONResponse
unless specified otherwise. JSONResponse
is a char *
whose format depends on whether the function was executed sucessfully or not:
// On failure:
{ "error": "the error message" }
// On success:
{ "result": ... } // result format depends on the function response
Events
Asynchronous events require a callback to be registered. An example of an asynchronous event that might be emitted is receiving a message. When an event is emitted, this callback will be triggered receiving a json string with the following format:
{
"type": "message", // type of signal being emitted. Currently only "message" is available
"event": ... // format depends on the type of signal. In the case of "message", a waku message can be expected here
}
extern void waku_set_event_callback(void* cb)
Register callback to act as signal handler and receive application signals, which are used to react to asyncronous events in waku. Parameters
void* cb
: callback that will be executed when an async event is emitted. The function signature for the callback should bevoid myCallback(char* signalJSON)
Node management
extern char* waku_new(char* configJSON)
Initialize a go-waku node.
Parameters
char* configJSON
: JSON string containing the options used to initialize a go-waku node. It can beNULL
to use defaults. All the keys from the configuration are optional. If a key isundefined
, ornull
, a default value will be set// example config: { "host": "0.0.0.0", "port": 60000, "advertiseAddr": "1.2.3.4", "nodeKey": "0x123...567", "keepAliveInterval": 20, "relay": true, "minPeersToPublish": 0 }
host
-String
(optional): Listening IP address. Default0.0.0.0
port
-Number
(optional): Libp2p TCP listening port. Default60000
. Use0
for randomadvertiseAddr
-String
(optional): External address to advertise to other nodes.nodeKey
-String
(optional): secp256k1 private key in Hex format (0x123...abc
). Default randomkeepAliveInterval
-Number
(optional): Interval in seconds for pinging peers to keep the connection alive. Default20
relay
-Boolean
(optional): Enable relay protocol. Defaulttrue
minPeersToPublish
-Number
(optional). The minimum number of peers required on a topic to allow broadcasting a message. Default0
Returns
JSONResponse
with a NULL result
. An error
message otherwise
extern char* waku_start()
Initialize a go-waku node mounting all the protocols that were enabled during the waku node initialization.
Returns
JSONResponse
containing a null result
if the function executes successfully. An error
message otherwise
extern char* waku_stop()
Stops a go-waku node
Returns
JSONResponse
containing a null result
if the function executes successfully. An error
message otherwise
extern char* waku_peerid()
Obtain the peer ID of the go-waku node.
Returns
JSONResponse
containing the peer ID (base58 encoded) if the function executes successfully. An error
message otherwise
extern char* waku_listen_addresses()
Obtain the multiaddresses the wakunode is listening to
Returns
JSONResponse
containing an array of multiaddresses if the function executes successfully. An error
message otherwise
Connecting to peers
extern char* waku_add_peer(char* address, char* protocolID)
Add node multiaddress and protocol to the wakunode peerstore
Parameters
char* address
: multiaddress of the peer being addedchar* protocolID
: protocol supported by the peer
Returns
JSONResponse
containing the peer ID (base58 encoded) of the peer that was added if the function executes successfully. An error
message otherwise
extern char* waku_connect(char* address, int ms)
Connect to peer at multiaddress.
Parameters
char* address
: multiaddress of the peer being dialedint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
with a null result
if the function executes successfully. An error
message otherwise
extern char* waku_connect_peerid(char* id, int ms)
Connect to peer using peerID.
Parameters
char* peerID
: peerID to dial. The peer must be already known. It must have been added before withwaku_add_peer
or previously dialed withwaku_dial_peer
int ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
with a null result
if the function executes successfully. An error
message otherwise
extern char* waku_disconnect(char* peerID)
Disconnect a peer using its peerID.
Parameters
char* peerID
: peerID to disconnect.
Returns
JSONResponse
with a null result
if the function executes successfully. An error
message otherwise
extern char* waku_peer_cnt()
Obtain number of connected peers
Returns
JSONResponse
containing an int
with the number of connected peers. An error
message otherwise
extern char* waku_peers()
Retrieve the list of peers known by the go-waku node
Returns
JSONResponse
containing a list of peers. An error
message otherwise. The list of peers has this format:
{
"result":[
...
{
"peerID":"16Uiu2HAmJb2e28qLXxT5kZxVUUoJt72EMzNGXB47RedcBafeDCBA",
"protocols":[
"/ipfs/id/1.0.0",
"/vac/waku/relay/2.0.0",
"/ipfs/ping/1.0.0",
...
],
"addrs":[
"/ip4/1.2.3.4/tcp/30303",
...
],
"connected":true
}
]
}
Waku Relay
extern char* waku_content_topic(char* applicationName, unsigned int applicationVersion, char* contentTopicName, char* encoding)
Create a content topic string according to RFC 23
Parameters
char* applicationName
unsigned int applicationVersion
char* contentTopicName
char* encoding
: depending on the payload, useproto
,rlp
orrfc26
Returns
char *
containing a content topic formatted according to RFC 23
/{application-name}/{version-of-the-application}/{content-topic-name}/{encoding}
--
extern char* waku_pubsub_topic(char* name, char* encoding)
Create a pubsub topic string according to RFC 23
Parameters
char* name
char* encoding
: depending on the payload, useproto
,rlp
orrfc26
Returns
char *
containing a content topic formatted according to RFC 23
/waku/2/{topic-name}/{encoding}
extern char* waku_default_pubsub_topic()
Returns the default pubsub topic used for exchanging waku messages defined in RFC 10
Returns
char *
containing the default pubsub topic:
/waku/2/default-waku/proto
extern char* waku_relay_publish(char* messageJSON, char* topic, int ms)
Publish a message using waku relay.
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"", // base64 encoded payload. waku_utils_base64_encode can be used for this "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* topic
: pubsub topic. Set toNULL
to use the default pubsub topicint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the message ID. An error
message otherwise
extern char* waku_relay_publish_enc_asymmetric(char* messageJSON, char* topic, char* publicKey, char* optionalSigningKey, int ms)
Publish a message encrypted with a secp256k1 public key using waku relay
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"", // base64 encoded payload. waku_utils_base64_encode can be used for this "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* topic
: pubsub topic. Set toNULL
to use the default pubsub topicchar* publicKey
: hex string prefixed with "0x" containing a valid secp256k1 public key.char* optionalSigningKey
: optional hex string prefixed with "0x" containing a valid secp256k1 private key for signing the message. Use NULL otherwiseint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the message ID. An error
message otherwise
extern char* waku_relay_publish_enc_symmetric(char* messageJSON, char* topic, char* symmetricKey, char* optionalSigningKey, int ms)
Publish a message encrypted with a 32 bytes symmetric key using waku relay
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"", // base64 encoded payload. waku_utils_base64_encode can be used for this "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* topic
: pubsub topic. Set toNULL
to use the default pubsub topicchar* symmetricKey
: hex string prefixed with "0x" containing a 32 bytes symmetric keychar* optionalSigningKey
: optional hex string prefixed with "0x" containing a valid secp256k1 private key for signing the message. Use NULL otherwiseint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the message ID. An error
message otherwise
extern char* waku_enough_peers(char* topic)
Determine if there are enough peers to publish a message on a topic.
Parameters
char* topic
: pubsub topic to verify. UseNULL
to verify the number of peers in the default pubsub topic
Returns
JSONResponse
with a boolean indicating if there are enough peers or not. An error
message otherwise
extern char* waku_relay_subscribe(char* topic)
Subscribe to a WakuRelay topic to receive messages.
Parameters
char* topic
: pubsub topic to subscribe to. UseNULL
for subscribing to the default pubsub topic
Returns
JSONResponse
with a null result. An error
message otherwise
Events
When a message is received, a ``"message" event
is emitted containing the message, and pubsub topic in which the message was received. Here's an example event that could be received:
{
"type":"message",
"event":{
"pubsubTopic":"/waku/2/default-waku/proto",
"messageID":"0x6496491e40dbe0b6c3a2198c2426b16301688a2daebc4f57ad7706115eac3ad1",
"wakuMessage":{
"payload":"...", // base64 encoded message. Use waku_decode_data to decode
"contentTopic":"ABC",
"version":1,
"timestamp":1647826358000000000 // in nanoseconds
}
}
}
extern char* waku_relay_unsubscribe(char* topic)
Closes the subscription to a pubsub topic.
Parameters
char* topic
: pubsub topic to unsubscribe from. UseNULL
for unsubscribe from the default pubsub topic
Returns
JSONResponse
with null response
if successful. An error
message otherwise
Waku LightPush
extern char* waku_lightpush_publish(char* messageJSON, char* topic, char* peerID, int ms)
Publish a message using waku lightpush.
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"", // base64 encoded payload. waku_utils_base64_encode can be used for this "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* topic
: pubsub topic. Set toNULL
to use the default pubsub topicchar* peerID
: should contain the ID of a peer supporting the lightpush protocol. Use NULL to automatically select a nodeint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the message ID. An error
message otherwise
extern char* waku_lightpush_publish_enc_asymmetric(char* messageJSON, char* topic, char* publicKey, char* optionalSigningKey, char* peerID, int ms)
Publish a message encrypted with a secp256k1 public key using waku lightpush
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"", // base64 encoded payload. waku_utils_base64_encode can be used for this "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* topic
: pubsub topic. Set toNULL
to use the default pubsub topicchar* publicKey
: hex string prefixed with "0x" containing a valid secp256k1 public key.char* optionalSigningKey
: optional hex string prefixed with "0x" containing a valid secp256k1 private key for signing the message. Use NULL otherwisechar* peerID
: should contain the ID of a peer supporting the lightpush protocol. Use NULL to automatically select a nodeint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the message ID. An error
message otherwise
extern char* waku_lightpush_publish_enc_symmetric(char* messageJSON, char* topic, char* symmetricKey, char* optionalSigningKey, char* peerID, int ms)
Publish a message encrypted with a 32 bytes symmetric key using waku relay
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"", // base64 encoded payload. waku_utils_base64_encode can be used for this "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* topic
: pubsub topic. Set toNULL
to use the default pubsub topicchar* symmetricKey
: hex string prefixed with "0x" containing a 32 bytes symmetric keychar* optionalSigningKey
: optional hex string prefixed with "0x" containing a valid secp256k1 private key for signing the message. Use NULL otherwisechar* peerID
: should contain the ID of a peer supporting the lightpush protocol. Use NULL to automatically select a nodeint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the message ID. An error
message otherwise
Waku Store
extern char* waku_store_query(char* queryJSON, char* peerID, int ms)
Query historic messages using waku store protocol.
Parameters
char* queryJSON
: json string containing the query. If the message length is greater than 0, this function should be executed again, setting thecursor
attribute with the cursor returned in the response
{
"pubsubTopic": "...", // optional string
"startTime": 1234, // optional, unix epoch time in nanoseconds
"endTime": 1234, // optional, unix epoch time in nanoseconds
"contentFilters": [ // optional
{
"contentTopic": "..."
}, ...
],
"pagingOptions": { // optional pagination information
"pageSize": 40, // number
"cursor": { // optional
"digest": ...,
"receiverTime": ...,
"senderTime": ...,
"pubsubTopic" ...,
},
"forward": true, // sort order
}
}
char* peerID
: should contain the ID of a peer supporting the store protocol. Use NULL to automatically select a nodeint ms
: max duration in milliseconds this function might take to execute. If the function execution takes longer than this value, the execution will be canceled and an error returned. Use0
for unlimited duration
Returns
JSONResponse
containing the store response. An error
message otherwise
{
"result": {
"messages": [ ... ], // array of waku messages
"pagingOptions": { // optional pagination information
"pageSize": 40, // number
"cursor": { // optional
"digest": ...,
"receiverTime": ...,
"senderTime": ...,
"pubsubTopic" ...,
},
"forward": true, // sort order
}
}
}
Decrypting messages
extern char* waku_decode_symmetric(char* messageJSON, char* symmetricKey)
Decrypt a message using a symmetric key
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"...", // encrypted payload encoded in base64. "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* symmetricKey
: 32 byte symmetric key
Returns
JSONResponse
containing a DecodedPayload
. An error
message otherwise
{
"result": {
"pubkey": "0x......", // pubkey that signed the message (optional)
"signature": "0x....", // message signature (optional)
"data": "...", // decrypted message payload encoded in base64
"padding": "...", // base64 encoded padding
}
}
extern char* waku_decode_asymmetric(char* messageJSON, char* privateKey)
Decrypt a message using a secp256k1 private key
Parameters
char* messageJSON
: json string containing the Waku Message{ "payload":"...", // encrypted payload encoded in base64. "contentTopic: "...", "version": 1, "timestamp": 1647963508000000000 // Unix timestamp in nanoseconds }
char* privateKey
: secp256k1 private key
Returns
JSONResponse
containing a DecodedPayload
. An error
message otherwise
{
"result": {
"pubkey": "0x......", // pubkey that signed the message (optional)
"signature": "0x....", // message signature (optional)
"data": "...", // decrypted message payload encoded in base64
"padding": "...", // base64 encoded padding
}
}
Waku Message Utils
extern char* waku_utils_base64_encode(char* data)
Encode a byte array to base64 useful for creating the payload of a waku message in the format understood by waku_relay_publish
Parameters
char* data
: byte array to encode
Returns
A char *
containing the base64 encoded byte array
extern char* waku_utils_base64_decode(char* data)
Decode a base64 string (useful for reading the payload from waku messages)
Parameters
char* data
: base64 encoded byte array to decode
Returns
JSONResponse
with the decoded payload. An error
message otherwise. The decoded payload has this format:
extern void waku_utils_free(char* data)
Frees a char* since all strings returned by gowaku are allocated in the C heap using malloc.
Parameters
char* data
: variable to free
Copyright
Copyright and related rights waived via CC0.