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
|
|
|
|
|
|
|
// Query historic messages using waku store protocol.
|
|
|
|
// queryJSON must contain a valid json string with the following format:
|
2022-10-09 11:08:46 -04:00
|
|
|
//
|
|
|
|
// {
|
|
|
|
// "pubsubTopic": "...", // optional string
|
2023-10-28 19:37:53 -04:00
|
|
|
// "startTime": 1234, // optional, unix epoch time in nanoseconds
|
|
|
|
// "endTime": 1234, // optional, unix epoch time in nanoseconds
|
|
|
|
// "contentTopics": [ // optional
|
|
|
|
// "contentTopic1",
|
|
|
|
// ...
|
|
|
|
// ],
|
|
|
|
// "pagingOptions": {// optional pagination information
|
|
|
|
// "pageSize": 40, // number
|
2022-10-09 11:08:46 -04:00
|
|
|
// "cursor": { // optional
|
|
|
|
// "digest": ...,
|
|
|
|
// "receiverTime": ...,
|
|
|
|
// "senderTime": ...,
|
2023-10-28 19:37:53 -04:00
|
|
|
// "pubsubTopic": ...,
|
|
|
|
// },
|
2022-10-09 11:08:46 -04:00
|
|
|
// "forward": true, // sort order
|
2023-10-28 19:37:53 -04:00
|
|
|
// }
|
2022-10-09 11:08:46 -04:00
|
|
|
// }
|
|
|
|
//
|
|
|
|
// If a non empty cursor is returned, this function should be executed again, setting the `cursor` attribute with the cursor returned in the response
|
2022-05-06 14:13:10 -04:00
|
|
|
// peerID should contain the ID of a peer supporting the store protocol. Use NULL to automatically select a node
|
2022-04-02 20:22:42 -04:00
|
|
|
// 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
|
2022-10-09 11:08:46 -04:00
|
|
|
//
|
|
|
|
//export waku_store_query
|
2023-10-28 19:37:53 -04:00
|
|
|
func waku_store_query(queryJSON *C.char, peerID *C.char, ms C.int, cb C.WakuCallBack, userData unsafe.Pointer) C.int {
|
2023-08-10 09:30:38 -04:00
|
|
|
return singleFnExec(func() (string, error) {
|
|
|
|
return library.StoreQuery(C.GoString(queryJSON), C.GoString(peerID), int(ms))
|
2023-10-28 19:37:53 -04:00
|
|
|
}, cb, userData)
|
2022-04-02 20:22:42 -04:00
|
|
|
}
|
2023-02-10 16:17:23 -04:00
|
|
|
|
|
|
|
// Query historic messages stored in the localDB using waku store protocol.
|
|
|
|
// queryJSON must contain a valid json string with the following format:
|
|
|
|
//
|
|
|
|
// {
|
|
|
|
// "pubsubTopic": "...", // optional string
|
2023-10-28 19:37:53 -04:00
|
|
|
// "startTime": 1234, // optional, unix epoch time in nanoseconds
|
|
|
|
// "endTime": 1234, // optional, unix epoch time in nanoseconds
|
|
|
|
// "contentTopics": [ // optional
|
|
|
|
// "contentTopic1"
|
|
|
|
// ...
|
|
|
|
// ],
|
|
|
|
// "pagingOptions": {// optional pagination information
|
|
|
|
// "pageSize": 40, // number
|
2023-02-10 16:17:23 -04:00
|
|
|
// "cursor": { // optional
|
|
|
|
// "digest": ...,
|
|
|
|
// "receiverTime": ...,
|
|
|
|
// "senderTime": ...,
|
2023-10-28 19:37:53 -04:00
|
|
|
// "pubsubTopic": ...,
|
|
|
|
// },
|
2023-02-10 16:17:23 -04:00
|
|
|
// "forward": true, // sort order
|
2023-10-28 19:37:53 -04:00
|
|
|
// }
|
2023-02-10 16:17:23 -04:00
|
|
|
// }
|
|
|
|
//
|
|
|
|
// If a non empty cursor is returned, this function should be executed again, setting the `cursor` attribute with the cursor returned in the response
|
|
|
|
// Requires the `store` option to be passed when setting up the initial configuration
|
|
|
|
//
|
|
|
|
//export waku_store_local_query
|
2023-10-28 19:37:53 -04:00
|
|
|
func waku_store_local_query(queryJSON *C.char, cb C.WakuCallBack, userData unsafe.Pointer) C.int {
|
2023-08-10 09:30:38 -04:00
|
|
|
return singleFnExec(func() (string, error) {
|
|
|
|
return library.StoreLocalQuery(C.GoString(queryJSON))
|
2023-10-28 19:37:53 -04:00
|
|
|
}, cb, userData)
|
2023-02-10 16:17:23 -04:00
|
|
|
}
|