2023-07-07 08:53:00 +00:00
|
|
|
|
|
|
|
// Generated manually and inspired by the one generated by the Nim Compiler.
|
|
|
|
// In order to see the header file generated by Nim just run `make libwaku`
|
|
|
|
// from the root repo folder and the header should be created in
|
|
|
|
// nimcache/release/libwaku/libwaku.h
|
|
|
|
#ifndef __libwaku__
|
|
|
|
#define __libwaku__
|
|
|
|
|
2024-02-13 14:21:31 +00:00
|
|
|
#include <stddef.h>
|
|
|
|
|
2023-07-07 08:53:00 +00:00
|
|
|
// The possible returned values for the functions that return int
|
|
|
|
#define RET_OK 0
|
|
|
|
#define RET_ERR 1
|
|
|
|
#define RET_MISSING_CALLBACK 2
|
|
|
|
|
2023-09-28 09:10:42 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2024-02-13 14:22:22 +00:00
|
|
|
typedef void (*WakuCallBack) (int callerRet, const char* msg, size_t len, void* userData);
|
2023-10-23 06:37:28 +00:00
|
|
|
|
2023-07-07 08:53:00 +00:00
|
|
|
// Creates a new instance of the waku node.
|
|
|
|
// Sets up the waku node from the given configuration.
|
2023-12-15 12:32:12 +00:00
|
|
|
// Returns a pointer to the Context needed by the rest of the API functions.
|
|
|
|
void* waku_new(
|
2023-10-23 06:37:28 +00:00
|
|
|
const char* configJson,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_start(void* ctx,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_stop(void* ctx,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2024-03-07 17:53:03 +00:00
|
|
|
// Destroys an instance of a waku node created with waku_new
|
|
|
|
int waku_destroy(void* ctx,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_version(void* ctx,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2024-02-13 14:22:22 +00:00
|
|
|
void waku_set_event_callback(void* ctx,
|
|
|
|
WakuCallBack callback,
|
2023-10-23 06:37:28 +00:00
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_content_topic(void* ctx,
|
|
|
|
const char* appName,
|
2023-07-07 08:53:00 +00:00
|
|
|
unsigned int appVersion,
|
|
|
|
const char* contentTopicName,
|
|
|
|
const char* encoding,
|
2023-10-23 06:37:28 +00:00
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_pubsub_topic(void* ctx,
|
|
|
|
const char* topicName,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_default_pubsub_topic(void* ctx,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_relay_publish(void* ctx,
|
|
|
|
const char* pubSubTopic,
|
2023-07-07 08:53:00 +00:00
|
|
|
const char* jsonWakuMessage,
|
|
|
|
unsigned int timeoutMs,
|
2023-10-23 06:37:28 +00:00
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_relay_subscribe(void* ctx,
|
|
|
|
const char* pubSubTopic,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_relay_unsubscribe(void* ctx,
|
|
|
|
const char* pubSubTopic,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2023-10-23 06:37:28 +00:00
|
|
|
int waku_connect(void* ctx,
|
|
|
|
const char* peerMultiAddr,
|
2023-07-07 08:53:00 +00:00
|
|
|
unsigned int timeoutMs,
|
2023-10-23 06:37:28 +00:00
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
2023-07-07 08:53:00 +00:00
|
|
|
|
2024-02-21 11:06:05 +00:00
|
|
|
int waku_listen_addresses(void* ctx,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
|
|
|
|
2024-05-21 16:37:50 +00:00
|
|
|
// Returns a list of multiaddress given a url to a DNS discoverable ENR tree
|
|
|
|
// Parameters
|
|
|
|
// char* entTreeUrl: URL containing a discoverable ENR tree
|
|
|
|
// char* nameDnsServer: The nameserver to resolve the ENR tree url.
|
|
|
|
// int timeoutMs: Timeout value in milliseconds to execute the call.
|
|
|
|
int waku_dns_discovery(void* ctx,
|
|
|
|
const char* entTreeUrl,
|
|
|
|
const char* nameDnsServer,
|
|
|
|
int timeoutMs,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
|
|
|
|
|
|
|
// Updates the bootnode list used for discovering new peers via DiscoveryV5
|
|
|
|
// bootnodes - JSON array containing the bootnode ENRs i.e. `["enr:...", "enr:..."]`
|
|
|
|
int waku_discv5_update_bootnodes(void* ctx,
|
|
|
|
char* bootnodes,
|
|
|
|
WakuCallBack callback,
|
|
|
|
void* userData);
|
|
|
|
|
2023-09-28 09:10:42 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2023-07-07 08:53:00 +00:00
|
|
|
#endif /* __libwaku__ */
|