2023-04-04 11:44:28 -04:00
|
|
|
package rln
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ethereum/go-ethereum/core/types"
|
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/pb"
|
2023-11-07 15:48:43 -04:00
|
|
|
rlnpb "github.com/waku-org/go-waku/waku/v2/protocol/rln/pb"
|
2023-04-04 11:44:28 -04:00
|
|
|
"github.com/waku-org/go-zerokit-rln/rln"
|
2023-11-07 15:48:43 -04:00
|
|
|
"google.golang.org/protobuf/proto"
|
2023-04-04 11:44:28 -04:00
|
|
|
)
|
|
|
|
|
2023-07-19 12:25:35 -04:00
|
|
|
type messageValidationResult int
|
2023-04-04 11:44:28 -04:00
|
|
|
|
|
|
|
const (
|
2023-07-19 12:25:35 -04:00
|
|
|
validationError messageValidationResult = iota
|
|
|
|
validMessage
|
|
|
|
invalidMessage
|
|
|
|
spamMessage
|
2023-04-04 11:44:28 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// the maximum clock difference between peers in seconds
|
2023-07-19 12:25:35 -04:00
|
|
|
const maxClockGapSeconds = 20
|
2023-04-04 11:44:28 -04:00
|
|
|
|
|
|
|
// maximum allowed gap between the epochs of messages' RateLimitProofs
|
2023-07-19 12:25:35 -04:00
|
|
|
const maxEpochGap = int64(maxClockGapSeconds / rln.EPOCH_UNIT_SECONDS)
|
2023-04-04 11:44:28 -04:00
|
|
|
|
2023-07-19 12:25:35 -04:00
|
|
|
// acceptable roots for merkle root validation of incoming messages
|
|
|
|
const acceptableRootWindowSize = 5
|
2023-04-04 11:44:28 -04:00
|
|
|
|
|
|
|
type RegistrationHandler = func(tx *types.Transaction)
|
|
|
|
|
2023-09-07 17:39:10 -04:00
|
|
|
type SpamHandler = func(msg *pb.WakuMessage, topic string) error
|
2023-04-04 11:44:28 -04:00
|
|
|
|
|
|
|
func toRLNSignal(wakuMessage *pb.WakuMessage) []byte {
|
|
|
|
if wakuMessage == nil {
|
|
|
|
return []byte{}
|
|
|
|
}
|
|
|
|
|
|
|
|
contentTopicBytes := []byte(wakuMessage.ContentTopic)
|
|
|
|
return append(wakuMessage.Payload, contentTopicBytes...)
|
|
|
|
}
|
|
|
|
|
2023-11-07 15:48:43 -04:00
|
|
|
// Bytres2RateLimitProof converts a slice of bytes into a RateLimitProof instance
|
|
|
|
func BytesToRateLimitProof(data []byte) (*rln.RateLimitProof, error) {
|
|
|
|
if data == nil {
|
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
rateLimitProof := &rlnpb.RateLimitProof{}
|
|
|
|
err := proto.Unmarshal(data, rateLimitProof)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2023-04-04 11:44:28 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
result := &rln.RateLimitProof{
|
2023-11-07 15:48:43 -04:00
|
|
|
Proof: rln.ZKSNARK(rln.Bytes128(rateLimitProof.Proof)),
|
|
|
|
MerkleRoot: rln.MerkleNode(rln.Bytes32(rateLimitProof.MerkleRoot)),
|
|
|
|
Epoch: rln.Epoch(rln.Bytes32(rateLimitProof.Epoch)),
|
|
|
|
ShareX: rln.MerkleNode(rln.Bytes32(rateLimitProof.ShareX)),
|
|
|
|
ShareY: rln.MerkleNode(rln.Bytes32(rateLimitProof.ShareY)),
|
|
|
|
Nullifier: rln.Nullifier(rln.Bytes32(rateLimitProof.Nullifier)),
|
|
|
|
RLNIdentifier: rln.RLNIdentifier(rln.Bytes32(rateLimitProof.RlnIdentifier)),
|
2023-04-04 11:44:28 -04:00
|
|
|
}
|
|
|
|
|
2023-11-07 15:48:43 -04:00
|
|
|
return result, nil
|
2023-04-04 11:44:28 -04:00
|
|
|
}
|