mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-14 15:54:20 +00:00
feat(rln-relay): use atomic operations API
This commit is contained in:
parent
da45dab68e
commit
c320b38cbe
@ -28,7 +28,7 @@
|
|||||||
];
|
];
|
||||||
doCheck = false;
|
doCheck = false;
|
||||||
# FIXME: This needs to be manually changed when updating modules.
|
# FIXME: This needs to be manually changed when updating modules.
|
||||||
vendorSha256 = "sha256-cMjGBz4/sDRcE55cfPBTl1lFkvHfZHeM4bTBcs5lO2s=";
|
vendorSha256 = "sha256-8khocBcz0klKwhoYKoPOvMSwFwa8rFcFSRM9jL8A0BU=";
|
||||||
# Fix for 'nix run' trying to execute 'go-waku'.
|
# Fix for 'nix run' trying to execute 'go-waku'.
|
||||||
meta = { mainProgram = "waku"; };
|
meta = { mainProgram = "waku"; };
|
||||||
};
|
};
|
||||||
|
2
go.mod
2
go.mod
@ -39,7 +39,7 @@ require (
|
|||||||
github.com/jackc/pgx/v5 v5.4.1
|
github.com/jackc/pgx/v5 v5.4.1
|
||||||
github.com/waku-org/go-libp2p-rendezvous v0.0.0-20230628220917-7b4e5ae4c0e7
|
github.com/waku-org/go-libp2p-rendezvous v0.0.0-20230628220917-7b4e5ae4c0e7
|
||||||
github.com/waku-org/go-noise v0.0.4
|
github.com/waku-org/go-noise v0.0.4
|
||||||
github.com/waku-org/go-zerokit-rln v0.1.13-0.20230803113701-ea89e5d7eedb
|
github.com/waku-org/go-zerokit-rln v0.1.13
|
||||||
github.com/wk8/go-ordered-map v1.0.0
|
github.com/wk8/go-ordered-map v1.0.0
|
||||||
)
|
)
|
||||||
|
|
||||||
|
4
go.sum
4
go.sum
@ -1554,8 +1554,8 @@ github.com/waku-org/go-libp2p-rendezvous v0.0.0-20230628220917-7b4e5ae4c0e7 h1:0
|
|||||||
github.com/waku-org/go-libp2p-rendezvous v0.0.0-20230628220917-7b4e5ae4c0e7/go.mod h1:pFvOZ9YTFsW0o5zJW7a0B5tr1owAijRWJctXJ2toL04=
|
github.com/waku-org/go-libp2p-rendezvous v0.0.0-20230628220917-7b4e5ae4c0e7/go.mod h1:pFvOZ9YTFsW0o5zJW7a0B5tr1owAijRWJctXJ2toL04=
|
||||||
github.com/waku-org/go-noise v0.0.4 h1:ZfQDcCw8pazm89EBl5SXY7GGAnzDQb9AHFXlw3Ktbvk=
|
github.com/waku-org/go-noise v0.0.4 h1:ZfQDcCw8pazm89EBl5SXY7GGAnzDQb9AHFXlw3Ktbvk=
|
||||||
github.com/waku-org/go-noise v0.0.4/go.mod h1:+PWRfs2eSOVwKrPcQlfhwDngSh3faL/1QoxvoqggEKc=
|
github.com/waku-org/go-noise v0.0.4/go.mod h1:+PWRfs2eSOVwKrPcQlfhwDngSh3faL/1QoxvoqggEKc=
|
||||||
github.com/waku-org/go-zerokit-rln v0.1.13-0.20230803113701-ea89e5d7eedb h1:f1UbFvroZbAul1HTlzM4ZGgjQ3mtn0bW8Jvk7XZQ5V4=
|
github.com/waku-org/go-zerokit-rln v0.1.13 h1:9Ti/my7dmpJGNxNpL1MvVurzAjSd6xwBOm2WUZi33Mo=
|
||||||
github.com/waku-org/go-zerokit-rln v0.1.13-0.20230803113701-ea89e5d7eedb/go.mod h1:1S6g1KXC45HkDXhIWD9+mdAs9fdyzQy8gtmw4RLjVcM=
|
github.com/waku-org/go-zerokit-rln v0.1.13/go.mod h1:1S6g1KXC45HkDXhIWD9+mdAs9fdyzQy8gtmw4RLjVcM=
|
||||||
github.com/waku-org/go-zerokit-rln-apple v0.0.0-20230803113401-9a7ef94d120e h1:Ad0rJod5F1FuYCJ8SUB/bQZsQwirNHQRE0IcaVloxZo=
|
github.com/waku-org/go-zerokit-rln-apple v0.0.0-20230803113401-9a7ef94d120e h1:Ad0rJod5F1FuYCJ8SUB/bQZsQwirNHQRE0IcaVloxZo=
|
||||||
github.com/waku-org/go-zerokit-rln-apple v0.0.0-20230803113401-9a7ef94d120e/go.mod h1:KYykqtdApHVYZ3G0spwMnoxc5jH5eI3jyO9SwsSfi48=
|
github.com/waku-org/go-zerokit-rln-apple v0.0.0-20230803113401-9a7ef94d120e/go.mod h1:KYykqtdApHVYZ3G0spwMnoxc5jH5eI3jyO9SwsSfi48=
|
||||||
github.com/waku-org/go-zerokit-rln-arm v0.0.0-20230801152407-8101ff87ee0a h1:10cre+P76QvnLeyeCVAM8WDbUCri/y5xY3LtwI9Y5DE=
|
github.com/waku-org/go-zerokit-rln-arm v0.0.0-20230801152407-8101ff87ee0a h1:10cre+P76QvnLeyeCVAM8WDbUCri/y5xY3LtwI9Y5DE=
|
||||||
|
@ -66,12 +66,12 @@ func handler(gm *DynamicGroupManager, events []*contracts.RLNMemberRegistered) e
|
|||||||
toInsertTable := om.New()
|
toInsertTable := om.New()
|
||||||
for _, event := range events {
|
for _, event := range events {
|
||||||
if event.Raw.Removed {
|
if event.Raw.Removed {
|
||||||
var indexes []uint64
|
var indexes []uint
|
||||||
i_idx, ok := toRemoveTable.Get(event.Raw.BlockNumber)
|
i_idx, ok := toRemoveTable.Get(event.Raw.BlockNumber)
|
||||||
if ok {
|
if ok {
|
||||||
indexes = i_idx.([]uint64)
|
indexes = i_idx.([]uint)
|
||||||
}
|
}
|
||||||
indexes = append(indexes, event.Index.Uint64())
|
indexes = append(indexes, uint(event.Index.Uint64()))
|
||||||
toRemoveTable.Set(event.Raw.BlockNumber, indexes)
|
toRemoveTable.Set(event.Raw.BlockNumber, indexes)
|
||||||
} else {
|
} else {
|
||||||
var eventsPerBlock []*contracts.RLNMemberRegistered
|
var eventsPerBlock []*contracts.RLNMemberRegistered
|
||||||
@ -278,17 +278,28 @@ func (gm *DynamicGroupManager) persistCredentials() error {
|
|||||||
func (gm *DynamicGroupManager) InsertMembers(toInsert *om.OrderedMap) error {
|
func (gm *DynamicGroupManager) InsertMembers(toInsert *om.OrderedMap) error {
|
||||||
for pair := toInsert.Oldest(); pair != nil; pair = pair.Next() {
|
for pair := toInsert.Oldest(); pair != nil; pair = pair.Next() {
|
||||||
events := pair.Value.([]*contracts.RLNMemberRegistered) // TODO: should these be sortered by index? we assume all members arrive in order
|
events := pair.Value.([]*contracts.RLNMemberRegistered) // TODO: should these be sortered by index? we assume all members arrive in order
|
||||||
|
var idCommitments []rln.IDCommitment
|
||||||
|
var oldestIndexInBlock *big.Int
|
||||||
for _, evt := range events {
|
for _, evt := range events {
|
||||||
pubkey := rln.Bytes32(evt.Pubkey.Bytes())
|
if oldestIndexInBlock == nil {
|
||||||
// TODO: should we track indexes to identify missing?
|
oldestIndexInBlock = evt.Index
|
||||||
err := gm.rln.InsertMember(pubkey)
|
|
||||||
if err != nil {
|
|
||||||
gm.log.Error("inserting member into merkletree", zap.Error(err))
|
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
|
idCommitments = append(idCommitments, rln.Bytes32(evt.Pubkey.Bytes()))
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := gm.rootTracker.UpdateLatestRoot(pair.Key.(uint64))
|
if len(idCommitments) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: should we track indexes to identify missing?
|
||||||
|
startIndex := rln.MembershipIndex(uint(oldestIndexInBlock.Int64()))
|
||||||
|
err := gm.rln.InsertMembers(startIndex, idCommitments)
|
||||||
|
if err != nil {
|
||||||
|
gm.log.Error("inserting members into merkletree", zap.Error(err))
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = gm.rootTracker.UpdateLatestRoot(pair.Key.(uint64))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -298,13 +309,11 @@ func (gm *DynamicGroupManager) InsertMembers(toInsert *om.OrderedMap) error {
|
|||||||
|
|
||||||
func (gm *DynamicGroupManager) RemoveMembers(toRemove *om.OrderedMap) error {
|
func (gm *DynamicGroupManager) RemoveMembers(toRemove *om.OrderedMap) error {
|
||||||
for pair := toRemove.Newest(); pair != nil; pair = pair.Prev() {
|
for pair := toRemove.Newest(); pair != nil; pair = pair.Prev() {
|
||||||
memberIndexes := pair.Value.([]uint64)
|
memberIndexes := pair.Value.([]uint)
|
||||||
for _, index := range memberIndexes {
|
err := gm.rln.DeleteMembers(memberIndexes)
|
||||||
err := gm.rln.DeleteMember(uint(index))
|
if err != nil {
|
||||||
if err != nil {
|
gm.log.Error("deleting members", zap.Error(err))
|
||||||
gm.log.Error("deleting member", zap.Error(err))
|
return err
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
gm.rootTracker.Backfill(pair.Key.(uint64))
|
gm.rootTracker.Backfill(pair.Key.(uint64))
|
||||||
}
|
}
|
||||||
|
@ -59,8 +59,8 @@ func TestHandler(t *testing.T) {
|
|||||||
roots = gm.rootTracker.Roots()
|
roots = gm.rootTracker.Roots()
|
||||||
|
|
||||||
require.Len(t, roots, 2)
|
require.Len(t, roots, 2)
|
||||||
require.Equal(t, roots[0], root0)
|
require.Equal(t, root0, roots[0])
|
||||||
require.Equal(t, roots[1], [32]byte{253, 232, 31, 10, 168, 25, 42, 0, 28, 221, 146, 119, 34, 212, 121, 51, 82, 55, 113, 181, 236, 3, 11, 190, 194, 144, 125, 59, 46, 171, 90, 43})
|
require.Equal(t, [32]byte{0x96, 0x65, 0xdb, 0xbc, 0x28, 0x6b, 0x1f, 0xc6, 0xab, 0x2d, 0x82, 0xe, 0x30, 0xe0, 0xc1, 0x92, 0x32, 0x73, 0xd2, 0xd6, 0xe1, 0x21, 0xef, 0xa1, 0xc8, 0xa6, 0xa6, 0xd, 0x9, 0x7c, 0x85, 0x19}, roots[1])
|
||||||
|
|
||||||
events = []*contracts.RLNMemberRegistered{
|
events = []*contracts.RLNMemberRegistered{
|
||||||
eventBuilder(1, false, 0xbbbb, 2),
|
eventBuilder(1, false, 0xbbbb, 2),
|
||||||
@ -75,9 +75,9 @@ func TestHandler(t *testing.T) {
|
|||||||
// Root[1] should become [0]
|
// Root[1] should become [0]
|
||||||
roots = gm.rootTracker.Roots()
|
roots = gm.rootTracker.Roots()
|
||||||
require.Len(t, roots, 5)
|
require.Len(t, roots, 5)
|
||||||
require.Equal(t, roots[0], [32]byte{253, 232, 31, 10, 168, 25, 42, 0, 28, 221, 146, 119, 34, 212, 121, 51, 82, 55, 113, 181, 236, 3, 11, 190, 194, 144, 125, 59, 46, 171, 90, 43})
|
require.Equal(t, [32]byte{0x96, 0x65, 0xdb, 0xbc, 0x28, 0x6b, 0x1f, 0xc6, 0xab, 0x2d, 0x82, 0xe, 0x30, 0xe0, 0xc1, 0x92, 0x32, 0x73, 0xd2, 0xd6, 0xe1, 0x21, 0xef, 0xa1, 0xc8, 0xa6, 0xa6, 0xd, 0x9, 0x7c, 0x85, 0x19}, roots[0])
|
||||||
require.Len(t, rootTracker.Buffer(), 1)
|
require.Len(t, rootTracker.Buffer(), 1)
|
||||||
require.Equal(t, rootTracker.Buffer()[0], [32]byte{62, 31, 25, 34, 223, 182, 113, 211, 249, 18, 247, 234, 70, 30, 10, 136, 238, 132, 143, 221, 225, 43, 108, 24, 171, 26, 210, 197, 106, 231, 52, 33})
|
require.Equal(t, root0, rootTracker.Buffer()[0])
|
||||||
|
|
||||||
// We detect a fork
|
// We detect a fork
|
||||||
//
|
//
|
||||||
|
@ -18,6 +18,7 @@ type StaticGroupManager struct {
|
|||||||
|
|
||||||
group []rln.IDCommitment
|
group []rln.IDCommitment
|
||||||
rootTracker *group_manager.MerkleRootTracker
|
rootTracker *group_manager.MerkleRootTracker
|
||||||
|
nextIndex uint64
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewStaticGroupManager(
|
func NewStaticGroupManager(
|
||||||
@ -46,11 +47,10 @@ func (gm *StaticGroupManager) Start(ctx context.Context, rlnInstance *rln.RLN, r
|
|||||||
gm.rootTracker = rootTracker
|
gm.rootTracker = rootTracker
|
||||||
|
|
||||||
// add members to the Merkle tree
|
// add members to the Merkle tree
|
||||||
for i, member := range gm.group {
|
|
||||||
err := gm.insertMember(member, uint64(i+1))
|
err := gm.insertMembers(gm.group)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gm.group = nil // Deleting group to release memory
|
gm.group = nil // Deleting group to release memory
|
||||||
@ -58,21 +58,22 @@ func (gm *StaticGroupManager) Start(ctx context.Context, rlnInstance *rln.RLN, r
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (gm *StaticGroupManager) insertMember(pubkey rln.IDCommitment, index uint64) error {
|
func (gm *StaticGroupManager) insertMembers(idCommitments []rln.IDCommitment) error {
|
||||||
gm.log.Debug("a new key is added", zap.Binary("pubkey", pubkey[:]), zap.Uint64("index", index))
|
err := gm.rln.InsertMembers(rln.MembershipIndex(gm.nextIndex), idCommitments)
|
||||||
|
|
||||||
// assuming all the members arrive in order
|
|
||||||
err := gm.rln.InsertMember(pubkey)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
gm.log.Error("inserting member into merkletree", zap.Error(err))
|
gm.log.Error("inserting members into merkletree", zap.Error(err))
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = gm.rootTracker.UpdateLatestRoot(index)
|
latestIndex := gm.nextIndex + uint64(len(idCommitments))
|
||||||
|
|
||||||
|
_, err = gm.rootTracker.UpdateLatestRoot(latestIndex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gm.nextIndex = latestIndex + 1
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user