mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-09 20:41:20 +00:00
29ff8daa92
addressing some aspects of the req/resp portion of the CL spec: https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/p2p-interface.md#reqresp-interaction. this PR does a few things: 1. moves `blocksByRangeHandler` and `beaconBlocksByRootHandler` handlers to a different file in the `handlers` package. these are going to be the more complicated handlers so they will be better in their own files. 2. makes `pingHandler` a method on the `*ConsensusHandlers` receiver and starts returning the sequence number instead of the request. (see https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/p2p-interface.md#ping `Peers request and respond with their local metadata sequence number`). 3. adds a `goodbyeHandler` to respond with a status message of 1. (see https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/p2p-interface.md#goodbye). 4. makes `statusHandler` a method on the `*ConsensusHandlers` receiver. (the rest of this handler is still not implemented. 5. refactored the `heartbeats_test` into a table driven test. this makes the test much more readable: https://dave.cheney.net/2019/05/07/prefer-table-driven-tests.
56 lines
2.2 KiB
Go
56 lines
2.2 KiB
Go
/*
|
|
Copyright 2022 Erigon-Lightclient contributors
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package handlers
|
|
|
|
import (
|
|
"github.com/ledgerwatch/erigon/cmd/lightclient/cltypes"
|
|
"github.com/ledgerwatch/erigon/cmd/lightclient/sentinel/communication"
|
|
)
|
|
|
|
// Type safe handlers which all have access to the original stream & decompressed data.
|
|
// Since packets are just structs, they can be resent with no issue
|
|
|
|
func (c *ConsensusHandlers) pingHandler(ctx *communication.StreamContext, _ *communication.EmptyPacket) error {
|
|
return ctx.Codec.WritePacket(&cltypes.Ping{
|
|
Id: c.metadata.SeqNumber,
|
|
}, SuccessfulResponsePrefix)
|
|
}
|
|
|
|
func (c *ConsensusHandlers) goodbyeHandler(ctx *communication.StreamContext, _ *communication.EmptyPacket) error {
|
|
// From the spec, these are the valid goodbye numbers. Start with just
|
|
// sending 1, but we should think about when the others need to be sent.
|
|
// 1: Client shut down.
|
|
// 2: Irrelevant network.
|
|
// 3: Fault/error.
|
|
return ctx.Codec.WritePacket(&cltypes.Ping{
|
|
Id: 1,
|
|
}, SuccessfulResponsePrefix)
|
|
}
|
|
|
|
func (c *ConsensusHandlers) metadataV1Handler(ctx *communication.StreamContext, _ *communication.EmptyPacket) error {
|
|
return ctx.Codec.WritePacket(&cltypes.MetadataV1{
|
|
SeqNumber: c.metadata.SeqNumber,
|
|
Attnets: c.metadata.Attnets,
|
|
}, SuccessfulResponsePrefix)
|
|
}
|
|
|
|
func (c *ConsensusHandlers) metadataV2Handler(ctx *communication.StreamContext, _ *communication.EmptyPacket) error {
|
|
return ctx.Codec.WritePacket(c.metadata, SuccessfulResponsePrefix)
|
|
}
|
|
|
|
// TODO: Actually respond with proper status
|
|
func (c *ConsensusHandlers) statusHandler(ctx *communication.StreamContext, dat *cltypes.Status) error {
|
|
return ctx.Codec.WritePacket(dat, SuccessfulResponsePrefix)
|
|
}
|