mirror of
https://github.com/logos-messaging/logos-messaging-go-bindings.git
synced 2026-06-10 18:59:31 +00:00
refactor: extract libwaku cgo bridge into internal/ffi (#114)
* refactor: extract libwaku cgo bridge into internal/ffi Move the C preamble, cgo shims, and callback plumbing from pkg/kernel/nwaku.go into internal/ffi/libwaku.go, where #111 scaffolded them to live. The bridge exposes Go-typed Waku* primitives (handle in, strings out) and owns the handle->event-handler registry, so pkg/kernel is now pure Go: WakuNode keeps its full API, logging, and error texts, and just calls ffi. Behavior is unchanged. Dropped four C shims that had no Go callers (cGoWakuContentTopic, cGoWakuPubsubTopic, cGoWakuDefaultPubsubTopic, cGoWakuLightpushPublish). CGO flags still come from the environment (Makefile/CI untouched). Part of #106. Co-Authored-By: Claude Fable 5 <noreply@anthropic.com> * refactor: move libwaku bridge into internal/ffi/libwaku subpackage One subpackage per C library so a binary links exactly the libraries it imports: libwaku and liblogosdelivery carry overlapping symbols and must never link together (until logos-delivery#3851). With the package named libwaku the Waku* prefixes became stutter, so the exported primitives drop them (libwaku.New/Start/RelayPublish/...). internal/ffi keeps an umbrella doc.go stating the rule. Co-Authored-By: Claude Fable 5 <noreply@anthropic.com> --------- Co-authored-by: Claude Fable 5 <noreply@anthropic.com>
This commit is contained in:
parent
4fd33b6121
commit
1dc549d1d7
@ -1,8 +1,7 @@
|
||||
// Package ffi holds the cgo bridge over the logos-delivery C libraries: the
|
||||
// synchronous request/callback plumbing, the global event callback, and the
|
||||
// handle registry. It exposes Go-typed primitives so the public packages
|
||||
// (e.g. messaging) stay pure Go.
|
||||
// Package ffi groups the cgo bridges over the logos-delivery C libraries.
|
||||
//
|
||||
// Scaffolding only for now; the Messaging API bindings land here (over
|
||||
// liblogosdelivery) in a follow-up.
|
||||
// Each C library gets its own subpackage (libwaku now; liblogosdelivery in a
|
||||
// follow-up) so that a binary links exactly the libraries it imports — the
|
||||
// two .so files carry overlapping symbols and must never be linked together
|
||||
// (until logos-delivery#3851 consolidates them).
|
||||
package ffi
|
||||
|
||||
474
internal/ffi/libwaku/libwaku.go
Normal file
474
internal/ffi/libwaku/libwaku.go
Normal file
@ -0,0 +1,474 @@
|
||||
// Package libwaku is the cgo bridge over libwaku (the legacy Kernel API
|
||||
// library): the synchronous request/callback plumbing, the global event
|
||||
// callback, and the handle registry. It exposes Go-typed primitives so
|
||||
// pkg/kernel stays pure Go.
|
||||
package libwaku
|
||||
|
||||
/*
|
||||
#include <libwaku.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
// wakuGoCallback (sync request/response) and wakuEventCallback (async events)
|
||||
// are implemented in Go and exported below.
|
||||
extern void wakuGoCallback(int ret, char* msg, size_t len, void* resp);
|
||||
extern void wakuEventCallback(int ret, char* msg, size_t len, void* userData);
|
||||
|
||||
// wakuResp carries a single synchronous call's result back from the callback,
|
||||
// plus a pointer to the Go sync.WaitGroup the caller blocks on.
|
||||
typedef struct {
|
||||
int ret;
|
||||
char* msg;
|
||||
size_t len;
|
||||
void* wg;
|
||||
} wakuResp;
|
||||
|
||||
static void* allocWakuResp(void* wg) {
|
||||
wakuResp* r = (wakuResp*) calloc(1, sizeof(wakuResp));
|
||||
r->wg = wg;
|
||||
return r;
|
||||
}
|
||||
static void freeWakuResp(void* resp) { if (resp != NULL) free(resp); }
|
||||
static char* wakuRespMsg(void* resp) { return resp ? ((wakuResp*)resp)->msg : NULL; }
|
||||
static size_t wakuRespLen(void* resp) { return resp ? ((wakuResp*)resp)->len : 0; }
|
||||
static int wakuRespRet(void* resp) { return resp ? ((wakuResp*)resp)->ret : RET_ERR; }
|
||||
|
||||
// Thin wrappers binding the shared Go callback to each libwaku entry point.
|
||||
static void* cGoWakuNew(const char* configJson, void* resp) {
|
||||
return waku_new(configJson, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuStart(void* ctx, void* resp) {
|
||||
waku_start(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuStop(void* ctx, void* resp) {
|
||||
waku_stop(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuDestroy(void* ctx, void* resp) {
|
||||
waku_destroy(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuStartDiscV5(void* ctx, void* resp) {
|
||||
waku_start_discv5(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuStopDiscV5(void* ctx, void* resp) {
|
||||
waku_stop_discv5(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuVersion(void* ctx, void* resp) {
|
||||
waku_version(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuSetEventCallback(void* ctx) {
|
||||
// The ctx doubles as userData so the shared event callback can route the
|
||||
// event to the right registered handler.
|
||||
set_event_callback(ctx, (FFICallBack) wakuEventCallback, ctx);
|
||||
}
|
||||
static void cGoWakuRelayPublish(void* ctx, const char* pubSubTopic, const char* jsonWakuMessage, int timeoutMs, void* resp) {
|
||||
waku_relay_publish(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic, jsonWakuMessage, timeoutMs);
|
||||
}
|
||||
static void cGoWakuRelaySubscribe(void* ctx, const char* pubSubTopic, void* resp) {
|
||||
waku_relay_subscribe(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic);
|
||||
}
|
||||
static void cGoWakuRelayAddProtectedShard(void* ctx, int clusterId, int shardId, char* publicKey, void* resp) {
|
||||
waku_relay_add_protected_shard(ctx, (FFICallBack) wakuGoCallback, resp, clusterId, shardId, publicKey);
|
||||
}
|
||||
static void cGoWakuRelayUnsubscribe(void* ctx, const char* pubSubTopic, void* resp) {
|
||||
waku_relay_unsubscribe(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic);
|
||||
}
|
||||
static void cGoWakuConnect(void* ctx, const char* peerMultiAddr, int timeoutMs, void* resp) {
|
||||
waku_connect(ctx, (FFICallBack) wakuGoCallback, resp, peerMultiAddr, timeoutMs);
|
||||
}
|
||||
static void cGoWakuDialPeer(void* ctx, const char* peerMultiAddr, const char* protocol, int timeoutMs, void* resp) {
|
||||
waku_dial_peer(ctx, (FFICallBack) wakuGoCallback, resp, peerMultiAddr, protocol, timeoutMs);
|
||||
}
|
||||
static void cGoWakuDialPeerById(void* ctx, const char* peerId, const char* protocol, int timeoutMs, void* resp) {
|
||||
waku_dial_peer_by_id(ctx, (FFICallBack) wakuGoCallback, resp, peerId, protocol, timeoutMs);
|
||||
}
|
||||
static void cGoWakuDisconnectPeerById(void* ctx, const char* peerId, void* resp) {
|
||||
waku_disconnect_peer_by_id(ctx, (FFICallBack) wakuGoCallback, resp, peerId);
|
||||
}
|
||||
static void cGoWakuDisconnectAllPeers(void* ctx, void* resp) {
|
||||
waku_disconnect_all_peers(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuListenAddresses(void* ctx, void* resp) {
|
||||
waku_listen_addresses(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuGetMyENR(void* ctx, void* resp) {
|
||||
waku_get_my_enr(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuGetMyPeerId(void* ctx, void* resp) {
|
||||
waku_get_my_peerid(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuPingPeer(void* ctx, const char* peerAddr, int timeoutMs, void* resp) {
|
||||
waku_ping_peer(ctx, (FFICallBack) wakuGoCallback, resp, peerAddr, timeoutMs);
|
||||
}
|
||||
static void cGoWakuGetPeersInMesh(void* ctx, const char* pubSubTopic, void* resp) {
|
||||
waku_relay_get_peers_in_mesh(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic);
|
||||
}
|
||||
static void cGoWakuGetNumPeersInMesh(void* ctx, const char* pubSubTopic, void* resp) {
|
||||
waku_relay_get_num_peers_in_mesh(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic);
|
||||
}
|
||||
static void cGoWakuGetNumConnectedRelayPeers(void* ctx, const char* pubSubTopic, void* resp) {
|
||||
waku_relay_get_num_connected_peers(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic);
|
||||
}
|
||||
static void cGoWakuGetConnectedRelayPeers(void* ctx, const char* pubSubTopic, void* resp) {
|
||||
waku_relay_get_connected_peers(ctx, (FFICallBack) wakuGoCallback, resp, pubSubTopic);
|
||||
}
|
||||
static void cGoWakuGetConnectedPeers(void* ctx, void* resp) {
|
||||
waku_get_connected_peers(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuGetPeerIdsFromPeerStore(void* ctx, void* resp) {
|
||||
waku_get_peerids_from_peerstore(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuGetConnectedPeersInfo(void* ctx, void* resp) {
|
||||
waku_get_connected_peers_info(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuStoreQuery(void* ctx, const char* jsonQuery, const char* peerAddr, int timeoutMs, void* resp) {
|
||||
waku_store_query(ctx, (FFICallBack) wakuGoCallback, resp, jsonQuery, peerAddr, timeoutMs);
|
||||
}
|
||||
static void cGoWakuPeerExchangeQuery(void* ctx, uint64_t numPeers, void* resp) {
|
||||
waku_peer_exchange_request(ctx, (FFICallBack) wakuGoCallback, resp, numPeers);
|
||||
}
|
||||
static void cGoWakuGetPeerIdsByProtocol(void* ctx, const char* protocol, void* resp) {
|
||||
waku_get_peerids_by_protocol(ctx, (FFICallBack) wakuGoCallback, resp, protocol);
|
||||
}
|
||||
static void cGoWakuDnsDiscovery(void* ctx, const char* entTreeUrl, const char* nameDnsServer, int timeoutMs, void* resp) {
|
||||
waku_dns_discovery(ctx, (FFICallBack) wakuGoCallback, resp, entTreeUrl, nameDnsServer, timeoutMs);
|
||||
}
|
||||
static void cGoWakuIsOnline(void* ctx, void* resp) {
|
||||
waku_is_online(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
static void cGoWakuGetMetrics(void* ctx, void* resp) {
|
||||
waku_get_metrics(ctx, (FFICallBack) wakuGoCallback, resp);
|
||||
}
|
||||
*/
|
||||
import "C"
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"sync"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
// Handle is an opaque pointer to a node context owned by the C library.
|
||||
type Handle = unsafe.Pointer
|
||||
|
||||
// RetOK is the return code callbacks report on success.
|
||||
const RetOK = C.RET_OK
|
||||
|
||||
// EventHandler receives every event libwaku emits for a node: the raw
|
||||
// event JSON when ret == RetOK, an error message otherwise.
|
||||
type EventHandler func(ret int, msg string)
|
||||
|
||||
// eventHandlers maps a node handle to the Go function that receives its
|
||||
// events. The shared C event callback looks the handler up by handle.
|
||||
var (
|
||||
eventHandlersMu sync.RWMutex
|
||||
eventHandlers = make(map[Handle]EventHandler)
|
||||
)
|
||||
|
||||
//export wakuGoCallback
|
||||
func wakuGoCallback(ret C.int, msg *C.char, length C.size_t, resp unsafe.Pointer) {
|
||||
if resp == nil {
|
||||
return
|
||||
}
|
||||
r := (*C.wakuResp)(resp)
|
||||
r.ret = ret
|
||||
r.msg = msg
|
||||
r.len = length
|
||||
wg := (*sync.WaitGroup)(r.wg)
|
||||
wg.Done()
|
||||
}
|
||||
|
||||
//export wakuEventCallback
|
||||
func wakuEventCallback(ret C.int, msg *C.char, length C.size_t, userData unsafe.Pointer) {
|
||||
eventHandlersMu.RLock()
|
||||
fn := eventHandlers[userData] // userData carries the node's handle
|
||||
eventHandlersMu.RUnlock()
|
||||
if fn != nil {
|
||||
fn(int(ret), C.GoStringN(msg, C.int(length)))
|
||||
}
|
||||
}
|
||||
|
||||
// call runs a synchronous libwaku entry point that reports its result
|
||||
// through the response callback, blocks until it completes, and returns the
|
||||
// callback message (on RetOK) or an error built from it.
|
||||
func call(invoke func(resp unsafe.Pointer)) (string, error) {
|
||||
var wg sync.WaitGroup
|
||||
wg.Add(1)
|
||||
resp := C.allocWakuResp(unsafe.Pointer(&wg))
|
||||
defer C.freeWakuResp(resp)
|
||||
|
||||
invoke(resp)
|
||||
wg.Wait()
|
||||
|
||||
msg := C.GoStringN(C.wakuRespMsg(resp), C.int(C.wakuRespLen(resp)))
|
||||
if C.wakuRespRet(resp) != C.RET_OK {
|
||||
return "", errors.New(msg)
|
||||
}
|
||||
return msg, nil
|
||||
}
|
||||
|
||||
// New builds a node from a WakuConfig JSON string and returns its handle.
|
||||
// The handle must be released with Destroy.
|
||||
func New(configJSON string) (Handle, error) {
|
||||
cCfg := C.CString(configJSON)
|
||||
defer C.free(unsafe.Pointer(cCfg))
|
||||
|
||||
var wg sync.WaitGroup
|
||||
wg.Add(1)
|
||||
resp := C.allocWakuResp(unsafe.Pointer(&wg))
|
||||
defer C.freeWakuResp(resp)
|
||||
|
||||
ctx := C.cGoWakuNew(cCfg, resp)
|
||||
wg.Wait()
|
||||
|
||||
if C.wakuRespRet(resp) != C.RET_OK || ctx == nil {
|
||||
msg := C.GoStringN(C.wakuRespMsg(resp), C.int(C.wakuRespLen(resp)))
|
||||
if msg == "" {
|
||||
msg = "waku_new returned no context"
|
||||
}
|
||||
return nil, errors.New(msg)
|
||||
}
|
||||
return Handle(ctx), nil
|
||||
}
|
||||
|
||||
// SetEventHandler registers fn to receive events for the node and wires up
|
||||
// the underlying C event callback.
|
||||
func SetEventHandler(h Handle, fn EventHandler) {
|
||||
eventHandlersMu.Lock()
|
||||
eventHandlers[h] = fn
|
||||
eventHandlersMu.Unlock()
|
||||
C.cGoWakuSetEventCallback(h)
|
||||
}
|
||||
|
||||
// Start starts the node.
|
||||
func Start(h Handle) error {
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuStart(h, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// Stop stops the node.
|
||||
func Stop(h Handle) error {
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuStop(h, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// Destroy releases the node context and unregisters its event handler.
|
||||
func Destroy(h Handle) error {
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuDestroy(h, resp) })
|
||||
if err == nil {
|
||||
eventHandlersMu.Lock()
|
||||
delete(eventHandlers, h)
|
||||
eventHandlersMu.Unlock()
|
||||
}
|
||||
return err
|
||||
}
|
||||
|
||||
// StartDiscV5 starts DiscV5 peer discovery.
|
||||
func StartDiscV5(h Handle) error {
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuStartDiscV5(h, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// StopDiscV5 stops DiscV5 peer discovery.
|
||||
func StopDiscV5(h Handle) error {
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuStopDiscV5(h, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// Version returns the libwaku version string.
|
||||
func Version(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuVersion(h, resp) })
|
||||
}
|
||||
|
||||
// RelayPublish publishes a WakuMessage JSON on a pubsub topic and returns
|
||||
// the message hash.
|
||||
func RelayPublish(h Handle, pubsubTopic, messageJSON string, timeoutMs int) (string, error) {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
cMsg := C.CString(messageJSON)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
defer C.free(unsafe.Pointer(cMsg))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuRelayPublish(h, cTopic, cMsg, C.int(timeoutMs), resp) })
|
||||
}
|
||||
|
||||
// RelaySubscribe subscribes the node to a pubsub topic.
|
||||
func RelaySubscribe(h Handle, pubsubTopic string) error {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuRelaySubscribe(h, cTopic, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// RelayAddProtectedShard registers the hex-encoded public key allowed to
|
||||
// sign messages on a protected shard.
|
||||
func RelayAddProtectedShard(h Handle, clusterID, shardID int, publicKeyHex string) error {
|
||||
cPublicKey := C.CString(publicKeyHex)
|
||||
defer C.free(unsafe.Pointer(cPublicKey))
|
||||
_, err := call(func(resp unsafe.Pointer) {
|
||||
C.cGoWakuRelayAddProtectedShard(h, C.int(clusterID), C.int(shardID), cPublicKey, resp)
|
||||
})
|
||||
return err
|
||||
}
|
||||
|
||||
// RelayUnsubscribe unsubscribes the node from a pubsub topic.
|
||||
func RelayUnsubscribe(h Handle, pubsubTopic string) error {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuRelayUnsubscribe(h, cTopic, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// Connect dials a peer multiaddress.
|
||||
func Connect(h Handle, peerMultiAddr string, timeoutMs int) error {
|
||||
cAddr := C.CString(peerMultiAddr)
|
||||
defer C.free(unsafe.Pointer(cAddr))
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuConnect(h, cAddr, C.int(timeoutMs), resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// DialPeer dials a peer multiaddress over a specific protocol.
|
||||
func DialPeer(h Handle, peerMultiAddr, protocol string, timeoutMs int) error {
|
||||
cAddr := C.CString(peerMultiAddr)
|
||||
cProtocol := C.CString(protocol)
|
||||
defer C.free(unsafe.Pointer(cAddr))
|
||||
defer C.free(unsafe.Pointer(cProtocol))
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuDialPeer(h, cAddr, cProtocol, C.int(timeoutMs), resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// DialPeerByID dials a known peer id over a specific protocol.
|
||||
func DialPeerByID(h Handle, peerID, protocol string, timeoutMs int) error {
|
||||
cPeerID := C.CString(peerID)
|
||||
cProtocol := C.CString(protocol)
|
||||
defer C.free(unsafe.Pointer(cPeerID))
|
||||
defer C.free(unsafe.Pointer(cProtocol))
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuDialPeerById(h, cPeerID, cProtocol, C.int(timeoutMs), resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// DisconnectPeerByID drops the connection to a peer.
|
||||
func DisconnectPeerByID(h Handle, peerID string) error {
|
||||
cPeerID := C.CString(peerID)
|
||||
defer C.free(unsafe.Pointer(cPeerID))
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuDisconnectPeerById(h, cPeerID, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// DisconnectAllPeers drops all peer connections.
|
||||
func DisconnectAllPeers(h Handle) error {
|
||||
_, err := call(func(resp unsafe.Pointer) { C.cGoWakuDisconnectAllPeers(h, resp) })
|
||||
return err
|
||||
}
|
||||
|
||||
// ListenAddresses returns the node's listen multiaddresses as a
|
||||
// comma-separated list.
|
||||
func ListenAddresses(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuListenAddresses(h, resp) })
|
||||
}
|
||||
|
||||
// GetMyENR returns the node's ENR record.
|
||||
func GetMyENR(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetMyENR(h, resp) })
|
||||
}
|
||||
|
||||
// GetMyPeerID returns the node's peer id.
|
||||
func GetMyPeerID(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetMyPeerId(h, resp) })
|
||||
}
|
||||
|
||||
// PingPeer pings a peer (comma-separated multiaddresses) and returns the
|
||||
// round-trip time in nanoseconds.
|
||||
func PingPeer(h Handle, peerAddrs string, timeoutMs int) (string, error) {
|
||||
cAddr := C.CString(peerAddrs)
|
||||
defer C.free(unsafe.Pointer(cAddr))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuPingPeer(h, cAddr, C.int(timeoutMs), resp) })
|
||||
}
|
||||
|
||||
// GetPeersInMesh returns the relay mesh peer ids for a pubsub topic as a
|
||||
// comma-separated list.
|
||||
func GetPeersInMesh(h Handle, pubsubTopic string) (string, error) {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetPeersInMesh(h, cTopic, resp) })
|
||||
}
|
||||
|
||||
// GetNumPeersInMesh returns the relay mesh peer count for a pubsub topic.
|
||||
func GetNumPeersInMesh(h Handle, pubsubTopic string) (string, error) {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetNumPeersInMesh(h, cTopic, resp) })
|
||||
}
|
||||
|
||||
// GetNumConnectedRelayPeers returns the connected relay peer count for a
|
||||
// pubsub topic.
|
||||
func GetNumConnectedRelayPeers(h Handle, pubsubTopic string) (string, error) {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetNumConnectedRelayPeers(h, cTopic, resp) })
|
||||
}
|
||||
|
||||
// GetConnectedRelayPeers returns the connected relay peer ids for a pubsub
|
||||
// topic as a comma-separated list.
|
||||
func GetConnectedRelayPeers(h Handle, pubsubTopic string) (string, error) {
|
||||
cTopic := C.CString(pubsubTopic)
|
||||
defer C.free(unsafe.Pointer(cTopic))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetConnectedRelayPeers(h, cTopic, resp) })
|
||||
}
|
||||
|
||||
// GetConnectedPeers returns the connected peer ids as a comma-separated
|
||||
// list.
|
||||
func GetConnectedPeers(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetConnectedPeers(h, resp) })
|
||||
}
|
||||
|
||||
// GetPeerIDsFromPeerStore returns the peer-store peer ids as a
|
||||
// comma-separated list.
|
||||
func GetPeerIDsFromPeerStore(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetPeerIdsFromPeerStore(h, resp) })
|
||||
}
|
||||
|
||||
// GetConnectedPeersInfo returns the connected peers' info as JSON.
|
||||
func GetConnectedPeersInfo(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetConnectedPeersInfo(h, resp) })
|
||||
}
|
||||
|
||||
// StoreQuery runs a store query (JSON) against a peer (comma-separated
|
||||
// multiaddresses) and returns the response JSON.
|
||||
func StoreQuery(h Handle, queryJSON, peerAddrs string, timeoutMs int) (string, error) {
|
||||
cQuery := C.CString(queryJSON)
|
||||
cAddr := C.CString(peerAddrs)
|
||||
defer C.free(unsafe.Pointer(cQuery))
|
||||
defer C.free(unsafe.Pointer(cAddr))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuStoreQuery(h, cQuery, cAddr, C.int(timeoutMs), resp) })
|
||||
}
|
||||
|
||||
// PeerExchangeRequest asks peer exchange for numPeers peers and returns
|
||||
// the number of received peers.
|
||||
func PeerExchangeRequest(h Handle, numPeers uint64) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuPeerExchangeQuery(h, C.uint64_t(numPeers), resp) })
|
||||
}
|
||||
|
||||
// GetPeerIDsByProtocol returns the peer ids supporting a protocol as a
|
||||
// comma-separated list.
|
||||
func GetPeerIDsByProtocol(h Handle, protocol string) (string, error) {
|
||||
cProtocol := C.CString(protocol)
|
||||
defer C.free(unsafe.Pointer(cProtocol))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetPeerIdsByProtocol(h, cProtocol, resp) })
|
||||
}
|
||||
|
||||
// DnsDiscovery resolves an ENR tree URL via DNS discovery and returns the
|
||||
// discovered multiaddresses as a comma-separated list.
|
||||
func DnsDiscovery(h Handle, enrTreeURL, nameDNSServer string, timeoutMs int) (string, error) {
|
||||
cEnrTree := C.CString(enrTreeURL)
|
||||
cDNSServer := C.CString(nameDNSServer)
|
||||
defer C.free(unsafe.Pointer(cEnrTree))
|
||||
defer C.free(unsafe.Pointer(cDNSServer))
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuDnsDiscovery(h, cEnrTree, cDNSServer, C.int(timeoutMs), resp) })
|
||||
}
|
||||
|
||||
// IsOnline reports the node's online state ("true"/"false").
|
||||
func IsOnline(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuIsOnline(h, resp) })
|
||||
}
|
||||
|
||||
// GetMetrics returns the node's metrics in Prometheus text format.
|
||||
func GetMetrics(h Handle) (string, error) {
|
||||
return call(func(resp unsafe.Pointer) { C.cGoWakuGetMetrics(h, resp) })
|
||||
}
|
||||
1392
pkg/kernel/nwaku.go
1392
pkg/kernel/nwaku.go
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user