mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-16 08:44:36 +00:00
chore(rln): run rln in all relay pubsubtopics + remove cli flags
This commit is contained in:
parent
5422af8130
commit
624fe1bb2f
@ -6,7 +6,6 @@ package main
|
|||||||
import (
|
import (
|
||||||
cli "github.com/urfave/cli/v2"
|
cli "github.com/urfave/cli/v2"
|
||||||
wcli "github.com/waku-org/go-waku/waku/cliutils"
|
wcli "github.com/waku-org/go-waku/waku/cliutils"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func rlnFlags() []cli.Flag {
|
func rlnFlags() []cli.Flag {
|
||||||
@ -23,18 +22,6 @@ func rlnFlags() []cli.Flag {
|
|||||||
Usage: "the index of credentials to use, within a specific rln membership set",
|
Usage: "the index of credentials to use, within a specific rln membership set",
|
||||||
Destination: &options.RLNRelay.MembershipGroupIndex,
|
Destination: &options.RLNRelay.MembershipGroupIndex,
|
||||||
},
|
},
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "rln-relay-pubsub-topic",
|
|
||||||
Value: "/waku/2/default-waku/proto",
|
|
||||||
Usage: "the pubsub topic for which rln-relay gets enabled",
|
|
||||||
Destination: &options.RLNRelay.PubsubTopic,
|
|
||||||
},
|
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "rln-relay-content-topic",
|
|
||||||
Value: protocol.NewContentTopic("toy-chat", 3, "mingde", "proto").String(),
|
|
||||||
Usage: "the content topic for which rln-relay gets enabled",
|
|
||||||
Destination: &options.RLNRelay.ContentTopic,
|
|
||||||
},
|
|
||||||
&cli.BoolFlag{
|
&cli.BoolFlag{
|
||||||
Name: "rln-relay-dynamic",
|
Name: "rln-relay-dynamic",
|
||||||
Usage: "Enable waku-rln-relay with on-chain dynamic group management",
|
Usage: "Enable waku-rln-relay with on-chain dynamic group management",
|
||||||
|
@ -17,13 +17,11 @@ func checkForRLN(logger *zap.Logger, options NodeOptions, nodeOpts *[]node.WakuN
|
|||||||
failOnErr(errors.New("relay not available"), "Could not enable RLN Relay")
|
failOnErr(errors.New("relay not available"), "Could not enable RLN Relay")
|
||||||
}
|
}
|
||||||
if !options.RLNRelay.Dynamic {
|
if !options.RLNRelay.Dynamic {
|
||||||
*nodeOpts = append(*nodeOpts, node.WithStaticRLNRelay(options.RLNRelay.PubsubTopic, options.RLNRelay.ContentTopic, rln.MembershipIndex(options.RLNRelay.MembershipGroupIndex), nil))
|
*nodeOpts = append(*nodeOpts, node.WithStaticRLNRelay(rln.MembershipIndex(options.RLNRelay.MembershipGroupIndex), nil))
|
||||||
} else {
|
} else {
|
||||||
// TODO: too many parameters in this function
|
// TODO: too many parameters in this function
|
||||||
// consider passing a config struct instead
|
// consider passing a config struct instead
|
||||||
*nodeOpts = append(*nodeOpts, node.WithDynamicRLNRelay(
|
*nodeOpts = append(*nodeOpts, node.WithDynamicRLNRelay(
|
||||||
options.RLNRelay.PubsubTopic,
|
|
||||||
options.RLNRelay.ContentTopic,
|
|
||||||
options.RLNRelay.CredentialsPath,
|
options.RLNRelay.CredentialsPath,
|
||||||
options.RLNRelay.CredentialsPassword,
|
options.RLNRelay.CredentialsPassword,
|
||||||
options.RLNRelay.CredentialsIndex,
|
options.RLNRelay.CredentialsIndex,
|
||||||
|
@ -40,8 +40,6 @@ type RLNRelayOptions struct {
|
|||||||
CredentialsIndex uint
|
CredentialsIndex uint
|
||||||
TreePath string
|
TreePath string
|
||||||
MembershipGroupIndex uint
|
MembershipGroupIndex uint
|
||||||
PubsubTopic string
|
|
||||||
ContentTopic string
|
|
||||||
Dynamic bool
|
Dynamic bool
|
||||||
ETHClientAddress string
|
ETHClientAddress string
|
||||||
MembershipContractAddress common.Address
|
MembershipContractAddress common.Address
|
||||||
|
@ -141,7 +141,7 @@ func (c *Chat) receiveMessages() {
|
|||||||
case value := <-c.C:
|
case value := <-c.C:
|
||||||
|
|
||||||
msgContentTopic := value.Message().ContentTopic
|
msgContentTopic := value.Message().ContentTopic
|
||||||
if msgContentTopic != c.options.ContentTopic || (c.options.RLNRelay.Enable && msgContentTopic != c.options.RLNRelay.ContentTopic) {
|
if msgContentTopic != c.options.ContentTopic {
|
||||||
continue // Discard messages from other topics
|
continue // Discard messages from other topics
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,8 +50,6 @@ func execute(options Options) {
|
|||||||
if options.RLNRelay.Dynamic {
|
if options.RLNRelay.Dynamic {
|
||||||
fmt.Println("Setting up dynamic rln...")
|
fmt.Println("Setting up dynamic rln...")
|
||||||
opts = append(opts, node.WithDynamicRLNRelay(
|
opts = append(opts, node.WithDynamicRLNRelay(
|
||||||
options.RLNRelay.PubsubTopic,
|
|
||||||
options.RLNRelay.ContentTopic,
|
|
||||||
options.RLNRelay.CredentialsPath,
|
options.RLNRelay.CredentialsPath,
|
||||||
options.RLNRelay.CredentialsPassword,
|
options.RLNRelay.CredentialsPassword,
|
||||||
options.RLNRelay.CredentialsIndex,
|
options.RLNRelay.CredentialsIndex,
|
||||||
@ -63,8 +61,6 @@ func execute(options Options) {
|
|||||||
))
|
))
|
||||||
} else {
|
} else {
|
||||||
opts = append(opts, node.WithStaticRLNRelay(
|
opts = append(opts, node.WithStaticRLNRelay(
|
||||||
options.RLNRelay.PubsubTopic,
|
|
||||||
options.RLNRelay.ContentTopic,
|
|
||||||
uint(options.RLNRelay.MembershipIndex),
|
uint(options.RLNRelay.MembershipIndex),
|
||||||
spamHandler))
|
spamHandler))
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,6 @@ import (
|
|||||||
"github.com/waku-org/go-waku/waku/cliutils"
|
"github.com/waku-org/go-waku/waku/cliutils"
|
||||||
wcli "github.com/waku-org/go-waku/waku/cliutils"
|
wcli "github.com/waku-org/go-waku/waku/cliutils"
|
||||||
"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/relay"
|
|
||||||
|
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
)
|
)
|
||||||
@ -198,18 +197,6 @@ func getFlags() []cli.Flag {
|
|||||||
Usage: "the index of credentials to use",
|
Usage: "the index of credentials to use",
|
||||||
Destination: &options.RLNRelay.CredentialsIndex,
|
Destination: &options.RLNRelay.CredentialsIndex,
|
||||||
},
|
},
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "rln-relay-pubsub-topic",
|
|
||||||
Value: relay.DefaultWakuTopic,
|
|
||||||
Usage: "the pubsub topic for which rln-relay gets enabled",
|
|
||||||
Destination: &options.RLNRelay.PubsubTopic,
|
|
||||||
},
|
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "rln-relay-content-topic",
|
|
||||||
Value: testnetContentTopic,
|
|
||||||
Usage: "the content topic for which rln-relay gets enabled",
|
|
||||||
Destination: &options.RLNRelay.ContentTopic,
|
|
||||||
},
|
|
||||||
&cli.BoolFlag{
|
&cli.BoolFlag{
|
||||||
Name: "rln-relay-dynamic",
|
Name: "rln-relay-dynamic",
|
||||||
Usage: "Enable waku-rln-relay with on-chain dynamic group management",
|
Usage: "Enable waku-rln-relay with on-chain dynamic group management",
|
||||||
|
@ -34,8 +34,6 @@ type RLNRelayOptions struct {
|
|||||||
CredentialsIndex uint
|
CredentialsIndex uint
|
||||||
MembershipGroupIndex uint
|
MembershipGroupIndex uint
|
||||||
MembershipIndex uint
|
MembershipIndex uint
|
||||||
PubsubTopic string
|
|
||||||
ContentTopic string
|
|
||||||
Dynamic bool
|
Dynamic bool
|
||||||
ETHClientAddress string
|
ETHClientAddress string
|
||||||
MembershipContractAddress common.Address
|
MembershipContractAddress common.Address
|
||||||
|
@ -10,6 +10,7 @@ import (
|
|||||||
backoffv4 "github.com/cenkalti/backoff/v4"
|
backoffv4 "github.com/cenkalti/backoff/v4"
|
||||||
golog "github.com/ipfs/go-log/v2"
|
golog "github.com/ipfs/go-log/v2"
|
||||||
"github.com/libp2p/go-libp2p"
|
"github.com/libp2p/go-libp2p"
|
||||||
|
pubsub "github.com/libp2p/go-libp2p-pubsub"
|
||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/crypto"
|
"github.com/ethereum/go-ethereum/crypto"
|
||||||
@ -66,10 +67,14 @@ type IdentityCredential = struct {
|
|||||||
IDCommitment byte32 `json:"idCommitment"`
|
IDCommitment byte32 `json:"idCommitment"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type SpamHandler = func(message *pb.WakuMessage) error
|
||||||
|
|
||||||
type RLNRelay interface {
|
type RLNRelay interface {
|
||||||
IdentityCredential() (IdentityCredential, error)
|
IdentityCredential() (IdentityCredential, error)
|
||||||
MembershipIndex() (uint, error)
|
MembershipIndex() (uint, error)
|
||||||
AppendRLNProof(msg *pb.WakuMessage, senderEpochTime time.Time) error
|
AppendRLNProof(msg *pb.WakuMessage, senderEpochTime time.Time) error
|
||||||
|
Validator(spamHandler SpamHandler) func(ctx context.Context, peerID peer.ID, message *pubsub.Message) bool
|
||||||
|
Start(ctx context.Context) error
|
||||||
Stop() error
|
Stop() error
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -275,6 +280,14 @@ func New(opts ...WakuNodeOption) (*WakuNode, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
w.rendezvous = rendezvous.NewRendezvous(w.opts.rendezvousDB, w.peerConnector, w.log)
|
w.rendezvous = rendezvous.NewRendezvous(w.opts.rendezvousDB, w.peerConnector, w.log)
|
||||||
|
|
||||||
|
if w.opts.enableRelay {
|
||||||
|
err = w.setupRLNRelay()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
w.relay = relay.NewWakuRelay(w.bcaster, w.opts.minRelayPeersToPublish, w.timesource, w.opts.prometheusReg, w.log, w.opts.pubsubOpts...)
|
w.relay = relay.NewWakuRelay(w.bcaster, w.opts.minRelayPeersToPublish, w.timesource, w.opts.prometheusReg, w.log, w.opts.pubsubOpts...)
|
||||||
w.legacyFilter = legacy_filter.NewWakuFilter(w.bcaster, w.opts.isLegacyFilterFullNode, w.timesource, w.opts.prometheusReg, w.log, w.opts.legacyFilterOpts...)
|
w.legacyFilter = legacy_filter.NewWakuFilter(w.bcaster, w.opts.isLegacyFilterFullNode, w.timesource, w.opts.prometheusReg, w.log, w.opts.legacyFilterOpts...)
|
||||||
w.filterFullNode = filter.NewWakuFilterFullNode(w.timesource, w.opts.prometheusReg, w.log, w.opts.filterOpts...)
|
w.filterFullNode = filter.NewWakuFilterFullNode(w.timesource, w.opts.prometheusReg, w.log, w.opts.filterOpts...)
|
||||||
@ -480,7 +493,7 @@ func (w *WakuNode) Start(ctx context.Context) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if w.opts.enableRLN {
|
if w.opts.enableRLN {
|
||||||
err = w.mountRlnRelay(ctx)
|
err = w.startRlnRelay(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,11 @@ func (w *WakuNode) RLNRelay() RLNRelay {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *WakuNode) mountRlnRelay(ctx context.Context) error {
|
func (w *WakuNode) setupRLNRelay() error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w *WakuNode) startRlnRelay(ctx context.Context) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,11 +8,11 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
|
|
||||||
|
pubsub "github.com/libp2p/go-libp2p-pubsub"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/dynamic"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/dynamic"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/static"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/static"
|
||||||
r "github.com/waku-org/go-zerokit-rln/rln"
|
r "github.com/waku-org/go-zerokit-rln/rln"
|
||||||
"go.uber.org/zap"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// RLNRelay is used to access any operation related to Waku RLN protocol
|
// RLNRelay is used to access any operation related to Waku RLN protocol
|
||||||
@ -20,13 +20,7 @@ func (w *WakuNode) RLNRelay() RLNRelay {
|
|||||||
return w.rlnRelay
|
return w.rlnRelay
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *WakuNode) mountRlnRelay(ctx context.Context) error {
|
func (w *WakuNode) setupRLNRelay() error {
|
||||||
// check whether inputs are provided
|
|
||||||
// relay protocol is the prerequisite of rln-relay
|
|
||||||
if w.Relay() == nil {
|
|
||||||
return errors.New("relay protocol is required")
|
|
||||||
}
|
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
var groupManager rln.GroupManager
|
var groupManager rln.GroupManager
|
||||||
|
|
||||||
@ -61,18 +55,27 @@ func (w *WakuNode) mountRlnRelay(ctx context.Context) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rlnRelay, err := rln.New(w.Relay(), groupManager, w.opts.rlnTreePath, w.opts.rlnRelayPubsubTopic, w.opts.rlnRelayContentTopic, w.opts.rlnSpamHandler, w.timesource, w.log)
|
rlnRelay, err := rln.New(groupManager, w.opts.rlnTreePath, w.timesource, w.log)
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
err = rlnRelay.Start(ctx)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
w.rlnRelay = rlnRelay
|
w.rlnRelay = rlnRelay
|
||||||
|
|
||||||
|
// Adding RLN as a default validator
|
||||||
|
w.opts.pubsubOpts = append(w.opts.pubsubOpts, pubsub.WithDefaultValidator(rlnRelay.Validator(w.opts.rlnSpamHandler)))
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w *WakuNode) startRlnRelay(ctx context.Context) error {
|
||||||
|
rlnRelay := w.rlnRelay.(*rln.WakuRLNRelay)
|
||||||
|
|
||||||
|
err := rlnRelay.Start(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
if !w.opts.rlnRelayDynamic {
|
if !w.opts.rlnRelayDynamic {
|
||||||
// check the correct construction of the tree by comparing the calculated root against the expected root
|
// check the correct construction of the tree by comparing the calculated root against the expected root
|
||||||
// no error should happen as it is already captured in the unit tests
|
// no error should happen as it is already captured in the unit tests
|
||||||
@ -91,7 +94,7 @@ func (w *WakuNode) mountRlnRelay(ctx context.Context) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
w.log.Info("mounted waku RLN relay", zap.String("pubsubTopic", w.opts.rlnRelayPubsubTopic), zap.String("contentTopic", w.opts.rlnRelayContentTopic))
|
w.log.Info("mounted waku RLN relay")
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -95,8 +95,6 @@ type WakuNodeParameters struct {
|
|||||||
|
|
||||||
enableRLN bool
|
enableRLN bool
|
||||||
rlnRelayMemIndex uint
|
rlnRelayMemIndex uint
|
||||||
rlnRelayPubsubTopic string
|
|
||||||
rlnRelayContentTopic string
|
|
||||||
rlnRelayDynamic bool
|
rlnRelayDynamic bool
|
||||||
rlnSpamHandler func(message *pb.WakuMessage) error
|
rlnSpamHandler func(message *pb.WakuMessage) error
|
||||||
rlnETHClientAddress string
|
rlnETHClientAddress string
|
||||||
|
@ -11,13 +11,11 @@ import (
|
|||||||
|
|
||||||
// WithStaticRLNRelay enables the Waku V2 RLN protocol in offchain mode
|
// WithStaticRLNRelay enables the Waku V2 RLN protocol in offchain mode
|
||||||
// Requires the `gowaku_rln` build constrain (or the env variable RLN=true if building go-waku)
|
// Requires the `gowaku_rln` build constrain (or the env variable RLN=true if building go-waku)
|
||||||
func WithStaticRLNRelay(pubsubTopic string, contentTopic string, memberIndex r.MembershipIndex, spamHandler rln.SpamHandler) WakuNodeOption {
|
func WithStaticRLNRelay(memberIndex r.MembershipIndex, spamHandler rln.SpamHandler) WakuNodeOption {
|
||||||
return func(params *WakuNodeParameters) error {
|
return func(params *WakuNodeParameters) error {
|
||||||
params.enableRLN = true
|
params.enableRLN = true
|
||||||
params.rlnRelayDynamic = false
|
params.rlnRelayDynamic = false
|
||||||
params.rlnRelayMemIndex = memberIndex
|
params.rlnRelayMemIndex = memberIndex
|
||||||
params.rlnRelayPubsubTopic = pubsubTopic
|
|
||||||
params.rlnRelayContentTopic = contentTopic
|
|
||||||
params.rlnSpamHandler = spamHandler
|
params.rlnSpamHandler = spamHandler
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -25,15 +23,13 @@ func WithStaticRLNRelay(pubsubTopic string, contentTopic string, memberIndex r.M
|
|||||||
|
|
||||||
// WithDynamicRLNRelay enables the Waku V2 RLN protocol in onchain mode.
|
// WithDynamicRLNRelay enables the Waku V2 RLN protocol in onchain mode.
|
||||||
// Requires the `gowaku_rln` build constrain (or the env variable RLN=true if building go-waku)
|
// Requires the `gowaku_rln` build constrain (or the env variable RLN=true if building go-waku)
|
||||||
func WithDynamicRLNRelay(pubsubTopic string, contentTopic string, keystorePath string, keystorePassword string, keystoreIndex uint, treePath string, membershipContract common.Address, membershipGroupIndex uint, spamHandler rln.SpamHandler, ethClientAddress string) WakuNodeOption {
|
func WithDynamicRLNRelay(keystorePath string, keystorePassword string, keystoreIndex uint, treePath string, membershipContract common.Address, membershipGroupIndex uint, spamHandler rln.SpamHandler, ethClientAddress string) WakuNodeOption {
|
||||||
return func(params *WakuNodeParameters) error {
|
return func(params *WakuNodeParameters) error {
|
||||||
params.enableRLN = true
|
params.enableRLN = true
|
||||||
params.rlnRelayDynamic = true
|
params.rlnRelayDynamic = true
|
||||||
params.keystorePassword = keystorePassword
|
params.keystorePassword = keystorePassword
|
||||||
params.keystorePath = keystorePath
|
params.keystorePath = keystorePath
|
||||||
params.keystoreIndex = keystoreIndex
|
params.keystoreIndex = keystoreIndex
|
||||||
params.rlnRelayPubsubTopic = pubsubTopic
|
|
||||||
params.rlnRelayContentTopic = contentTopic
|
|
||||||
params.rlnSpamHandler = spamHandler
|
params.rlnSpamHandler = spamHandler
|
||||||
params.rlnETHClientAddress = ethClientAddress
|
params.rlnETHClientAddress = ethClientAddress
|
||||||
params.rlnMembershipContractAddress = membershipContract
|
params.rlnMembershipContractAddress = membershipContract
|
||||||
|
@ -179,6 +179,7 @@ func NewWakuRelay(bcaster Broadcaster, minPeersToPublish int, timesource timesou
|
|||||||
pubsub.WithSeenMessagesTTL(2 * time.Minute),
|
pubsub.WithSeenMessagesTTL(2 * time.Minute),
|
||||||
pubsub.WithPeerScore(w.peerScoreParams, w.peerScoreThresholds),
|
pubsub.WithPeerScore(w.peerScoreParams, w.peerScoreThresholds),
|
||||||
pubsub.WithPeerScoreInspect(w.peerScoreInspector, 6*time.Second),
|
pubsub.WithPeerScoreInspect(w.peerScoreInspector, 6*time.Second),
|
||||||
|
// TODO: to improve - setup default validator only if no default validator has been set.
|
||||||
pubsub.WithDefaultValidator(func(ctx context.Context, peerID peer.ID, message *pubsub.Message) bool {
|
pubsub.WithDefaultValidator(func(ctx context.Context, peerID peer.ID, message *pubsub.Message) bool {
|
||||||
msg := new(pb.WakuMessage)
|
msg := new(pb.WakuMessage)
|
||||||
err := proto.Unmarshal(message.Data, msg)
|
err := proto.Unmarshal(message.Data, msg)
|
||||||
|
@ -6,14 +6,12 @@ package rln
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"crypto/ecdsa"
|
"crypto/ecdsa"
|
||||||
"crypto/rand"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"math/big"
|
"math/big"
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
|
||||||
"github.com/waku-org/go-zerokit-rln/rln"
|
"github.com/waku-org/go-zerokit-rln/rln"
|
||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
|
|
||||||
@ -23,8 +21,6 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/crypto"
|
"github.com/ethereum/go-ethereum/crypto"
|
||||||
"github.com/ethereum/go-ethereum/ethclient"
|
"github.com/ethereum/go-ethereum/ethclient"
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
"github.com/waku-org/go-waku/tests"
|
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/relay"
|
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln/contracts"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/contracts"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager"
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/dynamic"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/dynamic"
|
||||||
@ -145,18 +141,6 @@ func (s *WakuRLNRelayDynamicSuite) TestDynamicGroupManagement() {
|
|||||||
rlnInstance, err := rln.NewRLN()
|
rlnInstance, err := rln.NewRLN()
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
port, err := tests.FindFreePort(s.T(), "", 5)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
host, err := tests.MakeHost(context.Background(), port, rand.Reader)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
relay := relay.NewWakuRelay(nil, 0, timesource.NewDefaultClock(), prometheus.DefaultRegisterer, utils.Logger())
|
|
||||||
relay.SetHost(host)
|
|
||||||
err = relay.Start(context.TODO())
|
|
||||||
defer relay.Stop()
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
rt, err := group_manager.NewMerkleRootTracker(5, rlnInstance)
|
rt, err := group_manager.NewMerkleRootTracker(5, rlnInstance)
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
@ -172,7 +156,6 @@ func (s *WakuRLNRelayDynamicSuite) TestDynamicGroupManagement() {
|
|||||||
rlnRelay := &WakuRLNRelay{
|
rlnRelay := &WakuRLNRelay{
|
||||||
rootTracker: rt,
|
rootTracker: rt,
|
||||||
groupManager: gm,
|
groupManager: gm,
|
||||||
relay: relay,
|
|
||||||
RLN: rlnInstance,
|
RLN: rlnInstance,
|
||||||
log: utils.Logger(),
|
log: utils.Logger(),
|
||||||
nullifierLog: make(map[rln.MerkleNode][]rln.ProofMetadata),
|
nullifierLog: make(map[rln.MerkleNode][]rln.ProofMetadata),
|
||||||
@ -243,25 +226,6 @@ func (s *WakuRLNRelayDynamicSuite) TestMerkleTreeConstruction() {
|
|||||||
_, membershipGroupIndex := s.register(credentials1, s.u1PrivKey, "./test_onchain.json")
|
_, membershipGroupIndex := s.register(credentials1, s.u1PrivKey, "./test_onchain.json")
|
||||||
_, membershipGroupIndex = s.register(credentials2, s.u1PrivKey, "./test_onchain.json")
|
_, membershipGroupIndex = s.register(credentials2, s.u1PrivKey, "./test_onchain.json")
|
||||||
|
|
||||||
// Creating relay
|
|
||||||
port, err := tests.FindFreePort(s.T(), "", 5)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
host, err := tests.MakeHost(context.Background(), port, rand.Reader)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
relay := relay.NewWakuRelay(nil, 0, timesource.NewDefaultClock(), prometheus.DefaultRegisterer, utils.Logger())
|
|
||||||
relay.SetHost(host)
|
|
||||||
err = relay.Start(context.TODO())
|
|
||||||
defer relay.Stop()
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
// Subscribing to topic
|
|
||||||
|
|
||||||
sub, err := relay.SubscribeToTopic(context.TODO(), RLNRELAY_PUBSUB_TOPIC)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
defer sub.Unsubscribe()
|
|
||||||
|
|
||||||
// mount the rln relay protocol in the on-chain/dynamic mode
|
// mount the rln relay protocol in the on-chain/dynamic mode
|
||||||
// TODO: This assumes the keystoreIndex is 0, but there are two possible credentials in this keystore due to using the same contract address
|
// TODO: This assumes the keystoreIndex is 0, but there are two possible credentials in this keystore due to using the same contract address
|
||||||
// when credentials1 and credentials2 were registered. We should remove this hardcoded value and obtain the correct value when the credentials are persisted
|
// when credentials1 and credentials2 were registered. We should remove this hardcoded value and obtain the correct value when the credentials are persisted
|
||||||
@ -269,7 +233,7 @@ func (s *WakuRLNRelayDynamicSuite) TestMerkleTreeConstruction() {
|
|||||||
gm, err := dynamic.NewDynamicGroupManager(s.clientAddr, s.rlnAddr, membershipGroupIndex, "./test_onchain.json", keystorePassword, keystoreIndex, false, utils.Logger())
|
gm, err := dynamic.NewDynamicGroupManager(s.clientAddr, s.rlnAddr, membershipGroupIndex, "./test_onchain.json", keystorePassword, keystoreIndex, false, utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
rlnRelay, err := New(relay, gm, "test-merkle-tree.db", RLNRELAY_PUBSUB_TOPIC, RLNRELAY_CONTENT_TOPIC, nil, timesource.NewDefaultClock(), utils.Logger())
|
rlnRelay, err := New(gm, "test-merkle-tree.db", timesource.NewDefaultClock(), utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
err = rlnRelay.Start(context.TODO())
|
err = rlnRelay.Start(context.TODO())
|
||||||
@ -292,21 +256,6 @@ func (s *WakuRLNRelayDynamicSuite) TestCorrectRegistrationOfPeers() {
|
|||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
// Node 1 ============================================================
|
// Node 1 ============================================================
|
||||||
port1, err := tests.FindFreePort(s.T(), "", 5)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
host1, err := tests.MakeHost(context.Background(), port1, rand.Reader)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
relay1 := relay.NewWakuRelay(nil, 0, timesource.NewDefaultClock(), prometheus.DefaultRegisterer, utils.Logger())
|
|
||||||
relay1.SetHost(host1)
|
|
||||||
err = relay1.Start(context.TODO())
|
|
||||||
defer relay1.Stop()
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
sub1, err := relay1.SubscribeToTopic(context.TODO(), RLNRELAY_PUBSUB_TOPIC)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
defer sub1.Unsubscribe()
|
|
||||||
|
|
||||||
// Register credentials1 in contract and keystore1
|
// Register credentials1 in contract and keystore1
|
||||||
credentials1 := s.generateCredentials(rlnInstance)
|
credentials1 := s.generateCredentials(rlnInstance)
|
||||||
@ -318,27 +267,12 @@ func (s *WakuRLNRelayDynamicSuite) TestCorrectRegistrationOfPeers() {
|
|||||||
gm1, err := dynamic.NewDynamicGroupManager(s.clientAddr, s.rlnAddr, membershipGroupIndex, keystorePath1, keystorePassword, 0, false, utils.Logger())
|
gm1, err := dynamic.NewDynamicGroupManager(s.clientAddr, s.rlnAddr, membershipGroupIndex, keystorePath1, keystorePassword, 0, false, utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
rlnRelay1, err := New(relay1, gm1, "test-correct-registration-1.db", RLNRELAY_PUBSUB_TOPIC, RLNRELAY_CONTENT_TOPIC, nil, timesource.NewDefaultClock(), utils.Logger())
|
rlnRelay1, err := New(gm1, "test-correct-registration-1.db", timesource.NewDefaultClock(), utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
err = rlnRelay1.Start(context.TODO())
|
err = rlnRelay1.Start(context.TODO())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
// Node 2 ============================================================
|
// Node 2 ============================================================
|
||||||
port2, err := tests.FindFreePort(s.T(), "", 5)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
host2, err := tests.MakeHost(context.Background(), port2, rand.Reader)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
relay2 := relay.NewWakuRelay(nil, 0, timesource.NewDefaultClock(), prometheus.DefaultRegisterer, utils.Logger())
|
|
||||||
relay2.SetHost(host2)
|
|
||||||
err = relay2.Start(context.TODO())
|
|
||||||
defer relay2.Stop()
|
|
||||||
s.Require().NoError(err)
|
|
||||||
|
|
||||||
sub2, err := relay2.SubscribeToTopic(context.TODO(), RLNRELAY_PUBSUB_TOPIC)
|
|
||||||
s.Require().NoError(err)
|
|
||||||
defer sub2.Unsubscribe()
|
|
||||||
|
|
||||||
// Register credentials2 in contract and keystore2
|
// Register credentials2 in contract and keystore2
|
||||||
credentials2 := s.generateCredentials(rlnInstance)
|
credentials2 := s.generateCredentials(rlnInstance)
|
||||||
@ -350,7 +284,7 @@ func (s *WakuRLNRelayDynamicSuite) TestCorrectRegistrationOfPeers() {
|
|||||||
gm2, err := dynamic.NewDynamicGroupManager(s.clientAddr, s.rlnAddr, membershipGroupIndex, keystorePath2, keystorePassword, 0, false, utils.Logger())
|
gm2, err := dynamic.NewDynamicGroupManager(s.clientAddr, s.rlnAddr, membershipGroupIndex, keystorePath2, keystorePassword, 0, false, utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
rlnRelay2, err := New(relay2, gm2, "test-correct-registration-2.db", RLNRELAY_PUBSUB_TOPIC, RLNRELAY_CONTENT_TOPIC, nil, timesource.NewDefaultClock(), utils.Logger())
|
rlnRelay2, err := New(gm2, "test-correct-registration-2.db", timesource.NewDefaultClock(), utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
err = rlnRelay2.Start(context.TODO())
|
err = rlnRelay2.Start(context.TODO())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
@ -59,7 +59,7 @@ func (s *WakuRLNRelaySuite) TestOffchainMode() {
|
|||||||
groupManager, err := static.NewStaticGroupManager(groupIDCommitments, idCredential, index, utils.Logger())
|
groupManager, err := static.NewStaticGroupManager(groupIDCommitments, idCredential, index, utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
wakuRLNRelay, err := New(relay, groupManager, "", RLNRELAY_PUBSUB_TOPIC, RLNRELAY_CONTENT_TOPIC, nil, timesource.NewDefaultClock(), utils.Logger())
|
wakuRLNRelay, err := New(groupManager, "", timesource.NewDefaultClock(), utils.Logger())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
err = wakuRLNRelay.Start(context.TODO())
|
err = wakuRLNRelay.Start(context.TODO())
|
||||||
|
@ -13,7 +13,6 @@ import (
|
|||||||
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"
|
||||||
"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/protocol/relay"
|
|
||||||
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager"
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager"
|
||||||
"github.com/waku-org/go-waku/waku/v2/timesource"
|
"github.com/waku-org/go-waku/waku/v2/timesource"
|
||||||
"github.com/waku-org/go-zerokit-rln/rln"
|
"github.com/waku-org/go-zerokit-rln/rln"
|
||||||
@ -29,17 +28,11 @@ type GroupManager interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type WakuRLNRelay struct {
|
type WakuRLNRelay struct {
|
||||||
relay *relay.WakuRelay
|
|
||||||
timesource timesource.Timesource
|
timesource timesource.Timesource
|
||||||
|
|
||||||
groupManager GroupManager
|
groupManager GroupManager
|
||||||
rootTracker *group_manager.MerkleRootTracker
|
rootTracker *group_manager.MerkleRootTracker
|
||||||
|
|
||||||
// pubsubTopic is the topic for which rln relay is mounted
|
|
||||||
pubsubTopic string
|
|
||||||
contentTopic string
|
|
||||||
spamHandler SpamHandler
|
|
||||||
|
|
||||||
RLN *rln.RLN
|
RLN *rln.RLN
|
||||||
|
|
||||||
// the log of nullifiers and Shamir shares of the past messages grouped per epoch
|
// the log of nullifiers and Shamir shares of the past messages grouped per epoch
|
||||||
@ -52,12 +45,8 @@ type WakuRLNRelay struct {
|
|||||||
const rlnDefaultTreePath = "./rln_tree.db"
|
const rlnDefaultTreePath = "./rln_tree.db"
|
||||||
|
|
||||||
func New(
|
func New(
|
||||||
relay *relay.WakuRelay,
|
|
||||||
groupManager GroupManager,
|
groupManager GroupManager,
|
||||||
treePath string,
|
treePath string,
|
||||||
pubsubTopic string,
|
|
||||||
contentTopic string,
|
|
||||||
spamHandler SpamHandler,
|
|
||||||
timesource timesource.Timesource,
|
timesource timesource.Timesource,
|
||||||
log *zap.Logger) (*WakuRLNRelay, error) {
|
log *zap.Logger) (*WakuRLNRelay, error) {
|
||||||
|
|
||||||
@ -86,10 +75,6 @@ func New(
|
|||||||
RLN: rlnInstance,
|
RLN: rlnInstance,
|
||||||
groupManager: groupManager,
|
groupManager: groupManager,
|
||||||
rootTracker: rootTracker,
|
rootTracker: rootTracker,
|
||||||
pubsubTopic: pubsubTopic,
|
|
||||||
contentTopic: contentTopic,
|
|
||||||
relay: relay,
|
|
||||||
spamHandler: spamHandler,
|
|
||||||
log: log,
|
log: log,
|
||||||
timesource: timesource,
|
timesource: timesource,
|
||||||
nullifierLog: make(map[rln.MerkleNode][]rln.ProofMetadata),
|
nullifierLog: make(map[rln.MerkleNode][]rln.ProofMetadata),
|
||||||
@ -104,15 +89,7 @@ func (rlnRelay *WakuRLNRelay) Start(ctx context.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// adds a topic validator for the supplied pubsub topic at the relay protocol
|
log.Info("rln relay topic validator mounted")
|
||||||
// messages published on this pubsub topic will be relayed upon a successful validation, otherwise they will be dropped
|
|
||||||
// the topic validator checks for the correct non-spamming proof of the message
|
|
||||||
err = rlnRelay.addValidator(rlnRelay.relay, rlnRelay.pubsubTopic, rlnRelay.contentTopic, rlnRelay.spamHandler)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
log.Info("rln relay topic validator mounted", zap.String("pubsubTopic", rlnRelay.pubsubTopic), zap.String("contentTopic", rlnRelay.contentTopic))
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -287,15 +264,11 @@ func (rlnRelay *WakuRLNRelay) AppendRLNProof(msg *pb.WakuMessage, senderEpochTim
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// this function sets a validator for the waku messages published on the supplied pubsubTopic and contentTopic
|
// Validator returns a validator for the waku messages.
|
||||||
// if contentTopic is empty, then validation takes place for All the messages published on the given pubsubTopic
|
// The message validation logic is according to https://rfc.vac.dev/spec/17/
|
||||||
// the message validation logic is according to https://rfc.vac.dev/spec/17/
|
func (rlnRelay *WakuRLNRelay) Validator(
|
||||||
func (rlnRelay *WakuRLNRelay) addValidator(
|
spamHandler SpamHandler) func(ctx context.Context, peerID peer.ID, message *pubsub.Message) bool {
|
||||||
relay *relay.WakuRelay,
|
return func(ctx context.Context, peerID peer.ID, message *pubsub.Message) bool {
|
||||||
pubsubTopic string,
|
|
||||||
contentTopic string,
|
|
||||||
spamHandler SpamHandler) error {
|
|
||||||
validator := func(ctx context.Context, peerID peer.ID, message *pubsub.Message) bool {
|
|
||||||
rlnRelay.log.Debug("rln-relay topic validator called")
|
rlnRelay.log.Debug("rln-relay topic validator called")
|
||||||
|
|
||||||
wakuMessage := &pb.WakuMessage{}
|
wakuMessage := &pb.WakuMessage{}
|
||||||
@ -304,12 +277,6 @@ func (rlnRelay *WakuRLNRelay) addValidator(
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
// check the contentTopic
|
|
||||||
if (wakuMessage.ContentTopic != "") && (contentTopic != "") && (wakuMessage.ContentTopic != contentTopic) {
|
|
||||||
rlnRelay.log.Debug("content topic did not match", zap.String("contentTopic", contentTopic))
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// validate the message
|
// validate the message
|
||||||
validationRes, err := rlnRelay.ValidateMessage(wakuMessage, nil)
|
validationRes, err := rlnRelay.ValidateMessage(wakuMessage, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -320,20 +287,17 @@ func (rlnRelay *WakuRLNRelay) addValidator(
|
|||||||
switch validationRes {
|
switch validationRes {
|
||||||
case validMessage:
|
case validMessage:
|
||||||
rlnRelay.log.Debug("message verified",
|
rlnRelay.log.Debug("message verified",
|
||||||
zap.String("pubsubTopic", pubsubTopic),
|
zap.String("id", hex.EncodeToString([]byte(message.ID))),
|
||||||
zap.String("id", hex.EncodeToString(wakuMessage.Hash(pubsubTopic))),
|
|
||||||
)
|
)
|
||||||
return true
|
return true
|
||||||
case invalidMessage:
|
case invalidMessage:
|
||||||
rlnRelay.log.Debug("message could not be verified",
|
rlnRelay.log.Debug("message could not be verified",
|
||||||
zap.String("pubsubTopic", pubsubTopic),
|
zap.String("id", hex.EncodeToString([]byte(message.ID))),
|
||||||
zap.String("id", hex.EncodeToString(wakuMessage.Hash(pubsubTopic))),
|
|
||||||
)
|
)
|
||||||
return false
|
return false
|
||||||
case spamMessage:
|
case spamMessage:
|
||||||
rlnRelay.log.Debug("spam message found",
|
rlnRelay.log.Debug("spam message found",
|
||||||
zap.String("pubsubTopic", pubsubTopic),
|
zap.String("id", hex.EncodeToString([]byte(message.ID))),
|
||||||
zap.String("id", hex.EncodeToString(wakuMessage.Hash(pubsubTopic))),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
if spamHandler != nil {
|
if spamHandler != nil {
|
||||||
@ -348,11 +312,6 @@ func (rlnRelay *WakuRLNRelay) addValidator(
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// In case there's a topic validator registered
|
|
||||||
_ = relay.PubSub().UnregisterTopicValidator(pubsubTopic)
|
|
||||||
|
|
||||||
return relay.PubSub().RegisterTopicValidator(pubsubTopic, validator)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (rlnRelay *WakuRLNRelay) generateProof(input []byte, epoch rln.Epoch) (*pb.RateLimitProof, error) {
|
func (rlnRelay *WakuRLNRelay) generateProof(input []byte, epoch rln.Epoch) (*pb.RateLimitProof, error) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user