2022-04-28 05:42:14 +00:00
|
|
|
package ethconsensusconfig
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"github.com/davecgh/go-spew/spew"
|
2023-01-13 18:12:18 +00:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
|
2023-04-14 06:24:10 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/chain"
|
|
|
|
|
2022-04-28 05:42:14 +00:00
|
|
|
"github.com/ledgerwatch/erigon/consensus"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/aura"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor"
|
2023-01-31 08:30:57 +00:00
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor/contract"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor/heimdall"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor/heimdall/span"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor/heimdallgrpc"
|
2022-04-28 05:42:14 +00:00
|
|
|
"github.com/ledgerwatch/erigon/consensus/clique"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/db"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/ethash"
|
2023-04-14 06:24:10 +00:00
|
|
|
"github.com/ledgerwatch/erigon/consensus/ethash/ethashcfg"
|
2023-05-09 17:45:33 +00:00
|
|
|
"github.com/ledgerwatch/erigon/consensus/merge"
|
2022-04-28 05:42:14 +00:00
|
|
|
"github.com/ledgerwatch/erigon/params"
|
|
|
|
)
|
|
|
|
|
2023-05-09 15:19:23 +00:00
|
|
|
func CreateConsensusEngine(chainConfig *chain.Config, config interface{}, notify []string, noVerify bool,
|
|
|
|
heimdallGrpcAddress string, heimdallUrl string, withoutHeimdall bool, dataDir string, readonly bool,
|
2023-05-13 20:22:30 +00:00
|
|
|
logger log.Logger,
|
2023-05-09 15:19:23 +00:00
|
|
|
) consensus.Engine {
|
2022-04-28 05:42:14 +00:00
|
|
|
var eng consensus.Engine
|
|
|
|
|
|
|
|
switch consensusCfg := config.(type) {
|
2023-03-29 07:27:06 +00:00
|
|
|
case *ethashcfg.Config:
|
2022-04-28 05:42:14 +00:00
|
|
|
switch consensusCfg.PowMode {
|
2023-03-29 07:27:06 +00:00
|
|
|
case ethashcfg.ModeFake:
|
2023-05-13 20:22:30 +00:00
|
|
|
logger.Warn("Ethash used in fake mode")
|
2022-04-28 05:42:14 +00:00
|
|
|
eng = ethash.NewFaker()
|
2023-03-29 07:27:06 +00:00
|
|
|
case ethashcfg.ModeTest:
|
2023-05-13 20:22:30 +00:00
|
|
|
logger.Warn("Ethash used in test mode")
|
2023-05-09 15:19:23 +00:00
|
|
|
eng = ethash.NewTester(nil, noVerify)
|
2023-03-29 07:27:06 +00:00
|
|
|
case ethashcfg.ModeShared:
|
2023-05-13 20:22:30 +00:00
|
|
|
logger.Warn("Ethash used in shared mode")
|
2022-04-28 05:42:14 +00:00
|
|
|
eng = ethash.NewShared()
|
|
|
|
default:
|
2023-03-29 07:27:06 +00:00
|
|
|
eng = ethash.New(ethashcfg.Config{
|
2022-04-28 05:42:14 +00:00
|
|
|
CachesInMem: consensusCfg.CachesInMem,
|
|
|
|
CachesLockMmap: consensusCfg.CachesLockMmap,
|
|
|
|
DatasetDir: consensusCfg.DatasetDir,
|
|
|
|
DatasetsInMem: consensusCfg.DatasetsInMem,
|
|
|
|
DatasetsOnDisk: consensusCfg.DatasetsOnDisk,
|
|
|
|
DatasetsLockMmap: consensusCfg.DatasetsLockMmap,
|
2023-05-09 15:19:23 +00:00
|
|
|
}, notify, noVerify)
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
|
|
|
case *params.ConsensusSnapshotConfig:
|
|
|
|
if chainConfig.Clique != nil {
|
2023-01-03 05:20:18 +00:00
|
|
|
if consensusCfg.DBPath == "" {
|
2023-05-09 15:19:23 +00:00
|
|
|
consensusCfg.DBPath = filepath.Join(dataDir, "clique", "db")
|
2023-01-03 05:20:18 +00:00
|
|
|
}
|
2023-05-16 09:53:50 +00:00
|
|
|
eng = clique.New(chainConfig, consensusCfg, db.OpenDatabase(consensusCfg.DBPath, consensusCfg.InMemory, readonly), logger)
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
2023-01-13 18:12:18 +00:00
|
|
|
case *chain.AuRaConfig:
|
2022-04-28 05:42:14 +00:00
|
|
|
if chainConfig.Aura != nil {
|
2023-05-09 15:19:23 +00:00
|
|
|
dbPath := filepath.Join(dataDir, "aura")
|
2022-04-28 05:42:14 +00:00
|
|
|
var err error
|
2023-04-14 07:51:25 +00:00
|
|
|
eng, err = aura.NewAuRa(chainConfig.Aura, db.OpenDatabase(dbPath, false, readonly))
|
2022-04-28 05:42:14 +00:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|
2023-01-13 18:12:18 +00:00
|
|
|
case *chain.BorConfig:
|
2023-01-31 08:30:57 +00:00
|
|
|
// 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 != "" {
|
2023-05-13 20:22:30 +00:00
|
|
|
genesisContractsClient := contract.NewGenesisContractsClient(chainConfig, chainConfig.Bor.ValidatorContract, chainConfig.Bor.StateReceiverContract, logger)
|
|
|
|
spanner := span.NewChainSpanner(contract.ValidatorSet(), chainConfig, logger)
|
2023-05-09 15:19:23 +00:00
|
|
|
borDbPath := filepath.Join(dataDir, "bor") // bor consensus path: datadir/bor
|
2023-04-07 21:08:44 +00:00
|
|
|
db := db.OpenDatabase(borDbPath, false, readonly)
|
2023-01-31 08:30:57 +00:00
|
|
|
|
|
|
|
var heimdallClient bor.IHeimdallClient
|
2023-05-09 15:19:23 +00:00
|
|
|
if withoutHeimdall {
|
2023-05-13 20:22:30 +00:00
|
|
|
return bor.New(chainConfig, db, spanner, nil, genesisContractsClient, logger)
|
2023-01-31 08:30:57 +00:00
|
|
|
} else {
|
2023-05-09 15:19:23 +00:00
|
|
|
if heimdallGrpcAddress != "" {
|
|
|
|
heimdallClient = heimdallgrpc.NewHeimdallGRPCClient(heimdallGrpcAddress)
|
2023-01-31 08:30:57 +00:00
|
|
|
} else {
|
2023-05-09 15:19:23 +00:00
|
|
|
heimdallClient = heimdall.NewHeimdallClient(heimdallUrl)
|
2023-01-31 08:30:57 +00:00
|
|
|
}
|
2023-05-13 20:22:30 +00:00
|
|
|
eng = bor.New(chainConfig, db, spanner, heimdallClient, genesisContractsClient, logger)
|
2023-01-31 08:30:57 +00:00
|
|
|
}
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if eng == nil {
|
|
|
|
panic("unknown config" + spew.Sdump(config))
|
|
|
|
}
|
|
|
|
|
|
|
|
if chainConfig.TerminalTotalDifficulty == nil {
|
|
|
|
return eng
|
|
|
|
} else {
|
2023-05-09 17:45:33 +00:00
|
|
|
return merge.New(eng) // the Merge
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
|
|
|
}
|
2023-05-09 15:19:23 +00:00
|
|
|
|
2023-05-13 20:22:30 +00:00
|
|
|
func CreateConsensusEngineBareBones(chainConfig *chain.Config, logger log.Logger) consensus.Engine {
|
2023-05-09 15:19:23 +00:00
|
|
|
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(chainConfig, consensusConfig, nil /* notify */, true, /* noVerify */
|
2023-05-13 20:22:30 +00:00
|
|
|
"" /* heimdallGrpcAddress */, "" /* heimdallUrl */, true /* withoutHeimdall */, "" /*dataDir*/, false /* readonly */, logger)
|
2023-05-09 15:19:23 +00:00
|
|
|
}
|