mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
fa3b8c23b2
migration included - no manual actions required
168 lines
4.9 KiB
Go
168 lines
4.9 KiB
Go
package helper
|
|
|
|
import (
|
|
"context"
|
|
"crypto/ecdsa"
|
|
"encoding/json"
|
|
"math/big"
|
|
"os"
|
|
"time"
|
|
|
|
"github.com/c2h5oh/datasize"
|
|
"github.com/ledgerwatch/erigon-lib/common/datadir"
|
|
"github.com/ledgerwatch/erigon-lib/direct"
|
|
"github.com/ledgerwatch/erigon-lib/downloader/downloadercfg"
|
|
"github.com/ledgerwatch/erigon-lib/txpool/txpoolcfg"
|
|
"github.com/ledgerwatch/erigon/cmd/utils"
|
|
"github.com/ledgerwatch/erigon/core/types"
|
|
"github.com/ledgerwatch/erigon/crypto"
|
|
"github.com/ledgerwatch/erigon/eth"
|
|
"github.com/ledgerwatch/erigon/eth/ethconfig"
|
|
"github.com/ledgerwatch/erigon/node"
|
|
"github.com/ledgerwatch/erigon/node/nodecfg"
|
|
"github.com/ledgerwatch/erigon/p2p"
|
|
"github.com/ledgerwatch/erigon/p2p/nat"
|
|
"github.com/ledgerwatch/erigon/params"
|
|
"github.com/ledgerwatch/log/v3"
|
|
)
|
|
|
|
// InitGenesis initializes genesis file from json with sprint size and chain name as configurable inputs
|
|
func InitGenesis(fileLocation string, sprintSize uint64, chainName string) types.Genesis {
|
|
|
|
// sprint size = 8 in genesis
|
|
genesisData, err := os.ReadFile(fileLocation)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
genesis := &types.Genesis{}
|
|
|
|
if err := json.Unmarshal(genesisData, genesis); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
genesis.Config.Bor.Sprint["0"] = sprintSize
|
|
genesis.Config.ChainName = chainName
|
|
|
|
return *genesis
|
|
}
|
|
|
|
func NewEthConfig() *ethconfig.Config {
|
|
ethConfig := ðconfig.Defaults
|
|
return ethConfig
|
|
}
|
|
|
|
func NewNodeConfig() *nodecfg.Config {
|
|
nodeConfig := nodecfg.DefaultConfig
|
|
// see simiar changes in `cmd/geth/config.go#defaultNodeConfig`
|
|
if commit := params.GitCommit; commit != "" {
|
|
nodeConfig.Version = params.VersionWithCommit(commit)
|
|
} else {
|
|
nodeConfig.Version = params.Version
|
|
}
|
|
nodeConfig.IPCPath = "" // force-disable IPC endpoint
|
|
nodeConfig.Name = "erigon"
|
|
return &nodeConfig
|
|
}
|
|
|
|
// InitNode initializes a node with the given genesis file and config
|
|
func InitMiner(genesis *types.Genesis, privKey *ecdsa.PrivateKey, withoutHeimdall bool, minerID int) (*node.Node, *eth.Ethereum, error) {
|
|
// Define the basic configurations for the Ethereum node
|
|
ddir, _ := os.MkdirTemp("", "")
|
|
|
|
logger := log.New()
|
|
|
|
nodeCfg := &nodecfg.Config{
|
|
Name: "erigon",
|
|
Version: params.Version,
|
|
Dirs: datadir.New(ddir),
|
|
P2P: p2p.Config{
|
|
ListenAddr: ":30303",
|
|
ProtocolVersion: []uint{direct.ETH68, direct.ETH67}, // No need to specify direct.ETH66, because 1 sentry is used for both 66 and 67
|
|
MaxPeers: 100,
|
|
MaxPendingPeers: 1000,
|
|
AllowedPorts: []uint{30303, 30304, 30305, 30306, 30307, 30308, 30309, 30310},
|
|
PrivateKey: privKey,
|
|
NAT: nat.Any(),
|
|
},
|
|
|
|
// These are set to prevent disk and page size churn which can be excessive
|
|
// when running multiple nodes
|
|
// MdbxGrowthStep impacts disk usage, MdbxDBSizeLimit impacts page file usage
|
|
MdbxGrowthStep: 4 * datasize.MB,
|
|
MdbxDBSizeLimit: 64 * datasize.MB,
|
|
}
|
|
|
|
stack, err := node.New(context.Background(), nodeCfg, logger)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
downloadRate, err := datasize.ParseString("16mb")
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
uploadRate, err := datasize.ParseString("4mb")
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
torrentLogLevel, _, err := downloadercfg.Int2LogLevel(3)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
downloaderConfig, err := downloadercfg.New(datadir.New(ddir), nodeCfg.Version, torrentLogLevel, downloadRate, uploadRate, utils.TorrentPortFlag.Value, utils.TorrentConnsPerFileFlag.Value, utils.TorrentDownloadSlotsFlag.Value, []string{}, "")
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
ethCfg := ðconfig.Config{
|
|
Dirs: datadir.New(ddir),
|
|
Genesis: genesis,
|
|
NetworkID: genesis.Config.ChainID.Uint64(),
|
|
TxPool: txpoolcfg.DefaultConfig,
|
|
GPO: ethconfig.Defaults.GPO,
|
|
Miner: params.MiningConfig{
|
|
Etherbase: crypto.PubkeyToAddress(privKey.PublicKey),
|
|
GasLimit: genesis.GasLimit,
|
|
GasPrice: big.NewInt(1),
|
|
Recommit: 125 * time.Second,
|
|
SigKey: privKey,
|
|
Enabled: true,
|
|
EnabledPOS: true,
|
|
},
|
|
Sync: ethconfig.Defaults.Sync,
|
|
Downloader: downloaderConfig,
|
|
WithoutHeimdall: withoutHeimdall,
|
|
ImportMode: ethconfig.Defaults.ImportMode,
|
|
|
|
DeprecatedTxPool: ethconfig.Defaults.DeprecatedTxPool,
|
|
RPCGasCap: 50000000,
|
|
RPCTxFeeCap: 1, // 1 ether
|
|
Snapshot: ethconfig.BlocksFreezing{NoDownloader: true},
|
|
P2PEnabled: true,
|
|
StateStream: true,
|
|
}
|
|
ethCfg.TxPool.DBDir = nodeCfg.Dirs.TxPool
|
|
ethCfg.DeprecatedTxPool.CommitEvery = 15 * time.Second
|
|
ethCfg.DeprecatedTxPool.StartOnInit = true
|
|
ethCfg.Downloader.ClientConfig.ListenPort = utils.TorrentPortFlag.Value + minerID
|
|
ethCfg.TxPool.AccountSlots = 1000000
|
|
ethCfg.DeprecatedTxPool.AccountSlots = 1000000
|
|
ethCfg.DeprecatedTxPool.GlobalSlots = 1000000
|
|
|
|
ethBackend, err := eth.New(stack, ethCfg, logger)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
err = ethBackend.Init(stack, ethCfg)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
return stack, ethBackend, err
|
|
}
|