package ethconsensusconfig import ( "path/filepath" "github.com/davecgh/go-spew/spew" "github.com/ledgerwatch/log/v3" "github.com/ledgerwatch/erigon-lib/chain" "github.com/ledgerwatch/erigon-lib/kv" "github.com/ledgerwatch/erigon/consensus" "github.com/ledgerwatch/erigon/consensus/aura" "github.com/ledgerwatch/erigon/consensus/bor" "github.com/ledgerwatch/erigon/consensus/bor/contract" "github.com/ledgerwatch/erigon/consensus/bor/heimdall/span" "github.com/ledgerwatch/erigon/consensus/clique" "github.com/ledgerwatch/erigon/consensus/ethash" "github.com/ledgerwatch/erigon/consensus/ethash/ethashcfg" "github.com/ledgerwatch/erigon/consensus/merge" "github.com/ledgerwatch/erigon/node" "github.com/ledgerwatch/erigon/node/nodecfg" "github.com/ledgerwatch/erigon/params" "github.com/ledgerwatch/erigon/turbo/services" ) func CreateConsensusEngine(nodeConfig *nodecfg.Config, chainConfig *chain.Config, config interface{}, notify []string, noVerify bool, heimdallClient bor.IHeimdallClient, withoutHeimdall bool, blockReader services.FullBlockReader, readonly bool, logger log.Logger, ) consensus.Engine { var eng consensus.Engine switch consensusCfg := config.(type) { case *ethashcfg.Config: switch consensusCfg.PowMode { case ethashcfg.ModeFake: logger.Warn("Ethash used in fake mode") eng = ethash.NewFaker() case ethashcfg.ModeTest: logger.Warn("Ethash used in test mode") eng = ethash.NewTester(nil, noVerify) case ethashcfg.ModeShared: logger.Warn("Ethash used in shared mode") eng = ethash.NewShared() default: eng = ethash.New(ethashcfg.Config{ CachesInMem: consensusCfg.CachesInMem, CachesLockMmap: consensusCfg.CachesLockMmap, DatasetDir: consensusCfg.DatasetDir, DatasetsInMem: consensusCfg.DatasetsInMem, DatasetsOnDisk: consensusCfg.DatasetsOnDisk, DatasetsLockMmap: consensusCfg.DatasetsLockMmap, }, notify, noVerify) } case *params.ConsensusSnapshotConfig: if chainConfig.Clique != nil { if consensusCfg.InMemory { nodeConfig.Dirs.DataDir = "" } else { if consensusCfg.DBPath != "" { if filepath.Base(consensusCfg.DBPath) == "clique" { nodeConfig.Dirs.DataDir = filepath.Dir(consensusCfg.DBPath) } else { nodeConfig.Dirs.DataDir = consensusCfg.DBPath } } } var err error var db kv.RwDB db, err = node.OpenDatabase(nodeConfig, kv.ConsensusDB, "clique", readonly, logger) if err != nil { panic(err) } eng = clique.New(chainConfig, consensusCfg, db, logger) } case *chain.AuRaConfig: if chainConfig.Aura != nil { var err error var db kv.RwDB db, err = node.OpenDatabase(nodeConfig, kv.ConsensusDB, "aura", readonly, logger) if err != nil { panic(err) } eng, err = aura.NewAuRa(chainConfig.Aura, db) if err != nil { panic(err) } } case *chain.BorConfig: // If Matic bor consensus is requested, set it up // In order to pass the ethereum transaction tests, we need to set the burn contract which is in the bor config // Then, bor != nil will also be enabled for ethash and clique. Only enable Bor for real if there is a validator contract present. if chainConfig.Bor != nil && chainConfig.Bor.ValidatorContract != "" { genesisContractsClient := contract.NewGenesisContractsClient(chainConfig, chainConfig.Bor.ValidatorContract, chainConfig.Bor.StateReceiverContract, logger) spanner := span.NewChainSpanner(contract.ValidatorSet(), chainConfig, withoutHeimdall, logger) var err error var db kv.RwDB db, err = node.OpenDatabase(nodeConfig, kv.ConsensusDB, "bor", readonly, logger) if err != nil { panic(err) } eng = bor.New(chainConfig, db, blockReader, spanner, heimdallClient, genesisContractsClient, logger) } } if eng == nil { panic("unknown config" + spew.Sdump(config)) } if chainConfig.TerminalTotalDifficulty == nil { return eng } else { return merge.New(eng) // the Merge } } func CreateConsensusEngineBareBones(chainConfig *chain.Config, logger log.Logger) consensus.Engine { var consensusConfig interface{} if chainConfig.Clique != nil { consensusConfig = params.CliqueSnapshot } else if chainConfig.Aura != nil { consensusConfig = &chainConfig.Aura } else if chainConfig.Bor != nil { consensusConfig = &chainConfig.Bor } else { var ethashCfg ethashcfg.Config ethashCfg.PowMode = ethashcfg.ModeFake consensusConfig = ðashCfg } return CreateConsensusEngine(&nodecfg.Config{}, chainConfig, consensusConfig, nil /* notify */, true, /* noVerify */ nil /* heimdallClient */, true /* withoutHeimdall */, nil /* blockReader */, false /* readonly */, logger) }