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