go-waku/library/api_store.go

40 lines
1.4 KiB
Go
Raw Normal View History

2022-04-02 20:22:42 -04:00
package main
import (
"C"
mobile "github.com/status-im/go-waku/mobile"
2022-04-02 20:22:42 -04:00
)
//export waku_store_query
// Query historic messages using waku store protocol.
// queryJSON must contain a valid json string with the following format:
// {
// "pubsubTopic": "...", // optional string
// "startTime": 1234, // optional, unix epoch time in nanoseconds
// "endTime": 1234, // optional, unix epoch time in nanoseconds
// "contentFilters": [ // optional
2022-08-09 14:26:57 -04:00
// {
// contentTopic: "contentTopic1"
// }, ...
2022-04-02 20:22:42 -04:00
// ],
// "pagingOptions": {// optional pagination information
// "pageSize": 40, // number
// "cursor": { // optional
// "digest": ...,
// "receiverTime": ...,
// "senderTime": ...,
// "pubsubTopic" ...,
// }
// "forward": true, // sort order
// }
// }
2022-05-06 14:13:10 -04:00
// If the message length is greater than 0, this function should be executed again, setting the `cursor` attribute with the cursor returned in the response
// 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
func waku_store_query(queryJSON *C.char, peerID *C.char, ms C.int) *C.char {
response := mobile.StoreQuery(C.GoString(queryJSON), C.GoString(peerID), int(ms))
return C.CString(response)
2022-04-02 20:22:42 -04:00
}