go-waku/mobile/encoding.go

97 lines
1.9 KiB
Go
Raw Normal View History

package gowaku
2022-04-02 20:22:42 -04:00
import (
"encoding/json"
"github.com/ethereum/go-ethereum/crypto"
"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/utils"
2022-04-02 20:22:42 -04:00
)
func wakuMessage(messageJSON string) (*pb.WakuMessage, error) {
var msg *pb.WakuMessage
2022-04-02 20:22:42 -04:00
err := json.Unmarshal([]byte(messageJSON), &msg)
msg.Version = 0
return msg, err
}
func wakuMessageSymmetricEncoding(messageJSON string, symmetricKey string, optionalSigningKey string) (*pb.WakuMessage, error) {
2022-04-02 20:22:42 -04:00
msg, err := wakuMessage(messageJSON)
if err != nil {
return msg, err
}
payload := payload.Payload{
2022-04-02 20:22:42 -04:00
Data: msg.Payload,
Key: &payload.KeyInfo{
Kind: payload.Symmetric,
2022-04-02 20:22:42 -04:00
},
}
keyBytes, err := utils.DecodeHexString(symmetricKey)
2022-04-02 20:22:42 -04:00
if err != nil {
return msg, err
}
payload.Key.SymKey = keyBytes
2022-04-02 20:22:42 -04:00
if optionalSigningKey != "" {
2022-09-14 15:19:04 -04:00
signingKeyBytes, err := utils.DecodeHexString(optionalSigningKey)
2022-04-02 20:22:42 -04:00
if err != nil {
return msg, err
}
payload.Key.PrivKey, err = crypto.ToECDSA(signingKeyBytes)
if err != nil {
return msg, err
}
}
msg.Version = 1
msg.Payload, err = payload.Encode(1)
return msg, err
}
func wakuMessageAsymmetricEncoding(messageJSON string, publicKey string, optionalSigningKey string) (*pb.WakuMessage, error) {
2022-04-02 20:22:42 -04:00
msg, err := wakuMessage(messageJSON)
if err != nil {
return msg, err
}
payload := payload.Payload{
2022-04-02 20:22:42 -04:00
Data: msg.Payload,
Key: &payload.KeyInfo{
Kind: payload.Asymmetric,
2022-04-02 20:22:42 -04:00
},
}
2022-09-14 15:19:04 -04:00
keyBytes, err := utils.DecodeHexString(publicKey)
2022-04-02 20:22:42 -04:00
if err != nil {
return msg, err
}
payload.Key.PubKey, err = unmarshalPubkey(keyBytes)
if err != nil {
return msg, err
}
if optionalSigningKey != "" {
2022-09-14 15:19:04 -04:00
signingKeyBytes, err := utils.DecodeHexString(optionalSigningKey)
2022-04-02 20:22:42 -04:00
if err != nil {
return msg, err
}
payload.Key.PrivKey, err = crypto.ToECDSA(signingKeyBytes)
if err != nil {
return msg, err
}
}
msg.Version = 1
msg.Payload, err = payload.Encode(1)
return msg, err
}