mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-14 15:54:20 +00:00
refactor: remove enc_publish functions and create separate encoding functions instead
This commit is contained in:
parent
b498308cdd
commit
eb836d71e3
@ -135,7 +135,11 @@ int main(int argc, char *argv[])
|
|||||||
sprintf(wakuMsg, "{\"payload\":\"%s\",\"contentTopic\":\"%s\",\"timestamp\":%"PRIu64"}", msgPayload, contentTopic, nowInNanosecs());
|
sprintf(wakuMsg, "{\"payload\":\"%s\",\"contentTopic\":\"%s\",\"timestamp\":%"PRIu64"}", msgPayload, contentTopic, nowInNanosecs());
|
||||||
free(msgPayload);
|
free(msgPayload);
|
||||||
|
|
||||||
WAKU_CALL(waku_relay_publish_enc_asymmetric(wakuMsg, NULL, bobPubKey, alicePrivKey, 0, handle_ok, handle_error)); // Broadcast via waku relay a message encrypting it with Bob's PubK, and signing it with Alice PrivK
|
|
||||||
|
WAKU_CALL(waku_encode_asymmetric(wakuMsg, bobPubKey, alicePrivKey, handle_ok, handle_error));
|
||||||
|
char *encodedMessage = strdup(result);
|
||||||
|
|
||||||
|
WAKU_CALL(waku_relay_publish(encodedMessage, NULL, 0, handle_ok, handle_error)); // Broadcast via waku relay
|
||||||
printf("C\n");
|
printf("C\n");
|
||||||
|
|
||||||
char *messageID = strdup(result);
|
char *messageID = strdup(result);
|
||||||
|
@ -766,62 +766,6 @@ A status code. Refer to the [`Status codes`](#status-codes) section for possible
|
|||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
||||||
|
|
||||||
### `extern int waku_relay_publish_enc_asymmetric(char* messageJson, char* pubsubTopic, char* publicKey, char* optionalSigningKey, int timeoutMs, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
|
||||||
|
|
||||||
Optionally sign,
|
|
||||||
encrypt using asymmetric encryption
|
|
||||||
and publish a message using Waku Relay.
|
|
||||||
|
|
||||||
**Parameters**
|
|
||||||
|
|
||||||
1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type).
|
|
||||||
2. `char* pubsubTopic`: pubsub topic on which to publish the message.
|
|
||||||
If `NULL`, it uses the default pubsub topic.
|
|
||||||
3. `char* publicKey`: hex encoded public key to be used for encryption.
|
|
||||||
4. `char* optionalSigningKey`: hex encoded private key to be used to sign the message.
|
|
||||||
5. `int timeoutMs`: Timeout value in milliseconds to execute the call.
|
|
||||||
If the function execution takes longer than this value,
|
|
||||||
the execution will be canceled and an error returned.
|
|
||||||
Use `0` for no timeout.
|
|
||||||
6. `WakuCallBack onOkCb`: callback to be executed if the function is succesful
|
|
||||||
7. `WakuCallBack onErrCb`: callback to be executed if the function fails
|
|
||||||
|
|
||||||
Note: `messageJson.version` is overwritten to `1`.
|
|
||||||
|
|
||||||
**Returns**
|
|
||||||
|
|
||||||
A status code. Refer to the [`Status codes`](#status-codes) section for possible values.
|
|
||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
|
||||||
|
|
||||||
### `extern int waku_relay_publish_enc_symmetric(char* messageJson, char* pubsubTopic, char* symmetricKey, char* optionalSigningKey, int timeoutMs, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
|
||||||
|
|
||||||
Optionally sign,
|
|
||||||
encrypt using symmetric encryption
|
|
||||||
and publish a message using Waku Relay.
|
|
||||||
|
|
||||||
**Parameters**
|
|
||||||
|
|
||||||
1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type).
|
|
||||||
2. `char* pubsubTopic`: pubsub topic on which to publish the message.
|
|
||||||
If `NULL`, it uses the default pubsub topic.
|
|
||||||
3. `char* symmetricKey`: hex encoded secret key to be used for encryption.
|
|
||||||
4. `char* optionalSigningKey`: hex encoded private key to be used to sign the message.
|
|
||||||
5. `int timeoutMs`: Timeout value in milliseconds to execute the call.
|
|
||||||
If the function execution takes longer than this value,
|
|
||||||
the execution will be canceled and an error returned.
|
|
||||||
Use `0` for no timeout.
|
|
||||||
6. `WakuCallBack onOkCb`: callback to be executed if the function is succesful
|
|
||||||
7. `WakuCallBack onErrCb`: callback to be executed if the function fails
|
|
||||||
|
|
||||||
Note: `messageJson.version` is overwritten to `1`.
|
|
||||||
|
|
||||||
**Returns**
|
|
||||||
|
|
||||||
A status code. Refer to the [`Status codes`](#status-codes) section for possible values.
|
|
||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
|
||||||
|
|
||||||
### `extern int waku_relay_enough_peers(char* pubsubTopic, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
### `extern int waku_relay_enough_peers(char* pubsubTopic, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
||||||
|
|
||||||
Determine if there are enough peers to publish a message on a given pubsub topic.
|
Determine if there are enough peers to publish a message on a given pubsub topic.
|
||||||
@ -1154,70 +1098,6 @@ A status code. Refer to the [`Status codes`](#status-codes) section for possible
|
|||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
||||||
|
|
||||||
### `extern int waku_lightpush_publish_enc_asymmetric(char* messageJson, char* pubsubTopic, char* peerID, char* publicKey, char* optionalSigningKey, int timeoutMs, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
|
||||||
|
|
||||||
Optionally sign,
|
|
||||||
encrypt using asymmetric encryption
|
|
||||||
and publish a message using Waku Lightpush.
|
|
||||||
|
|
||||||
**Parameters**
|
|
||||||
|
|
||||||
1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type).
|
|
||||||
2. `char* pubsubTopic`: pubsub topic on which to publish the message.
|
|
||||||
If `NULL`, it uses the default pubsub topic.
|
|
||||||
3. `char* peerID`: Peer ID supporting the lightpush protocol.
|
|
||||||
The peer must be already known.
|
|
||||||
It must have been added before with [`waku_add_peer`](#extern-char-waku_add_peerchar-address-char-protocolid)
|
|
||||||
or previously dialed with [`waku_connect_peer`](#extern-char-waku_connect_peerchar-address-int-timeoutms).
|
|
||||||
4. `char* publicKey`: hex encoded public key to be used for encryption.
|
|
||||||
5. `char* optionalSigningKey`: hex encoded private key to be used to sign the message.
|
|
||||||
6. `int timeoutMs`: Timeout value in milliseconds to execute the call.
|
|
||||||
If the function execution takes longer than this value,
|
|
||||||
the execution will be canceled and an error returned.
|
|
||||||
Use `0` for no timeout.
|
|
||||||
7. `WakuCallBack onOkCb`: callback to be executed if the function is succesful
|
|
||||||
8. `WakuCallBack onErrCb`: callback to be executed if the function fails
|
|
||||||
|
|
||||||
Note: `messageJson.version` is overwritten to `1`.
|
|
||||||
|
|
||||||
**Returns**
|
|
||||||
|
|
||||||
A status code. Refer to the [`Status codes`](#status-codes) section for possible values.
|
|
||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
|
||||||
|
|
||||||
### `extern int waku_lightpush_publish_enc_symmetric(char* messageJson, char* pubsubTopic, char* peerID, char* symmetricKey, char* optionalSigningKey, int timeoutMs, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
|
||||||
|
|
||||||
Optionally sign,
|
|
||||||
encrypt using symmetric encryption
|
|
||||||
and publish a message using Waku Lightpush.
|
|
||||||
|
|
||||||
**Parameters**
|
|
||||||
|
|
||||||
1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type).
|
|
||||||
2. `char* pubsubTopic`: pubsub topic on which to publish the message.
|
|
||||||
If `NULL`, it uses the default pubsub topic.
|
|
||||||
3. `char* peerID`: Peer ID supporting the lightpush protocol.
|
|
||||||
The peer must be already known.
|
|
||||||
It must have been added before with [`waku_add_peer`](#extern-char-waku_add_peerchar-address-char-protocolid)
|
|
||||||
or previously dialed with [`waku_connect_peer`](#extern-char-waku_connect_peerchar-address-int-timeoutms).
|
|
||||||
4. `char* symmetricKey`: hex encoded secret key to be used for encryption.
|
|
||||||
5. `char* optionalSigningKey`: hex encoded private key to be used to sign the message.
|
|
||||||
6. `int timeoutMs`: Timeout value in milliseconds to execute the call.
|
|
||||||
If the function execution takes longer than this value,
|
|
||||||
the execution will be canceled and an error returned.
|
|
||||||
Use `0` for no timeout.
|
|
||||||
7. `WakuCallBack onOkCb`: callback to be executed if the function is succesful
|
|
||||||
8. `WakuCallBack onErrCb`: callback to be executed if the function fails
|
|
||||||
|
|
||||||
Note: `messageJson.version` is overwritten to `1`.
|
|
||||||
|
|
||||||
**Returns**
|
|
||||||
|
|
||||||
A status code. Refer to the [`Status codes`](#status-codes) section for possible values.
|
|
||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive the message ID.
|
|
||||||
|
|
||||||
## Waku Store
|
## Waku Store
|
||||||
|
|
||||||
### `extern int waku_store_query(char* queryJSON, char* peerID, int timeoutMs, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
### `extern int waku_store_query(char* queryJSON, char* peerID, int timeoutMs, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
||||||
@ -1270,6 +1150,49 @@ A status code. Refer to the [`Status codes`](#status-codes) section for possible
|
|||||||
|
|
||||||
If the function is executed succesfully, `onOkCb` will receive a [`StoreResponse`](#storeresponse-type).
|
If the function is executed succesfully, `onOkCb` will receive a [`StoreResponse`](#storeresponse-type).
|
||||||
|
|
||||||
|
## Encrypting messages
|
||||||
|
|
||||||
|
### `extern int waku_encode_symmetric(char* messageJson, char* symmetricKey, char* optionalSigningKey, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
||||||
|
|
||||||
|
Encrypt a message using symmetric encryption and optionally sign the message
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
|
||||||
|
1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type).
|
||||||
|
2. `char* symmetricKey`: hex encoded secret key to be used for encryption.
|
||||||
|
3. `char* optionalSigningKey`: hex encoded private key to be used to sign the message.
|
||||||
|
4. `WakuCallBack onOkCb`: callback to be executed if the function is succesful
|
||||||
|
5. `WakuCallBack onErrCb`: callback to be executed if the function fails
|
||||||
|
|
||||||
|
Note: `messageJson.version` is overwritten to `1`.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
|
||||||
|
A status code. Refer to the [`Status codes`](#status-codes) section for possible values.
|
||||||
|
|
||||||
|
If the function is executed succesfully, `onOkCb` will receive the encrypted waku message which can be broadcasted with relay or lightpush protocol publish functions
|
||||||
|
|
||||||
|
### `extern int waku_encode_asymmetric(char* messageJson, char* publicKey, char* optionalSigningKey, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
||||||
|
|
||||||
|
Encrypt a message using asymmetric encryption and optionally sign the message
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
|
||||||
|
1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type).
|
||||||
|
2. `char* publicKey`: hex encoded public key to be used for encryption.
|
||||||
|
3. `char* optionalSigningKey`: hex encoded private key to be used to sign the message.
|
||||||
|
4. `WakuCallBack onOkCb`: callback to be executed if the function is succesful
|
||||||
|
5. `WakuCallBack onErrCb`: callback to be executed if the function fails
|
||||||
|
|
||||||
|
Note: `messageJson.version` is overwritten to `1`.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
|
||||||
|
A status code. Refer to the [`Status codes`](#status-codes) section for possible values.
|
||||||
|
|
||||||
|
If the function is executed succesfully, `onOkCb` will receive the encrypted waku message which can be broadcasted with relay or lightpush protocol publish functions
|
||||||
|
|
||||||
|
|
||||||
## Decrypting messages
|
## Decrypting messages
|
||||||
|
|
||||||
### `extern int waku_decode_symmetric(char* messageJson, char* symmetricKey, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
### `extern int waku_decode_symmetric(char* messageJson, char* symmetricKey, WakuCallBack onOkCb, WakuCallBack onErrCb)`
|
||||||
|
@ -235,21 +235,3 @@ func waku_peers(onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|||||||
return library.Peers()
|
return library.Peers()
|
||||||
}, onOkCb, onErrCb)
|
}, onOkCb, onErrCb)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Decode a waku message using a 32 bytes symmetric key. The key must be a hex encoded string with "0x" prefix
|
|
||||||
//
|
|
||||||
//export waku_decode_symmetric
|
|
||||||
func waku_decode_symmetric(messageJSON *C.char, symmetricKey *C.char, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|
||||||
return singleFnExec(func() (string, error) {
|
|
||||||
return library.DecodeSymmetric(C.GoString(messageJSON), C.GoString(symmetricKey))
|
|
||||||
}, onOkCb, onErrCb)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Decode a waku message using a secp256k1 private key. The key must be a hex encoded string with "0x" prefix
|
|
||||||
//
|
|
||||||
//export waku_decode_asymmetric
|
|
||||||
func waku_decode_asymmetric(messageJSON *C.char, privateKey *C.char, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|
||||||
return singleFnExec(func() (string, error) {
|
|
||||||
return library.DecodeAsymmetric(C.GoString(messageJSON), C.GoString(privateKey))
|
|
||||||
}, onOkCb, onErrCb)
|
|
||||||
}
|
|
||||||
|
49
library/c/api_encoding.go
Normal file
49
library/c/api_encoding.go
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
/*
|
||||||
|
#include <cgo_utils.h>
|
||||||
|
*/
|
||||||
|
import "C"
|
||||||
|
import "github.com/waku-org/go-waku/library"
|
||||||
|
|
||||||
|
// Decode a waku message using a 32 bytes symmetric key. The key must be a hex encoded string with "0x" prefix
|
||||||
|
//
|
||||||
|
//export waku_decode_symmetric
|
||||||
|
func waku_decode_symmetric(messageJSON *C.char, symmetricKey *C.char, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
||||||
|
return singleFnExec(func() (string, error) {
|
||||||
|
return library.DecodeSymmetric(C.GoString(messageJSON), C.GoString(symmetricKey))
|
||||||
|
}, onOkCb, onErrCb)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Decode a waku message using a secp256k1 private key. The key must be a hex encoded string with "0x" prefix
|
||||||
|
//
|
||||||
|
//export waku_decode_asymmetric
|
||||||
|
func waku_decode_asymmetric(messageJSON *C.char, privateKey *C.char, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
||||||
|
return singleFnExec(func() (string, error) {
|
||||||
|
return library.DecodeAsymmetric(C.GoString(messageJSON), C.GoString(privateKey))
|
||||||
|
}, onOkCb, onErrCb)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Encrypt a message with a secp256k1 public key.
|
||||||
|
// 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
|
||||||
|
// The message version will be set to 1
|
||||||
|
//
|
||||||
|
//export waku_encode_asymmetric
|
||||||
|
func waku_encode_asymmetric(messageJSON *C.char, publicKey *C.char, optionalSigningKey *C.char, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
||||||
|
return singleFnExec(func() (string, error) {
|
||||||
|
return library.EncodeAsymmetric(C.GoString(messageJSON), C.GoString(publicKey), C.GoString(optionalSigningKey))
|
||||||
|
}, onOkCb, onErrCb)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Encrypt a message with a 32 bytes symmetric key
|
||||||
|
// symmetricKey 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
|
||||||
|
// The message version will be set to 1
|
||||||
|
//
|
||||||
|
//export waku_encode_symmetric
|
||||||
|
func waku_encode_symmetric(messageJSON *C.char, symmetricKey *C.char, optionalSigningKey *C.char, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
||||||
|
return singleFnExec(func() (string, error) {
|
||||||
|
return library.EncodeSymmetric(C.GoString(messageJSON), C.GoString(symmetricKey), C.GoString(optionalSigningKey))
|
||||||
|
}, onOkCb, onErrCb)
|
||||||
|
}
|
@ -17,31 +17,3 @@ func waku_lightpush_publish(messageJSON *C.char, topic *C.char, peerID *C.char,
|
|||||||
return library.LightpushPublish(C.GoString(messageJSON), C.GoString(topic), C.GoString(peerID), int(ms))
|
return library.LightpushPublish(C.GoString(messageJSON), C.GoString(topic), C.GoString(peerID), int(ms))
|
||||||
}, onOkCb, onErrCb)
|
}, onOkCb, onErrCb)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Publish a message encrypted with a secp256k1 public key using waku lightpush. Use NULL for topic to use the default pubsub topic.
|
|
||||||
// peerID should contain the ID of a peer supporting the lightpush protocol. Use NULL to automatically select a node
|
|
||||||
// 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.
|
|
||||||
//
|
|
||||||
//export waku_lightpush_publish_enc_asymmetric
|
|
||||||
func waku_lightpush_publish_enc_asymmetric(messageJSON *C.char, topic *C.char, peerID *C.char, publicKey *C.char, optionalSigningKey *C.char, ms C.int, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|
||||||
return singleFnExec(func() (string, error) {
|
|
||||||
return library.LightpushPublishEncodeAsymmetric(C.GoString(messageJSON), C.GoString(topic), C.GoString(peerID), C.GoString(publicKey), C.GoString(optionalSigningKey), int(ms))
|
|
||||||
}, onOkCb, onErrCb)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Publish a message encrypted with a 32 bytes symmetric key using waku relay. Use NULL for topic to use the default pubsub topic.
|
|
||||||
// peerID should contain the ID of a peer supporting the lightpush protocol. Use NULL to automatically select a node
|
|
||||||
// symmetricKey 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.
|
|
||||||
//
|
|
||||||
//export waku_lightpush_publish_enc_symmetric
|
|
||||||
func waku_lightpush_publish_enc_symmetric(messageJSON *C.char, topic *C.char, peerID *C.char, symmetricKey *C.char, optionalSigningKey *C.char, ms C.int, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|
||||||
return singleFnExec(func() (string, error) {
|
|
||||||
return library.LightpushPublishEncodeSymmetric(C.GoString(messageJSON), C.GoString(topic), C.GoString(peerID), C.GoString(symmetricKey), C.GoString(optionalSigningKey), int(ms))
|
|
||||||
}, onOkCb, onErrCb)
|
|
||||||
}
|
|
||||||
|
@ -31,32 +31,6 @@ func waku_relay_publish(messageJSON *C.char, topic *C.char, ms C.int, onOkCb C.W
|
|||||||
}, onOkCb, onErrCb)
|
}, onOkCb, onErrCb)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Publish a message encrypted with a secp256k1 public key using waku relay and returns the message ID. 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.
|
|
||||||
//
|
|
||||||
//export waku_relay_publish_enc_asymmetric
|
|
||||||
func waku_relay_publish_enc_asymmetric(messageJSON *C.char, topic *C.char, publicKey *C.char, optionalSigningKey *C.char, ms C.int, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|
||||||
return singleFnExec(func() (string, error) {
|
|
||||||
return library.RelayPublishEncodeAsymmetric(C.GoString(messageJSON), C.GoString(topic), C.GoString(publicKey), C.GoString(optionalSigningKey), int(ms))
|
|
||||||
}, onOkCb, onErrCb)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Publish a message encrypted with a 32 bytes symmetric key using waku relay and returns the message ID. Use NULL for topic to use the default pubsub topic.
|
|
||||||
// symmetricKey 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.
|
|
||||||
//
|
|
||||||
//export waku_relay_publish_enc_symmetric
|
|
||||||
func waku_relay_publish_enc_symmetric(messageJSON *C.char, topic *C.char, symmetricKey *C.char, optionalSigningKey *C.char, ms C.int, onOkCb C.WakuCallBack, onErrCb C.WakuCallBack) C.int {
|
|
||||||
return singleFnExec(func() (string, error) {
|
|
||||||
return library.RelayPublishEncodeSymmetric(C.GoString(messageJSON), C.GoString(topic), C.GoString(symmetricKey), C.GoString(optionalSigningKey), int(ms))
|
|
||||||
}, onOkCb, onErrCb)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Subscribe to a WakuRelay topic. Set the topic to NULL to subscribe
|
// Subscribe to a WakuRelay topic. Set the topic to NULL to subscribe
|
||||||
// to the default topic. Returns a json response. When a message is received,
|
// to the default topic. Returns a json response. When a message is received,
|
||||||
// a "message" event is emitted containing the message and pubsub topic in which
|
// a "message" event is emitted containing the message and pubsub topic in which
|
||||||
|
@ -1,9 +1,14 @@
|
|||||||
package library
|
package library
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/ecdsa"
|
||||||
|
"crypto/elliptic"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"errors"
|
||||||
|
|
||||||
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
||||||
"github.com/ethereum/go-ethereum/crypto"
|
"github.com/ethereum/go-ethereum/crypto"
|
||||||
|
"github.com/ethereum/go-ethereum/crypto/secp256k1"
|
||||||
"github.com/waku-org/go-waku/waku/v2/payload"
|
"github.com/waku-org/go-waku/waku/v2/payload"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/pb"
|
"github.com/waku-org/go-waku/waku/v2/protocol/pb"
|
||||||
"github.com/waku-org/go-waku/waku/v2/utils"
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
||||||
@ -12,14 +17,13 @@ import (
|
|||||||
func wakuMessage(messageJSON string) (*pb.WakuMessage, error) {
|
func wakuMessage(messageJSON string) (*pb.WakuMessage, error) {
|
||||||
var msg *pb.WakuMessage
|
var msg *pb.WakuMessage
|
||||||
err := json.Unmarshal([]byte(messageJSON), &msg)
|
err := json.Unmarshal([]byte(messageJSON), &msg)
|
||||||
msg.Version = 0
|
|
||||||
return msg, err
|
return msg, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func wakuMessageSymmetricEncoding(messageJSON string, symmetricKey string, optionalSigningKey string) (*pb.WakuMessage, error) {
|
func EncodeSymmetric(messageJSON string, symmetricKey string, optionalSigningKey string) (string, error) {
|
||||||
msg, err := wakuMessage(messageJSON)
|
msg, err := wakuMessage(messageJSON)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
payload := payload.Payload{
|
payload := payload.Payload{
|
||||||
@ -31,7 +35,7 @@ func wakuMessageSymmetricEncoding(messageJSON string, symmetricKey string, optio
|
|||||||
|
|
||||||
keyBytes, err := utils.DecodeHexString(symmetricKey)
|
keyBytes, err := utils.DecodeHexString(symmetricKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
payload.Key.SymKey = keyBytes
|
payload.Key.SymKey = keyBytes
|
||||||
@ -39,25 +43,33 @@ func wakuMessageSymmetricEncoding(messageJSON string, symmetricKey string, optio
|
|||||||
if optionalSigningKey != "" {
|
if optionalSigningKey != "" {
|
||||||
signingKeyBytes, err := utils.DecodeHexString(optionalSigningKey)
|
signingKeyBytes, err := utils.DecodeHexString(optionalSigningKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
payload.Key.PrivKey, err = crypto.ToECDSA(signingKeyBytes)
|
payload.Key.PrivKey, err = crypto.ToECDSA(signingKeyBytes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
msg.Version = 1
|
msg.Version = 1
|
||||||
msg.Payload, err = payload.Encode(1)
|
msg.Payload, err = payload.Encode(1)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
return msg, err
|
encodedMsg, err := json.Marshal(msg)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
return string(encodedMsg), err
|
||||||
}
|
}
|
||||||
|
|
||||||
func wakuMessageAsymmetricEncoding(messageJSON string, publicKey string, optionalSigningKey string) (*pb.WakuMessage, error) {
|
func EncodeAsymmetric(messageJSON string, publicKey string, optionalSigningKey string) (string, error) {
|
||||||
msg, err := wakuMessage(messageJSON)
|
msg, err := wakuMessage(messageJSON)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
payload := payload.Payload{
|
payload := payload.Payload{
|
||||||
@ -69,28 +81,152 @@ func wakuMessageAsymmetricEncoding(messageJSON string, publicKey string, optiona
|
|||||||
|
|
||||||
keyBytes, err := utils.DecodeHexString(publicKey)
|
keyBytes, err := utils.DecodeHexString(publicKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
payload.Key.PubKey, err = unmarshalPubkey(keyBytes)
|
payload.Key.PubKey, err = unmarshalPubkey(keyBytes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
if optionalSigningKey != "" {
|
if optionalSigningKey != "" {
|
||||||
signingKeyBytes, err := utils.DecodeHexString(optionalSigningKey)
|
signingKeyBytes, err := utils.DecodeHexString(optionalSigningKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
payload.Key.PrivKey, err = crypto.ToECDSA(signingKeyBytes)
|
payload.Key.PrivKey, err = crypto.ToECDSA(signingKeyBytes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return msg, err
|
return "", err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
msg.Version = 1
|
msg.Version = 1
|
||||||
msg.Payload, err = payload.Encode(1)
|
msg.Payload, err = payload.Encode(1)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
return msg, err
|
encodedMsg, err := json.Marshal(msg)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
return string(encodedMsg), err
|
||||||
|
}
|
||||||
|
|
||||||
|
func extractPubKeyAndSignature(payload *payload.DecodedPayload) (pubkey string, signature string) {
|
||||||
|
pkBytes := crypto.FromECDSAPub(payload.PubKey)
|
||||||
|
if len(pkBytes) != 0 {
|
||||||
|
pubkey = hexutil.Encode(pkBytes)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(payload.Signature) != 0 {
|
||||||
|
signature = hexutil.Encode(payload.Signature)
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// DecodeSymmetric decodes a waku message using a 32 bytes symmetric key. The key must be a hex encoded string with "0x" prefix
|
||||||
|
func DecodeSymmetric(messageJSON string, symmetricKey string) (string, error) {
|
||||||
|
var msg pb.WakuMessage
|
||||||
|
err := json.Unmarshal([]byte(messageJSON), &msg)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
if msg.Version == 0 {
|
||||||
|
return marshalJSON(msg.Payload)
|
||||||
|
} else if msg.Version > 1 {
|
||||||
|
return "", errors.New("unsupported wakumessage version")
|
||||||
|
}
|
||||||
|
|
||||||
|
keyInfo := &payload.KeyInfo{
|
||||||
|
Kind: payload.Symmetric,
|
||||||
|
}
|
||||||
|
|
||||||
|
keyInfo.SymKey, err = utils.DecodeHexString(symmetricKey)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
payload, err := payload.DecodePayload(&msg, keyInfo)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
pubkey, signature := extractPubKeyAndSignature(payload)
|
||||||
|
|
||||||
|
response := struct {
|
||||||
|
PubKey string `json:"pubkey,omitempty"`
|
||||||
|
Signature string `json:"signature,omitempty"`
|
||||||
|
Data []byte `json:"data"`
|
||||||
|
Padding []byte `json:"padding"`
|
||||||
|
}{
|
||||||
|
PubKey: pubkey,
|
||||||
|
Signature: signature,
|
||||||
|
Data: payload.Data,
|
||||||
|
Padding: payload.Padding,
|
||||||
|
}
|
||||||
|
|
||||||
|
return marshalJSON(response)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DecodeAsymmetric decodes a waku message using a secp256k1 private key. The key must be a hex encoded string with "0x" prefix
|
||||||
|
func DecodeAsymmetric(messageJSON string, privateKey string) (string, error) {
|
||||||
|
var msg pb.WakuMessage
|
||||||
|
err := json.Unmarshal([]byte(messageJSON), &msg)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
if msg.Version == 0 {
|
||||||
|
return marshalJSON(msg.Payload)
|
||||||
|
} else if msg.Version > 1 {
|
||||||
|
return "", errors.New("unsupported wakumessage version")
|
||||||
|
}
|
||||||
|
|
||||||
|
keyInfo := &payload.KeyInfo{
|
||||||
|
Kind: payload.Asymmetric,
|
||||||
|
}
|
||||||
|
|
||||||
|
keyBytes, err := utils.DecodeHexString(privateKey)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
keyInfo.PrivKey, err = crypto.ToECDSA(keyBytes)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
payload, err := payload.DecodePayload(&msg, keyInfo)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
pubkey, signature := extractPubKeyAndSignature(payload)
|
||||||
|
|
||||||
|
response := struct {
|
||||||
|
PubKey string `json:"pubkey,omitempty"`
|
||||||
|
Signature string `json:"signature,omitempty"`
|
||||||
|
Data []byte `json:"data"`
|
||||||
|
Padding []byte `json:"padding"`
|
||||||
|
}{
|
||||||
|
PubKey: pubkey,
|
||||||
|
Signature: signature,
|
||||||
|
Data: payload.Data,
|
||||||
|
Padding: payload.Padding,
|
||||||
|
}
|
||||||
|
|
||||||
|
return marshalJSON(response)
|
||||||
|
}
|
||||||
|
|
||||||
|
func unmarshalPubkey(pub []byte) (ecdsa.PublicKey, error) {
|
||||||
|
x, y := elliptic.Unmarshal(secp256k1.S256(), pub)
|
||||||
|
if x == nil {
|
||||||
|
return ecdsa.PublicKey{}, errors.New("invalid public key")
|
||||||
|
}
|
||||||
|
return ecdsa.PublicKey{Curve: secp256k1.S256(), X: x, Y: y}, nil
|
||||||
}
|
}
|
||||||
|
@ -50,23 +50,3 @@ func LightpushPublish(messageJSON string, topic string, peerID string, ms int) (
|
|||||||
|
|
||||||
return lightpushPublish(msg, getTopic(topic), peerID, ms)
|
return lightpushPublish(msg, getTopic(topic), peerID, ms)
|
||||||
}
|
}
|
||||||
|
|
||||||
// LightpushPublishEncodeAsymmetric is used to publish a WakuMessage in a pubsub topic using Lightpush protocol, and encrypting the message with some public key
|
|
||||||
func LightpushPublishEncodeAsymmetric(messageJSON string, topic string, peerID string, publicKey string, optionalSigningKey string, ms int) (string, error) {
|
|
||||||
msg, err := wakuMessageAsymmetricEncoding(messageJSON, publicKey, optionalSigningKey)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return lightpushPublish(msg, getTopic(topic), peerID, ms)
|
|
||||||
}
|
|
||||||
|
|
||||||
// LightpushPublishEncodeSymmetric is used to publish a WakuMessage in a pubsub topic using Lightpush protocol, and encrypting the message with a symmetric key
|
|
||||||
func LightpushPublishEncodeSymmetric(messageJSON string, topic string, peerID string, symmetricKey string, optionalSigningKey string, ms int) (string, error) {
|
|
||||||
msg, err := wakuMessageSymmetricEncoding(messageJSON, symmetricKey, optionalSigningKey)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return lightpushPublish(msg, getTopic(topic), peerID, ms)
|
|
||||||
}
|
|
||||||
|
@ -92,15 +92,3 @@ func Peers() string {
|
|||||||
peers, err := library.Peers()
|
peers, err := library.Peers()
|
||||||
return prepareJSONResponse(peers, err)
|
return prepareJSONResponse(peers, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// DecodeSymmetric decodes a waku message using a 32 bytes symmetric key. The key must be a hex encoded string with "0x" prefix
|
|
||||||
func DecodeSymmetric(messageJSON string, symmetricKey string) string {
|
|
||||||
response, err := library.DecodeSymmetric(messageJSON, symmetricKey)
|
|
||||||
return prepareJSONResponse(response, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DecodeAsymmetric decodes a waku message using a secp256k1 private key. The key must be a hex encoded string with "0x" prefix
|
|
||||||
func DecodeAsymmetric(messageJSON string, privateKey string) string {
|
|
||||||
response, err := library.DecodeAsymmetric(messageJSON, privateKey)
|
|
||||||
return prepareJSONResponse(response, err)
|
|
||||||
}
|
|
||||||
|
29
library/mobile/api_encoding.go
Normal file
29
library/mobile/api_encoding.go
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
package gowaku
|
||||||
|
|
||||||
|
import "github.com/waku-org/go-waku/library"
|
||||||
|
|
||||||
|
// DecodeSymmetric decodes a waku message using a 32 bytes symmetric key. The key must be a hex encoded string with "0x" prefix
|
||||||
|
func DecodeSymmetric(messageJSON string, symmetricKey string) string {
|
||||||
|
response, err := library.DecodeSymmetric(messageJSON, symmetricKey)
|
||||||
|
return prepareJSONResponse(response, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DecodeAsymmetric decodes a waku message using a secp256k1 private key. The key must be a hex encoded string with "0x" prefix
|
||||||
|
func DecodeAsymmetric(messageJSON string, privateKey string) string {
|
||||||
|
response, err := library.DecodeAsymmetric(messageJSON, privateKey)
|
||||||
|
return prepareJSONResponse(response, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// EncodeSymmetric encodes a waku message using a 32 bytes symmetric key. A secp256k1 private key can be used to optionally sign the message.
|
||||||
|
// The keys must be a hex encoded string with "0x" prefix
|
||||||
|
func EncodeSymmetric(messageJSON string, symmetricKey string, optionalSigningKey string) string {
|
||||||
|
response, err := library.EncodeSymmetric(messageJSON, symmetricKey, optionalSigningKey)
|
||||||
|
return prepareJSONResponse(response, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// EncodeAsymmetric encodes a waku message using a secp256k1 public key. A secp256k1 private key can be used to optionally sign the message.
|
||||||
|
// The keys must be a hex encoded string with "0x" prefix
|
||||||
|
func EncodeAsymmetric(messageJSON string, publicKey string, optionalSigningKey string) string {
|
||||||
|
response, err := library.EncodeAsymmetric(messageJSON, publicKey, optionalSigningKey)
|
||||||
|
return prepareJSONResponse(response, err)
|
||||||
|
}
|
@ -7,15 +7,3 @@ func LightpushPublish(messageJSON string, topic string, peerID string, ms int) s
|
|||||||
response, err := library.LightpushPublish(messageJSON, topic, peerID, ms)
|
response, err := library.LightpushPublish(messageJSON, topic, peerID, ms)
|
||||||
return prepareJSONResponse(response, err)
|
return prepareJSONResponse(response, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// LightpushPublishEncodeAsymmetric is used to publish a WakuMessage in a pubsub topic using Lightpush protocol, and encrypting the message with some public key
|
|
||||||
func LightpushPublishEncodeAsymmetric(messageJSON string, topic string, peerID string, publicKey string, optionalSigningKey string, ms int) string {
|
|
||||||
response, err := library.LightpushPublishEncodeAsymmetric(messageJSON, topic, peerID, publicKey, optionalSigningKey, ms)
|
|
||||||
return prepareJSONResponse(response, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// LightpushPublishEncodeSymmetric is used to publish a WakuMessage in a pubsub topic using Lightpush protocol, and encrypting the message with a symmetric key
|
|
||||||
func LightpushPublishEncodeSymmetric(messageJSON string, topic string, peerID string, symmetricKey string, optionalSigningKey string, ms int) string {
|
|
||||||
response, err := library.LightpushPublishEncodeSymmetric(messageJSON, topic, peerID, symmetricKey, optionalSigningKey, ms)
|
|
||||||
return prepareJSONResponse(response, err)
|
|
||||||
}
|
|
||||||
|
@ -16,18 +16,6 @@ func RelayPublish(messageJSON string, topic string, ms int) string {
|
|||||||
return prepareJSONResponse(hash, err)
|
return prepareJSONResponse(hash, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// RelayPublishEncodeAsymmetric publish a message encrypted with a secp256k1 public key using waku relay and returns the message ID
|
|
||||||
func RelayPublishEncodeAsymmetric(messageJSON string, topic string, publicKey string, optionalSigningKey string, ms int) string {
|
|
||||||
hash, err := library.RelayPublishEncodeAsymmetric(messageJSON, topic, publicKey, optionalSigningKey, ms)
|
|
||||||
return prepareJSONResponse(hash, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// RelayPublishEncodeSymmetric publishes a message encrypted with a 32 bytes symmetric key using waku relay and returns the message ID
|
|
||||||
func RelayPublishEncodeSymmetric(messageJSON string, topic string, symmetricKey string, optionalSigningKey string, ms int) string {
|
|
||||||
hash, err := library.RelayPublishEncodeSymmetric(messageJSON, topic, symmetricKey, optionalSigningKey, ms)
|
|
||||||
return prepareJSONResponse(hash, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// RelaySubscribe subscribes to a WakuRelay topic.
|
// RelaySubscribe subscribes to a WakuRelay topic.
|
||||||
func RelaySubscribe(topic string) string {
|
func RelaySubscribe(topic string) string {
|
||||||
err := library.RelaySubscribe(topic)
|
err := library.RelaySubscribe(topic)
|
||||||
|
120
library/node.go
120
library/node.go
@ -3,11 +3,9 @@ package library
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"crypto/ecdsa"
|
"crypto/ecdsa"
|
||||||
"crypto/elliptic"
|
|
||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"encoding/json"
|
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
@ -17,7 +15,6 @@ import (
|
|||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common/hexutil"
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
||||||
"github.com/ethereum/go-ethereum/crypto"
|
"github.com/ethereum/go-ethereum/crypto"
|
||||||
"github.com/ethereum/go-ethereum/crypto/secp256k1"
|
|
||||||
"github.com/ethereum/go-ethereum/p2p/enode"
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
||||||
pubsub "github.com/libp2p/go-libp2p-pubsub"
|
pubsub "github.com/libp2p/go-libp2p-pubsub"
|
||||||
"github.com/libp2p/go-libp2p/core/peer"
|
"github.com/libp2p/go-libp2p/core/peer"
|
||||||
@ -26,7 +23,6 @@ import (
|
|||||||
"github.com/waku-org/go-waku/waku/persistence"
|
"github.com/waku-org/go-waku/waku/persistence"
|
||||||
dbutils "github.com/waku-org/go-waku/waku/persistence/utils"
|
dbutils "github.com/waku-org/go-waku/waku/persistence/utils"
|
||||||
"github.com/waku-org/go-waku/waku/v2/node"
|
"github.com/waku-org/go-waku/waku/v2/node"
|
||||||
"github.com/waku-org/go-waku/waku/v2/payload"
|
|
||||||
"github.com/waku-org/go-waku/waku/v2/peerstore"
|
"github.com/waku-org/go-waku/waku/v2/peerstore"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol"
|
"github.com/waku-org/go-waku/waku/v2/protocol"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/pb"
|
"github.com/waku-org/go-waku/waku/v2/protocol/pb"
|
||||||
@ -385,119 +381,3 @@ func Peers() (string, error) {
|
|||||||
|
|
||||||
return marshalJSON(peers)
|
return marshalJSON(peers)
|
||||||
}
|
}
|
||||||
|
|
||||||
func unmarshalPubkey(pub []byte) (ecdsa.PublicKey, error) {
|
|
||||||
x, y := elliptic.Unmarshal(secp256k1.S256(), pub)
|
|
||||||
if x == nil {
|
|
||||||
return ecdsa.PublicKey{}, errors.New("invalid public key")
|
|
||||||
}
|
|
||||||
return ecdsa.PublicKey{Curve: secp256k1.S256(), X: x, Y: y}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func extractPubKeyAndSignature(payload *payload.DecodedPayload) (pubkey string, signature string) {
|
|
||||||
pkBytes := crypto.FromECDSAPub(payload.PubKey)
|
|
||||||
if len(pkBytes) != 0 {
|
|
||||||
pubkey = hexutil.Encode(pkBytes)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(payload.Signature) != 0 {
|
|
||||||
signature = hexutil.Encode(payload.Signature)
|
|
||||||
}
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// DecodeSymmetric decodes a waku message using a 32 bytes symmetric key. The key must be a hex encoded string with "0x" prefix
|
|
||||||
func DecodeSymmetric(messageJSON string, symmetricKey string) (string, error) {
|
|
||||||
var msg pb.WakuMessage
|
|
||||||
err := json.Unmarshal([]byte(messageJSON), &msg)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
if msg.Version == 0 {
|
|
||||||
return marshalJSON(msg.Payload)
|
|
||||||
} else if msg.Version > 1 {
|
|
||||||
return "", errors.New("unsupported wakumessage version")
|
|
||||||
}
|
|
||||||
|
|
||||||
keyInfo := &payload.KeyInfo{
|
|
||||||
Kind: payload.Symmetric,
|
|
||||||
}
|
|
||||||
|
|
||||||
keyInfo.SymKey, err = utils.DecodeHexString(symmetricKey)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
payload, err := payload.DecodePayload(&msg, keyInfo)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
pubkey, signature := extractPubKeyAndSignature(payload)
|
|
||||||
|
|
||||||
response := struct {
|
|
||||||
PubKey string `json:"pubkey,omitempty"`
|
|
||||||
Signature string `json:"signature,omitempty"`
|
|
||||||
Data []byte `json:"data"`
|
|
||||||
Padding []byte `json:"padding"`
|
|
||||||
}{
|
|
||||||
PubKey: pubkey,
|
|
||||||
Signature: signature,
|
|
||||||
Data: payload.Data,
|
|
||||||
Padding: payload.Padding,
|
|
||||||
}
|
|
||||||
|
|
||||||
return marshalJSON(response)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DecodeAsymmetric decodes a waku message using a secp256k1 private key. The key must be a hex encoded string with "0x" prefix
|
|
||||||
func DecodeAsymmetric(messageJSON string, privateKey string) (string, error) {
|
|
||||||
var msg pb.WakuMessage
|
|
||||||
err := json.Unmarshal([]byte(messageJSON), &msg)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
if msg.Version == 0 {
|
|
||||||
return marshalJSON(msg.Payload)
|
|
||||||
} else if msg.Version > 1 {
|
|
||||||
return "", errors.New("unsupported wakumessage version")
|
|
||||||
}
|
|
||||||
|
|
||||||
keyInfo := &payload.KeyInfo{
|
|
||||||
Kind: payload.Asymmetric,
|
|
||||||
}
|
|
||||||
|
|
||||||
keyBytes, err := utils.DecodeHexString(privateKey)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
keyInfo.PrivKey, err = crypto.ToECDSA(keyBytes)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
payload, err := payload.DecodePayload(&msg, keyInfo)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
pubkey, signature := extractPubKeyAndSignature(payload)
|
|
||||||
|
|
||||||
response := struct {
|
|
||||||
PubKey string `json:"pubkey,omitempty"`
|
|
||||||
Signature string `json:"signature,omitempty"`
|
|
||||||
Data []byte `json:"data"`
|
|
||||||
Padding []byte `json:"padding"`
|
|
||||||
}{
|
|
||||||
PubKey: pubkey,
|
|
||||||
Signature: signature,
|
|
||||||
Data: payload.Data,
|
|
||||||
Padding: payload.Padding,
|
|
||||||
}
|
|
||||||
|
|
||||||
return marshalJSON(response)
|
|
||||||
}
|
|
||||||
|
@ -58,26 +58,6 @@ func RelayPublish(messageJSON string, topic string, ms int) (string, error) {
|
|||||||
return relayPublish(msg, getTopic(topic), int(ms))
|
return relayPublish(msg, getTopic(topic), int(ms))
|
||||||
}
|
}
|
||||||
|
|
||||||
// RelayPublishEncodeAsymmetric publish a message encrypted with a secp256k1 public key using waku relay and returns the message ID
|
|
||||||
func RelayPublishEncodeAsymmetric(messageJSON string, topic string, publicKey string, optionalSigningKey string, ms int) (string, error) {
|
|
||||||
msg, err := wakuMessageAsymmetricEncoding(messageJSON, publicKey, optionalSigningKey)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return relayPublish(msg, getTopic(topic), int(ms))
|
|
||||||
}
|
|
||||||
|
|
||||||
// RelayPublishEncodeSymmetric publishes a message encrypted with a 32 bytes symmetric key using waku relay and returns the message ID
|
|
||||||
func RelayPublishEncodeSymmetric(messageJSON string, topic string, symmetricKey string, optionalSigningKey string, ms int) (string, error) {
|
|
||||||
msg, err := wakuMessageSymmetricEncoding(messageJSON, symmetricKey, optionalSigningKey)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return relayPublish(msg, getTopic(topic), int(ms))
|
|
||||||
}
|
|
||||||
|
|
||||||
func relaySubscribe(topic string) error {
|
func relaySubscribe(topic string) error {
|
||||||
topicToSubscribe := getTopic(topic)
|
topicToSubscribe := getTopic(topic)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user