mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-19 00:04:12 +00:00
ac06362baf
* Add a helper for max request block * Add test * Use deneb fork epoch from config * Fix comment
71 lines
4.8 KiB
Go
71 lines
4.8 KiB
Go
package params
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/mohae/deepcopy"
|
|
"github.com/prysmaticlabs/prysm/v4/consensus-types/primitives"
|
|
)
|
|
|
|
// NetworkConfig defines the spec based network parameters.
|
|
type NetworkConfig struct {
|
|
GossipMaxSize uint64 `yaml:"GOSSIP_MAX_SIZE"` // GossipMaxSize is the maximum allowed size of uncompressed gossip messages.
|
|
GossipMaxSizeBellatrix uint64 `yaml:"GOSSIP_MAX_SIZE_BELLATRIX"` // GossipMaxSizeBellatrix is the maximum allowed size of uncompressed gossip messages after the bellatrix epoch.
|
|
MaxChunkSize uint64 `yaml:"MAX_CHUNK_SIZE"` // MaxChunkSize is the maximum allowed size of uncompressed req/resp chunked responses.
|
|
MaxChunkSizeBellatrix uint64 `yaml:"MAX_CHUNK_SIZE_BELLATRIX"` // MaxChunkSizeBellatrix is the maximum allowed size of uncompressed req/resp chunked responses after the bellatrix epoch.
|
|
AttestationSubnetCount uint64 `yaml:"ATTESTATION_SUBNET_COUNT"` // AttestationSubnetCount is the number of attestation subnets used in the gossipsub protocol.
|
|
AttestationPropagationSlotRange primitives.Slot `yaml:"ATTESTATION_PROPAGATION_SLOT_RANGE"` // AttestationPropagationSlotRange is the maximum number of slots during which an attestation can be propagated.
|
|
MaxRequestBlocks uint64 `yaml:"MAX_REQUEST_BLOCKS"` // MaxRequestBlocks is the maximum number of blocks in a single request.
|
|
TtfbTimeout time.Duration `yaml:"TTFB_TIMEOUT"` // TtfbTimeout is the maximum time to wait for first byte of request response (time-to-first-byte).
|
|
RespTimeout time.Duration `yaml:"RESP_TIMEOUT"` // RespTimeout is the maximum time for complete response transfer.
|
|
MaximumGossipClockDisparity time.Duration `yaml:"MAXIMUM_GOSSIP_CLOCK_DISPARITY"` // MaximumGossipClockDisparity is the maximum milliseconds of clock disparity assumed between honest nodes.
|
|
MessageDomainInvalidSnappy [4]byte `yaml:"MESSAGE_DOMAIN_INVALID_SNAPPY"` // MessageDomainInvalidSnappy is the 4-byte domain for gossip message-id isolation of invalid snappy messages.
|
|
MessageDomainValidSnappy [4]byte `yaml:"MESSAGE_DOMAIN_VALID_SNAPPY"` // MessageDomainValidSnappy is the 4-byte domain for gossip message-id isolation of valid snappy messages.
|
|
MinEpochsForBlobsSidecarsRequest primitives.Epoch `yaml:"MIN_EPOCHS_FOR_BLOBS_SIDECARS_REQUEST"` // MinEpochsForBlobsSidecarsRequest is the minimum number of epochs the node will keep the blobs for.
|
|
MaxRequestBlobSidecars uint64 `yaml:"MAX_REQUEST_BLOB_SIDECARS"` // MaxRequestBlobSidecars is the maximum number of blobs to request in a single request.
|
|
MaxRequestBlocksDeneb uint64 `yaml:"MAX_REQUEST_BLOCKS_DENEB"` // MaxRequestBlocksDeneb is the maximum number of blocks in a single request after the deneb epoch.
|
|
|
|
// DiscoveryV5 Config
|
|
ETH2Key string // ETH2Key is the ENR key of the Ethereum consensus object in an enr.
|
|
AttSubnetKey string // AttSubnetKey is the ENR key of the subnet bitfield in the enr.
|
|
SyncCommsSubnetKey string // SyncCommsSubnetKey is the ENR key of the sync committee subnet bitfield in the enr.
|
|
MinimumPeersInSubnetSearch uint64 // PeersInSubnetSearch is the required amount of peers that we need to be able to lookup in a subnet search.
|
|
|
|
// Chain Network Config
|
|
ContractDeploymentBlock uint64 // ContractDeploymentBlock is the eth1 block in which the deposit contract is deployed.
|
|
BootstrapNodes []string // BootstrapNodes are the addresses of the bootnodes.
|
|
}
|
|
|
|
var networkConfig = mainnetNetworkConfig
|
|
|
|
// BeaconNetworkConfig returns the current network config for
|
|
// the beacon chain.
|
|
func BeaconNetworkConfig() *NetworkConfig {
|
|
return networkConfig
|
|
}
|
|
|
|
// OverrideBeaconNetworkConfig will override the network
|
|
// config with the added argument.
|
|
func OverrideBeaconNetworkConfig(cfg *NetworkConfig) {
|
|
networkConfig = cfg.Copy()
|
|
}
|
|
|
|
// Copy returns Copy of the config object.
|
|
func (c *NetworkConfig) Copy() *NetworkConfig {
|
|
config, ok := deepcopy.Copy(*c).(NetworkConfig)
|
|
if !ok {
|
|
config = *networkConfig
|
|
}
|
|
return &config
|
|
}
|
|
|
|
// MaxRequestBlock determines the maximum number of blocks that can be requested in a single
|
|
// request for a given epoch. If the epoch is at or beyond config's `DenebForkEpoch`,
|
|
// a special limit defined for Deneb is used.
|
|
func MaxRequestBlock(e primitives.Epoch) uint64 {
|
|
if e >= BeaconConfig().DenebForkEpoch {
|
|
return networkConfig.MaxRequestBlocksDeneb
|
|
}
|
|
return networkConfig.MaxRequestBlocks
|
|
}
|