2022-04-28 05:42:14 +00:00
|
|
|
package ethconsensusconfig
|
|
|
|
|
|
|
|
import (
|
2022-08-16 12:16:16 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv"
|
2022-04-28 05:42:14 +00:00
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"github.com/davecgh/go-spew/spew"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/aura"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/aura/consensusconfig"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/bor"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/clique"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/db"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/ethash"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/parlia"
|
|
|
|
"github.com/ledgerwatch/erigon/consensus/serenity"
|
|
|
|
"github.com/ledgerwatch/erigon/params"
|
2022-04-29 06:10:31 +00:00
|
|
|
"github.com/ledgerwatch/erigon/turbo/snapshotsync"
|
2022-04-28 05:42:14 +00:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
)
|
|
|
|
|
2022-08-16 12:16:16 +00:00
|
|
|
func CreateConsensusEngine(chainConfig *params.ChainConfig, logger log.Logger, config interface{}, notify []string, noverify bool, HeimdallURL string, WithoutHeimdall bool, datadir string, snapshots *snapshotsync.RoSnapshots, readonly bool, chainDb ...kv.RwDB) consensus.Engine {
|
2022-04-28 05:42:14 +00:00
|
|
|
var eng consensus.Engine
|
|
|
|
|
|
|
|
switch consensusCfg := config.(type) {
|
|
|
|
case *ethash.Config:
|
|
|
|
switch consensusCfg.PowMode {
|
|
|
|
case ethash.ModeFake:
|
|
|
|
log.Warn("Ethash used in fake mode")
|
|
|
|
eng = ethash.NewFaker()
|
|
|
|
case ethash.ModeTest:
|
|
|
|
log.Warn("Ethash used in test mode")
|
|
|
|
eng = ethash.NewTester(nil, noverify)
|
|
|
|
case ethash.ModeShared:
|
|
|
|
log.Warn("Ethash used in shared mode")
|
|
|
|
eng = ethash.NewShared()
|
|
|
|
default:
|
|
|
|
eng = ethash.New(ethash.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 {
|
2022-07-31 20:54:23 +00:00
|
|
|
eng = clique.New(chainConfig, consensusCfg, db.OpenDatabase(consensusCfg.DBPath, logger, consensusCfg.InMemory, readonly))
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
|
|
|
case *params.AuRaConfig:
|
|
|
|
if chainConfig.Aura != nil {
|
|
|
|
var err error
|
2022-07-31 20:54:23 +00:00
|
|
|
eng, err = aura.NewAuRa(chainConfig.Aura, db.OpenDatabase(consensusCfg.DBPath, logger, consensusCfg.InMemory, readonly), chainConfig.Aura.Etherbase, consensusconfig.GetConfigByChain(chainConfig.ChainName))
|
2022-04-28 05:42:14 +00:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case *params.ParliaConfig:
|
|
|
|
if chainConfig.Parlia != nil {
|
2022-08-16 12:16:16 +00:00
|
|
|
eng = parlia.New(chainConfig, db.OpenDatabase(consensusCfg.DBPath, logger, consensusCfg.InMemory, readonly), snapshots, chainDb[0])
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
|
|
|
case *params.BorConfig:
|
|
|
|
if chainConfig.Bor != nil {
|
|
|
|
borDbPath := filepath.Join(datadir, "bor") // bor consensus path: datadir/bor
|
2022-07-31 20:54:23 +00:00
|
|
|
eng = bor.New(chainConfig, db.OpenDatabase(borDbPath, logger, false, readonly), HeimdallURL, WithoutHeimdall)
|
2022-04-28 05:42:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if eng == nil {
|
|
|
|
panic("unknown config" + spew.Sdump(config))
|
|
|
|
}
|
|
|
|
|
|
|
|
if chainConfig.TerminalTotalDifficulty == nil {
|
|
|
|
return eng
|
|
|
|
} else {
|
|
|
|
return serenity.New(eng) // the Merge
|
|
|
|
}
|
|
|
|
}
|