From 132db6881b68d3d3ba0feeeba097002668e34e68 Mon Sep 17 00:00:00 2001 From: rauljordan Date: Mon, 13 Apr 2020 18:56:16 -0500 Subject: [PATCH 1/4] address all comments --- beacon-chain/core/helpers/slot_epoch.go | 2 +- beacon-chain/node/node.go | 1 - beacon-chain/p2p/BUILD.bazel | 1 - beacon-chain/p2p/config.go | 2 - beacon-chain/p2p/discovery_test.go | 1 - beacon-chain/p2p/fork_test.go | 2 - beacon-chain/p2p/service.go | 22 ++------- beacon-chain/p2p/service_test.go | 2 - beacon-chain/p2p/subnets_test.go | 1 - beacon-chain/sync/subscriber_handlers.go | 16 +++--- ...th_go_binary_serialization_alloc_fix.patch | 49 ------------------- 11 files changed, 15 insertions(+), 84 deletions(-) delete mode 100644 third_party/herumi/bls_eth_go_binary_serialization_alloc_fix.patch diff --git a/beacon-chain/core/helpers/slot_epoch.go b/beacon-chain/core/helpers/slot_epoch.go index 1f69af56a255..47c2034c3204 100644 --- a/beacon-chain/core/helpers/slot_epoch.go +++ b/beacon-chain/core/helpers/slot_epoch.go @@ -90,7 +90,7 @@ func SlotsSinceEpochStarts(slot uint64) uint64 { } // TimeShiftTolerance specifies the tolerance threshold for slots "from the future". -const TimeShiftTolerance = 500 * time.Millisecond // ms +const TimeShiftTolerance = 10 * time.Millisecond // ms // VerifySlotTime validates the input slot is not from the future. func VerifySlotTime(genesisTime uint64, slot uint64, timeTolerance time.Duration) error { diff --git a/beacon-chain/node/node.go b/beacon-chain/node/node.go index cc879627f178..4709b9699686 100644 --- a/beacon-chain/node/node.go +++ b/beacon-chain/node/node.go @@ -289,7 +289,6 @@ func (b *BeaconNode) registerP2P(ctx *cli.Context) error { } svc, err := p2p.NewService(&p2p.Config{ - BeaconDB: b.db, NoDiscovery: ctx.Bool(cmd.NoDiscovery.Name), StaticPeers: sliceutil.SplitCommaSeparated(ctx.StringSlice(cmd.StaticPeers.Name)), BootstrapNodeAddr: bootnodeAddrs, diff --git a/beacon-chain/p2p/BUILD.bazel b/beacon-chain/p2p/BUILD.bazel index b0c2c8d0c8c4..5b15a220513f 100644 --- a/beacon-chain/p2p/BUILD.bazel +++ b/beacon-chain/p2p/BUILD.bazel @@ -35,7 +35,6 @@ go_library( "//beacon-chain/core/feed:go_default_library", "//beacon-chain/core/feed/state:go_default_library", "//beacon-chain/core/helpers:go_default_library", - "//beacon-chain/db:go_default_library", "//beacon-chain/p2p/connmgr:go_default_library", "//beacon-chain/p2p/encoder:go_default_library", "//beacon-chain/p2p/peers:go_default_library", diff --git a/beacon-chain/p2p/config.go b/beacon-chain/p2p/config.go index f6c3f88b227d..c325b6e68f52 100644 --- a/beacon-chain/p2p/config.go +++ b/beacon-chain/p2p/config.go @@ -2,13 +2,11 @@ package p2p import ( statefeed "github.com/prysmaticlabs/prysm/beacon-chain/core/feed/state" - "github.com/prysmaticlabs/prysm/beacon-chain/db" ) // Config for the p2p service. These parameters are set from application level flags // to initialize the p2p service. type Config struct { - BeaconDB db.ReadOnlyDatabase NoDiscovery bool EnableUPnP bool DisableDiscv5 bool diff --git a/beacon-chain/p2p/discovery_test.go b/beacon-chain/p2p/discovery_test.go index 8f6605ee9912..053beec25262 100644 --- a/beacon-chain/p2p/discovery_test.go +++ b/beacon-chain/p2p/discovery_test.go @@ -184,7 +184,6 @@ func TestStaticPeering_PeersAreAdded(t *testing.T) { cfg.TCPPort = 14500 cfg.UDPPort = 14501 cfg.StaticPeers = staticPeers - cfg.BeaconDB = db cfg.StateNotifier = &mock.MockStateNotifier{} s, err := NewService(cfg) if err != nil { diff --git a/beacon-chain/p2p/fork_test.go b/beacon-chain/p2p/fork_test.go index 8fb291d94c1b..dc4846773d67 100644 --- a/beacon-chain/p2p/fork_test.go +++ b/beacon-chain/p2p/fork_test.go @@ -87,7 +87,6 @@ func TestStartDiscv5_DifferentForkDigests(t *testing.T) { // bootnode given all nodes provided by discv5 will have different fork digests. cfg.UDPPort = 14000 cfg.TCPPort = 14001 - cfg.BeaconDB = db s, err := NewService(cfg) if err != nil { t.Fatal(err) @@ -176,7 +175,6 @@ func TestStartDiscv5_SameForkDigests_DifferentNextForkData(t *testing.T) { // bootnode given all nodes provided by discv5 will have different fork digests. cfg.UDPPort = 14000 cfg.TCPPort = 14001 - cfg.BeaconDB = db params.OverrideBeaconConfig(originalBeaconConfig) s, err := NewService(cfg) if err != nil { diff --git a/beacon-chain/p2p/service.go b/beacon-chain/p2p/service.go index 77948b6e97b0..1b2d8348f8a7 100644 --- a/beacon-chain/p2p/service.go +++ b/beacon-chain/p2p/service.go @@ -26,19 +26,19 @@ import ( ma "github.com/multiformats/go-multiaddr" "github.com/pkg/errors" "github.com/prysmaticlabs/go-bitfield" + pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1" + "github.com/sirupsen/logrus" + "github.com/prysmaticlabs/prysm/beacon-chain/cache" "github.com/prysmaticlabs/prysm/beacon-chain/core/feed" statefeed "github.com/prysmaticlabs/prysm/beacon-chain/core/feed/state" "github.com/prysmaticlabs/prysm/beacon-chain/core/helpers" - "github.com/prysmaticlabs/prysm/beacon-chain/db" "github.com/prysmaticlabs/prysm/beacon-chain/p2p/encoder" "github.com/prysmaticlabs/prysm/beacon-chain/p2p/peers" - pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1" "github.com/prysmaticlabs/prysm/shared" "github.com/prysmaticlabs/prysm/shared/params" "github.com/prysmaticlabs/prysm/shared/runutil" "github.com/prysmaticlabs/prysm/shared/sliceutil" - "github.com/sirupsen/logrus" ) var _ = shared.Service(&Service{}) @@ -70,7 +70,6 @@ type Service struct { exclusionList *ristretto.Cache metaData *pb.MetaData pubsub *pubsub.PubSub - beaconDB db.ReadOnlyDatabase dv5Listener Listener startupErr error stateNotifier statefeed.Notifier @@ -95,7 +94,6 @@ func NewService(cfg *Config) (*Service, error) { } s := &Service{ - beaconDB: cfg.BeaconDB, ctx: ctx, stateNotifier: cfg.StateNotifier, cancel: cancel, @@ -176,18 +174,8 @@ func (s *Service) Start() { } // Waits until the state is initialized via an event feed. - // Check if we have a genesis time / genesis state - // used for fork-related data when connecting peers. - genesisState, err := s.beaconDB.GenesisState(s.ctx) - if err != nil { - log.WithError(err).Error("Could not read genesis state") - } - if genesisState != nil { - s.genesisTime = time.Unix(int64(genesisState.GenesisTime()), 0) - s.genesisValidatorsRoot = genesisState.GenesisValidatorRoot() - } else { - s.awaitStateInitialized() - } + // Used for fork-related data when connecting peers. + s.awaitStateInitialized() s.isPreGenesis = false var peersToWatch []string diff --git a/beacon-chain/p2p/service_test.go b/beacon-chain/p2p/service_test.go index d3ca30e7ec1f..e20e63f64e66 100644 --- a/beacon-chain/p2p/service_test.go +++ b/beacon-chain/p2p/service_test.go @@ -99,7 +99,6 @@ func TestService_Start_OnlyStartsOnce(t *testing.T) { TCPPort: 2000, UDPPort: 2000, Encoding: "ssz", - BeaconDB: db, } s, err := NewService(cfg) if err != nil { @@ -211,7 +210,6 @@ func TestListenForNewNodes(t *testing.T) { cfg.UDPPort = 14000 cfg.TCPPort = 14001 - cfg.BeaconDB = db s, err := NewService(cfg) if err != nil { diff --git a/beacon-chain/p2p/subnets_test.go b/beacon-chain/p2p/subnets_test.go index 205238a6b5e6..ca3236de72d9 100644 --- a/beacon-chain/p2p/subnets_test.go +++ b/beacon-chain/p2p/subnets_test.go @@ -75,7 +75,6 @@ func TestStartDiscV5_DiscoverPeersWithSubnets(t *testing.T) { // Make one service on port 3001. port = 4000 cfg := &Config{ - BeaconDB: db, BootstrapNodeAddr: []string{bootNode.String()}, Discv5BootStrapAddr: []string{bootNode.String()}, Encoding: "ssz", diff --git a/beacon-chain/sync/subscriber_handlers.go b/beacon-chain/sync/subscriber_handlers.go index 55600994b014..6bf5c596d5db 100644 --- a/beacon-chain/sync/subscriber_handlers.go +++ b/beacon-chain/sync/subscriber_handlers.go @@ -2,10 +2,10 @@ package sync import ( "context" - "errors" "fmt" "github.com/gogo/protobuf/proto" + "github.com/pkg/errors" ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1" "github.com/prysmaticlabs/go-ssz" "github.com/prysmaticlabs/prysm/shared/bytesutil" @@ -37,8 +37,6 @@ func (r *Service) attesterSlashingSubscriber(ctx context.Context, msg proto.Mess } // Do some nil checks to prevent easy DoS'ing of this handler. if as != nil && as.Attestation_1 != nil && as.Attestation_1.Data != nil { - r.setAttesterSlashingIndicesSeen(as.Attestation_1.AttestingIndices, as.Attestation_2.AttestingIndices) - s, err := r.db.State(ctx, bytesutil.ToBytes32(as.Attestation_1.Data.BeaconBlockRoot)) if err != nil { return err @@ -46,7 +44,10 @@ func (r *Service) attesterSlashingSubscriber(ctx context.Context, msg proto.Mess if s == nil { return fmt.Errorf("no state found for block root %#x", as.Attestation_1.Data.BeaconBlockRoot) } - return r.slashingPool.InsertAttesterSlashing(ctx, s, as) + if err := r.slashingPool.InsertAttesterSlashing(ctx, s, as); err != nil { + return errors.Wrap(err, "could not insert attester slashing into pool") + } + r.setAttesterSlashingIndicesSeen(as.Attestation_1.AttestingIndices, as.Attestation_2.AttestingIndices) } return nil } @@ -58,8 +59,6 @@ func (r *Service) proposerSlashingSubscriber(ctx context.Context, msg proto.Mess } // Do some nil checks to prevent easy DoS'ing of this handler. if ps.Header_1 != nil && ps.Header_1.Header != nil { - r.setProposerSlashingIndexSeen(ps.Header_1.Header.ProposerIndex) - root, err := ssz.HashTreeRoot(ps.Header_1.Header) s, err := r.db.State(ctx, root) if err != nil { @@ -68,7 +67,10 @@ func (r *Service) proposerSlashingSubscriber(ctx context.Context, msg proto.Mess if s == nil { return fmt.Errorf("no state found for block root %#x", root) } - return r.slashingPool.InsertProposerSlashing(ctx, s, ps) + if err := r.slashingPool.InsertProposerSlashing(ctx, s, ps); err != nil { + return errors.Wrap(err, "could not insert proposer slashing into pool") + } + r.setProposerSlashingIndexSeen(ps.Header_1.Header.ProposerIndex) } return nil } diff --git a/third_party/herumi/bls_eth_go_binary_serialization_alloc_fix.patch b/third_party/herumi/bls_eth_go_binary_serialization_alloc_fix.patch deleted file mode 100644 index 202fcdc85469..000000000000 --- a/third_party/herumi/bls_eth_go_binary_serialization_alloc_fix.patch +++ /dev/null @@ -1,49 +0,0 @@ -diff --git a/bls/bls.go b/bls/bls.go -index bc3b607..f6fa95f 100644 ---- a/bls/bls.go -+++ b/bls/bls.go -@@ -157,7 +157,7 @@ type SecretKey struct { - - // Serialize -- - func (sec *SecretKey) Serialize() []byte { -- buf := make([]byte, 2048) -+ buf := make([]byte, 32) - // #nosec - n := C.blsSecretKeySerialize(unsafe.Pointer(&buf[0]), C.mclSize(len(buf)), &sec.v) - if n == 0 { -@@ -354,7 +354,7 @@ func (keys PublicKeys) JSON() string { - - // Serialize -- - func (pub *PublicKey) Serialize() []byte { -- buf := make([]byte, 2048) -+ buf := make([]byte, 48) - // #nosec - n := C.blsPublicKeySerialize(unsafe.Pointer(&buf[0]), C.mclSize(len(buf)), &pub.v) - if n == 0 { -@@ -452,7 +452,7 @@ type Sign struct { - - // Serialize -- - func (sig *Sign) Serialize() []byte { -- buf := make([]byte, 2048) -+ buf := make([]byte, 96) - // #nosec - n := C.blsSignatureSerialize(unsafe.Pointer(&buf[0]), C.mclSize(len(buf)), &sig.v) - if n == 0 { -@@ -665,7 +665,7 @@ func (sig *Sign) VerifyHashWithDomain(pub *PublicKey, hashWithDomain []byte) boo - - // SerializeUncompressed -- - func (pub *PublicKey) SerializeUncompressed() []byte { -- buf := make([]byte, 2048) -+ buf := make([]byte, 96) - // #nosec - n := C.blsPublicKeySerializeUncompressed(unsafe.Pointer(&buf[0]), C.mclSize(len(buf)), &pub.v) - if n == 0 { -@@ -676,7 +676,7 @@ func (pub *PublicKey) SerializeUncompressed() []byte { - - // SerializeUncompressed -- - func (sig *Sign) SerializeUncompressed() []byte { -- buf := make([]byte, 2048) -+ buf := make([]byte, 192) - // #nosec - n := C.blsSignatureSerializeUncompressed(unsafe.Pointer(&buf[0]), C.mclSize(len(buf)), &sig.v) - if n == 0 { From 0441743bb5ad156101bc795d4b211d1f53098b92 Mon Sep 17 00:00:00 2001 From: rauljordan Date: Mon, 13 Apr 2020 19:12:21 -0500 Subject: [PATCH 2/4] set faucet --- tools/faucet/server.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/tools/faucet/server.go b/tools/faucet/server.go index 0470e5a2780f..aed1730b057c 100644 --- a/tools/faucet/server.go +++ b/tools/faucet/server.go @@ -24,7 +24,7 @@ import ( const ipLimit = 5 -var fundingAmount = big.NewInt(32.5 * params.Ether) +var fundingAmount *big.Int var funded = make(map[string]bool) var ipCounter = make(map[string]int) var fundingLock sync.Mutex @@ -38,6 +38,14 @@ type faucetServer struct { minScore float64 } +func init() { + var ok bool + fundingAmount, ok = new(big.Int).SetString("32500000000000000000", 10) + if !ok { + log.Fatal("could not set funding amount") + } +} + func newFaucetServer( r recaptcha.Recaptcha, rpcPath string, From d724c5c002b44c53511cb83c29c6768985743f8a Mon Sep 17 00:00:00 2001 From: rauljordan Date: Mon, 13 Apr 2020 19:13:54 -0500 Subject: [PATCH 3/4] nishant feedback --- beacon-chain/core/helpers/slot_epoch.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/beacon-chain/core/helpers/slot_epoch.go b/beacon-chain/core/helpers/slot_epoch.go index 47c2034c3204..1f69af56a255 100644 --- a/beacon-chain/core/helpers/slot_epoch.go +++ b/beacon-chain/core/helpers/slot_epoch.go @@ -90,7 +90,7 @@ func SlotsSinceEpochStarts(slot uint64) uint64 { } // TimeShiftTolerance specifies the tolerance threshold for slots "from the future". -const TimeShiftTolerance = 10 * time.Millisecond // ms +const TimeShiftTolerance = 500 * time.Millisecond // ms // VerifySlotTime validates the input slot is not from the future. func VerifySlotTime(genesisTime uint64, slot uint64, timeTolerance time.Duration) error { From 54625c5546f79ababe1b9a0a5711bd1893442ad9 Mon Sep 17 00:00:00 2001 From: Raul Jordan Date: Mon, 13 Apr 2020 19:14:20 -0500 Subject: [PATCH 4/4] Update beacon-chain/p2p/service.go --- beacon-chain/p2p/service.go | 1 - 1 file changed, 1 deletion(-) diff --git a/beacon-chain/p2p/service.go b/beacon-chain/p2p/service.go index 1b2d8348f8a7..1578d336a5f3 100644 --- a/beacon-chain/p2p/service.go +++ b/beacon-chain/p2p/service.go @@ -28,7 +28,6 @@ import ( "github.com/prysmaticlabs/go-bitfield" pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1" "github.com/sirupsen/logrus" - "github.com/prysmaticlabs/prysm/beacon-chain/cache" "github.com/prysmaticlabs/prysm/beacon-chain/core/feed" statefeed "github.com/prysmaticlabs/prysm/beacon-chain/core/feed/state"