2022-04-02 20:22:42 -04:00
|
|
|
package main
|
|
|
|
|
2023-08-10 09:30:38 -04:00
|
|
|
/*
|
|
|
|
#include <cgo_utils.h>
|
|
|
|
*/
|
|
|
|
import "C"
|
2023-10-28 19:37:53 -04:00
|
|
|
import (
|
|
|
|
"unsafe"
|
|
|
|
|
|
|
|
"github.com/waku-org/go-waku/library"
|
|
|
|
)
|
2022-04-02 20:22:42 -04:00
|
|
|
|
2023-09-29 10:43:25 +05:30
|
|
|
// Publish a message using waku lightpush. Use NULL for topic to derive the pubsub topic from the contentTopic.
|
2022-04-02 20:22:42 -04:00
|
|
|
// peerID should contain the ID of a peer supporting the lightpush protocol. Use NULL to automatically select a node
|
|
|
|
// If ms is greater than 0, the broadcast of the message must happen before the timeout
|
|
|
|
// (in milliseconds) is reached, or an error will be returned
|
2023-08-10 09:30:38 -04:00
|
|
|
//
|
|
|
|
//export waku_lightpush_publish
|
2023-12-15 10:46:21 -04:00
|
|
|
func waku_lightpush_publish(ctx unsafe.Pointer, messageJSON *C.char, topic *C.char, peerID *C.char, ms C.int, cb C.WakuCallBack, userData unsafe.Pointer) C.int {
|
|
|
|
return singleFnExec(func(instance *library.WakuInstance) (string, error) {
|
|
|
|
return library.LightpushPublish(instance, C.GoString(messageJSON), C.GoString(topic), C.GoString(peerID), int(ms))
|
|
|
|
}, ctx, cb, userData)
|
2022-04-02 20:22:42 -04:00
|
|
|
}
|