2021-02-01 19:00:06 +00:00
|
|
|
package params
|
|
|
|
|
2022-03-21 19:43:41 +00:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
fieldparams "github.com/prysmaticlabs/prysm/config/fieldparams"
|
2022-04-29 14:32:11 +00:00
|
|
|
types "github.com/prysmaticlabs/prysm/consensus-types/primitives"
|
2022-03-21 19:43:41 +00:00
|
|
|
)
|
|
|
|
|
2021-02-01 19:00:06 +00:00
|
|
|
const (
|
2021-03-18 21:00:00 +00:00
|
|
|
Mainnet ConfigName = iota
|
2021-08-09 18:40:06 +00:00
|
|
|
Minimal
|
2021-02-01 19:00:06 +00:00
|
|
|
EndToEnd
|
2021-03-17 14:14:07 +00:00
|
|
|
Prater
|
2022-03-21 19:43:41 +00:00
|
|
|
EndToEndMainnet
|
2021-02-01 19:00:06 +00:00
|
|
|
)
|
|
|
|
|
2022-03-21 19:43:41 +00:00
|
|
|
// ConfigName enum describes the type of known network in use.
|
|
|
|
type ConfigName int
|
|
|
|
|
|
|
|
func (n ConfigName) String() string {
|
|
|
|
s, ok := ConfigNames[n]
|
|
|
|
if !ok {
|
|
|
|
return "undefined"
|
|
|
|
}
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
2021-02-01 19:00:06 +00:00
|
|
|
// ConfigNames provides network configuration names.
|
2021-03-18 21:00:00 +00:00
|
|
|
var ConfigNames = map[ConfigName]string{
|
2022-03-21 19:43:41 +00:00
|
|
|
Mainnet: "mainnet",
|
|
|
|
Minimal: "minimal",
|
|
|
|
EndToEnd: "end-to-end",
|
|
|
|
Prater: "prater",
|
|
|
|
EndToEndMainnet: "end-to-end-mainnet",
|
2021-02-01 19:00:06 +00:00
|
|
|
}
|
|
|
|
|
2022-03-21 19:43:41 +00:00
|
|
|
// KnownConfigs provides an index of all known BeaconChainConfig values.
|
|
|
|
var KnownConfigs = map[ConfigName]func() *BeaconChainConfig{
|
|
|
|
Mainnet: MainnetConfig,
|
|
|
|
Prater: PraterConfig,
|
|
|
|
Minimal: MinimalSpecConfig,
|
|
|
|
EndToEnd: E2ETestConfig,
|
|
|
|
EndToEndMainnet: E2EMainnetTestConfig,
|
|
|
|
}
|
|
|
|
|
|
|
|
var knownForkVersions map[[fieldparams.VersionLength]byte]ConfigName
|
|
|
|
|
|
|
|
var errUnknownForkVersion = errors.New("version not found in fork version schedule for any known config")
|
|
|
|
|
|
|
|
// ConfigForVersion find the BeaconChainConfig corresponding to the version bytes.
|
|
|
|
// Version bytes for BeaconChainConfig values in KnownConfigs are proven to be unique during package initialization.
|
|
|
|
func ConfigForVersion(version [fieldparams.VersionLength]byte) (*BeaconChainConfig, error) {
|
|
|
|
cfg, ok := knownForkVersions[version]
|
|
|
|
if !ok {
|
|
|
|
return nil, errors.Wrapf(errUnknownForkVersion, "version=%#x", version)
|
|
|
|
}
|
|
|
|
return KnownConfigs[cfg](), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
knownForkVersions = make(map[[fieldparams.VersionLength]byte]ConfigName)
|
|
|
|
for n, cfunc := range KnownConfigs {
|
|
|
|
cfg := cfunc()
|
|
|
|
// ensure that fork schedule is consistent w/ struct fields for all known configurations
|
|
|
|
if err := equalForkSchedules(configForkSchedule(cfg), cfg.ForkVersionSchedule); err != nil {
|
|
|
|
panic(errors.Wrapf(err, "improperly initialized for schedule for config %s", n.String()))
|
|
|
|
}
|
|
|
|
// ensure that all fork versions are unique
|
|
|
|
for v := range cfg.ForkVersionSchedule {
|
|
|
|
pn, exists := knownForkVersions[v]
|
|
|
|
if exists {
|
|
|
|
previous := KnownConfigs[pn]()
|
|
|
|
msg := fmt.Sprintf("version %#x is duplicated in 2 configs, %s at epoch %d, %s at epoch %d",
|
|
|
|
v, pn, previous.ForkVersionSchedule[v], n, cfg.ForkVersionSchedule[v])
|
|
|
|
panic(msg)
|
|
|
|
}
|
|
|
|
knownForkVersions[v] = n
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func equalForkSchedules(a, b map[[fieldparams.VersionLength]byte]types.Epoch) error {
|
|
|
|
if len(a) != len(b) {
|
|
|
|
return fmt.Errorf("different lengths, a=%d, b=%d", len(a), len(b))
|
|
|
|
}
|
|
|
|
for k, v := range a {
|
|
|
|
bv, ok := b[k]
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("fork version %#x from 'a', not present in 'b'", k)
|
|
|
|
}
|
|
|
|
if v != bv {
|
|
|
|
return fmt.Errorf("fork version mismatch, epoch in a=%d, b=%d", v, bv)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|