2023-09-12 15:14:08 -04:00
|
|
|
//go:build !gowaku_no_rln
|
|
|
|
// +build !gowaku_no_rln
|
2022-08-12 08:44:13 -04:00
|
|
|
|
|
|
|
package node
|
|
|
|
|
|
|
|
import (
|
2023-04-03 17:45:19 -04:00
|
|
|
"bytes"
|
2023-01-06 18:37:57 -04:00
|
|
|
"context"
|
2022-08-12 08:44:13 -04:00
|
|
|
"errors"
|
2023-08-18 09:59:37 -04:00
|
|
|
|
2022-11-09 15:53:01 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln"
|
2023-09-07 23:23:48 +07:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager"
|
2023-04-04 17:02:12 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/dynamic"
|
2023-04-03 17:45:19 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/group_manager/static"
|
2023-08-23 16:50:25 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/rln/keystore"
|
2022-10-27 11:23:20 -04:00
|
|
|
r "github.com/waku-org/go-zerokit-rln/rln"
|
2022-08-12 08:44:13 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// RLNRelay is used to access any operation related to Waku RLN protocol
|
|
|
|
func (w *WakuNode) RLNRelay() RLNRelay {
|
|
|
|
return w.rlnRelay
|
|
|
|
}
|
|
|
|
|
2024-01-24 11:31:21 +01:00
|
|
|
func (w *WakuNode) setupRLNRelay() (error, *r.RLN, *dynamic.DynamicGroupManager) {
|
2023-04-04 17:02:12 -04:00
|
|
|
var err error
|
|
|
|
|
2023-08-24 10:25:17 -04:00
|
|
|
if !w.opts.enableRLN {
|
2024-01-24 11:31:21 +01:00
|
|
|
return nil, nil, nil
|
2023-08-24 10:25:17 -04:00
|
|
|
}
|
|
|
|
|
2023-09-07 17:39:10 -04:00
|
|
|
if !w.opts.enableRelay {
|
2024-01-24 11:31:21 +01:00
|
|
|
return errors.New("rln requires relay"), nil, nil
|
2023-09-07 17:39:10 -04:00
|
|
|
}
|
|
|
|
|
2023-09-07 23:23:48 +07:00
|
|
|
var groupManager group_manager.GroupManager
|
|
|
|
|
|
|
|
rlnInstance, rootTracker, err := rln.GetRLNInstanceAndRootTracker(w.opts.rlnTreePath)
|
|
|
|
if err != nil {
|
2024-01-24 11:31:21 +01:00
|
|
|
return err, nil, nil
|
2023-09-07 23:23:48 +07:00
|
|
|
}
|
2022-08-12 08:44:13 -04:00
|
|
|
if !w.opts.rlnRelayDynamic {
|
|
|
|
w.log.Info("setting up waku-rln-relay in off-chain mode")
|
2023-04-04 17:02:12 -04:00
|
|
|
|
2023-09-04 17:44:41 -04:00
|
|
|
index := uint(0)
|
|
|
|
if w.opts.rlnRelayMemIndex != nil {
|
|
|
|
index = *w.opts.rlnRelayMemIndex
|
|
|
|
}
|
|
|
|
|
2022-08-12 08:44:13 -04:00
|
|
|
// set up rln relay inputs
|
2023-09-04 17:44:41 -04:00
|
|
|
groupKeys, idCredential, err := static.Setup(index)
|
2022-08-12 08:44:13 -04:00
|
|
|
if err != nil {
|
2024-01-24 11:31:21 +01:00
|
|
|
return err, nil, nil
|
2022-08-12 08:44:13 -04:00
|
|
|
}
|
|
|
|
|
2023-09-04 17:44:41 -04:00
|
|
|
groupManager, err = static.NewStaticGroupManager(groupKeys, idCredential, index, rlnInstance, rootTracker, w.log)
|
2023-04-03 17:45:19 -04:00
|
|
|
if err != nil {
|
2024-01-24 11:31:21 +01:00
|
|
|
return err, nil, nil
|
2023-04-03 17:45:19 -04:00
|
|
|
}
|
2023-04-04 17:02:12 -04:00
|
|
|
} else {
|
|
|
|
w.log.Info("setting up waku-rln-relay in on-chain mode")
|
2023-04-03 17:45:19 -04:00
|
|
|
|
2023-09-14 17:24:34 -04:00
|
|
|
var appKeystore *keystore.AppKeystore
|
|
|
|
if w.opts.keystorePath != "" {
|
|
|
|
appKeystore, err = keystore.New(w.opts.keystorePath, dynamic.RLNAppInfo, w.log)
|
|
|
|
if err != nil {
|
2024-01-24 11:31:21 +01:00
|
|
|
return err, nil, nil
|
2023-09-14 17:24:34 -04:00
|
|
|
}
|
2023-08-23 16:50:25 -04:00
|
|
|
}
|
|
|
|
|
2023-04-04 17:02:12 -04:00
|
|
|
groupManager, err = dynamic.NewDynamicGroupManager(
|
|
|
|
w.opts.rlnETHClientAddress,
|
|
|
|
w.opts.rlnMembershipContractAddress,
|
2023-07-27 15:51:31 -04:00
|
|
|
w.opts.rlnRelayMemIndex,
|
2023-08-23 16:50:25 -04:00
|
|
|
appKeystore,
|
2023-04-05 15:44:46 -04:00
|
|
|
w.opts.keystorePassword,
|
2023-08-22 15:30:04 -04:00
|
|
|
w.opts.prometheusReg,
|
2023-09-07 23:23:48 +07:00
|
|
|
rlnInstance,
|
|
|
|
rootTracker,
|
2023-04-04 17:02:12 -04:00
|
|
|
w.log,
|
|
|
|
)
|
2022-08-12 08:44:13 -04:00
|
|
|
if err != nil {
|
2024-01-24 11:31:21 +01:00
|
|
|
return err, nil, nil
|
2022-08-12 08:44:13 -04:00
|
|
|
}
|
2023-04-04 17:02:12 -04:00
|
|
|
}
|
|
|
|
|
2023-09-07 23:23:48 +07:00
|
|
|
rlnRelay := rln.New(group_manager.Details{
|
|
|
|
GroupManager: groupManager,
|
|
|
|
RootTracker: rootTracker,
|
|
|
|
RLN: rlnInstance,
|
|
|
|
}, w.timesource, w.opts.prometheusReg, w.log)
|
2022-08-12 08:44:13 -04:00
|
|
|
|
2023-08-21 16:54:13 -04:00
|
|
|
w.rlnRelay = rlnRelay
|
|
|
|
|
2023-09-07 17:39:10 -04:00
|
|
|
w.Relay().RegisterDefaultValidator(w.rlnRelay.Validator(w.opts.rlnSpamHandler))
|
2023-08-21 16:54:13 -04:00
|
|
|
|
2024-01-24 11:31:21 +01:00
|
|
|
return nil, rlnInstance, groupManager.(*dynamic.DynamicGroupManager)
|
2023-08-21 16:54:13 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (w *WakuNode) startRlnRelay(ctx context.Context) error {
|
|
|
|
rlnRelay := w.rlnRelay.(*rln.WakuRLNRelay)
|
|
|
|
|
|
|
|
err := rlnRelay.Start(ctx)
|
2023-04-04 17:02:12 -04:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-08-12 08:44:13 -04:00
|
|
|
|
2023-04-04 17:02:12 -04:00
|
|
|
if !w.opts.rlnRelayDynamic {
|
2022-08-12 08:44:13 -04:00
|
|
|
// 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
|
|
|
|
root, err := rlnRelay.RLN.GetMerkleRoot()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-04-04 11:44:28 -04:00
|
|
|
expectedRoot, err := r.ToBytes32LE(r.STATIC_GROUP_MERKLE_ROOT)
|
2023-04-03 17:45:19 -04:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if !bytes.Equal(expectedRoot[:], root[:]) {
|
2022-08-12 08:44:13 -04:00
|
|
|
return errors.New("root mismatch: something went wrong not in Merkle tree construction")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-21 16:54:13 -04:00
|
|
|
w.log.Info("mounted waku RLN relay")
|
2022-08-12 08:44:13 -04:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2022-08-18 12:27:10 -04:00
|
|
|
|
|
|
|
func (w *WakuNode) stopRlnRelay() error {
|
2022-08-26 22:01:26 -04:00
|
|
|
if w.rlnRelay != nil {
|
2023-08-18 09:59:37 -04:00
|
|
|
return w.rlnRelay.Stop()
|
2022-08-26 22:01:26 -04:00
|
|
|
}
|
2022-08-18 12:27:10 -04:00
|
|
|
return nil
|
|
|
|
}
|