mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-29 15:05:29 +00:00
f1f6cb04f0
* feat: kotlin android example * Adding lightpush and store to kotlin example
65 lines
3.4 KiB
Go
65 lines
3.4 KiB
Go
package main
|
|
|
|
import (
|
|
"C"
|
|
|
|
mobile "github.com/status-im/go-waku/mobile"
|
|
)
|
|
|
|
//export waku_relay_enough_peers
|
|
// Determine if there are enough peers to publish a message on a topic. Use NULL
|
|
// to verify the number of peers in the default pubsub topic
|
|
func waku_relay_enough_peers(topic *C.char) *C.char {
|
|
response := mobile.RelayEnoughPeers(C.GoString(topic))
|
|
return C.CString(response)
|
|
}
|
|
|
|
//export waku_relay_publish
|
|
// Publish a message using waku relay. Use NULL for topic to use the default pubsub topic
|
|
// 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_relay_publish(messageJSON *C.char, topic *C.char, ms C.int) *C.char {
|
|
response := mobile.RelayPublish(C.GoString(messageJSON), C.GoString(topic), int(ms))
|
|
return C.CString(response)
|
|
}
|
|
|
|
//export waku_relay_publish_enc_asymmetric
|
|
// Publish a message encrypted with a secp256k1 public key using waku relay. Use NULL for topic to use the default pubsub topic.
|
|
// publicKey must be a hex string prefixed with "0x" containing a valid secp256k1 public key.
|
|
// optionalSigningKey is an optional hex string prefixed with "0x" containing a valid secp256k1 private key for signing the message. Use NULL otherwise
|
|
// 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_relay_publish_enc_asymmetric(messageJSON *C.char, topic *C.char, publicKey *C.char, optionalSigningKey *C.char, ms C.int) *C.char {
|
|
response := mobile.RelayPublishEncodeAsymmetric(C.GoString(messageJSON), C.GoString(topic), C.GoString(publicKey), C.GoString(optionalSigningKey), int(ms))
|
|
return C.CString(response)
|
|
}
|
|
|
|
//export waku_relay_publish_enc_symmetric
|
|
// Publish a message encrypted with a 32 bytes symmetric key using waku relay. Use NULL for topic to use the default pubsub topic.
|
|
// publicKey must be a hex string prefixed with "0x" containing a 32 bytes symmetric key
|
|
// optionalSigningKey is an optional hex string prefixed with "0x" containing a valid secp256k1 private key for signing the message. Use NULL otherwise
|
|
// 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_relay_publish_enc_symmetric(messageJSON *C.char, topic *C.char, symmetricKey *C.char, optionalSigningKey *C.char, ms C.int) *C.char {
|
|
response := mobile.RelayPublishEncodeSymmetric(C.GoString(messageJSON), C.GoString(topic), C.GoString(symmetricKey), C.GoString(optionalSigningKey), int(ms))
|
|
return C.CString(response)
|
|
}
|
|
|
|
//export waku_relay_subscribe
|
|
// Subscribe to a WakuRelay topic. Set the topic to NULL to subscribe
|
|
// to the default topic. Returns a json response containing the subscription ID
|
|
// or an error message. When a message is received, a "message" is emitted containing
|
|
// the message, pubsub topic, and nodeID in which the message was received
|
|
func waku_relay_subscribe(topic *C.char) *C.char {
|
|
response := mobile.RelaySubscribe(C.GoString(topic))
|
|
return C.CString(response)
|
|
}
|
|
|
|
//export waku_relay_unsubscribe
|
|
// Closes the pubsub subscription to a pubsub topic. Existing subscriptions
|
|
// will not be closed, but they will stop receiving messages
|
|
func waku_relay_unsubscribe(topic *C.char) *C.char {
|
|
response := mobile.RelayUnsubscribe(C.GoString(topic))
|
|
return C.CString(response)
|
|
}
|