2022-01-17 12:30:53 +00:00
|
|
|
package validator
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2022-01-18 17:14:38 +00:00
|
|
|
"math/big"
|
2022-05-06 11:21:11 +00:00
|
|
|
"time"
|
2022-01-17 12:30:53 +00:00
|
|
|
|
2022-01-18 17:14:38 +00:00
|
|
|
"github.com/ethereum/go-ethereum/params"
|
2022-06-03 13:28:02 +00:00
|
|
|
"github.com/ethereum/go-ethereum/statediff"
|
2022-05-06 11:21:11 +00:00
|
|
|
"github.com/ethereum/go-ethereum/statediff/indexer/database/sql/postgres"
|
|
|
|
"github.com/jmoiron/sqlx"
|
2022-01-17 12:30:53 +00:00
|
|
|
"github.com/spf13/viper"
|
2022-05-23 13:38:17 +00:00
|
|
|
"github.com/vulcanize/ipld-eth-server/v4/pkg/shared"
|
2022-05-06 11:21:11 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
DATABASE_NAME = "DATABASE_NAME"
|
|
|
|
DATABASE_HOSTNAME = "DATABASE_HOSTNAME"
|
|
|
|
DATABASE_PORT = "DATABASE_PORT"
|
|
|
|
DATABASE_USER = "DATABASE_USER"
|
|
|
|
DATABASE_PASSWORD = "DATABASE_PASSWORD"
|
|
|
|
DATABASE_MAX_IDLE_CONNECTIONS = "DATABASE_MAX_IDLE_CONNECTIONS"
|
|
|
|
DATABASE_MAX_OPEN_CONNECTIONS = "DATABASE_MAX_OPEN_CONNECTIONS"
|
|
|
|
DATABASE_MAX_CONN_LIFETIME = "DATABASE_MAX_CONN_LIFETIME"
|
2022-01-17 12:30:53 +00:00
|
|
|
)
|
|
|
|
|
2022-01-20 13:22:01 +00:00
|
|
|
var IntegrationTestChainConfig = ¶ms.ChainConfig{
|
2022-05-20 11:17:02 +00:00
|
|
|
ChainID: big.NewInt(99),
|
2022-01-20 13:22:01 +00:00
|
|
|
HomesteadBlock: big.NewInt(0),
|
|
|
|
EIP150Block: big.NewInt(0),
|
|
|
|
EIP155Block: big.NewInt(0),
|
|
|
|
EIP158Block: big.NewInt(0),
|
|
|
|
ByzantiumBlock: big.NewInt(0),
|
|
|
|
ConstantinopleBlock: big.NewInt(0),
|
|
|
|
PetersburgBlock: big.NewInt(0),
|
|
|
|
IstanbulBlock: big.NewInt(0),
|
|
|
|
Clique: ¶ms.CliqueConfig{
|
|
|
|
Period: 0,
|
|
|
|
Epoch: 30000,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var TestChainConfig = ¶ms.ChainConfig{
|
2022-01-18 17:38:11 +00:00
|
|
|
ChainID: big.NewInt(1),
|
|
|
|
HomesteadBlock: big.NewInt(0),
|
|
|
|
EIP150Block: big.NewInt(0),
|
|
|
|
EIP155Block: big.NewInt(0),
|
|
|
|
EIP158Block: big.NewInt(0),
|
|
|
|
ByzantiumBlock: big.NewInt(0),
|
|
|
|
ConstantinopleBlock: big.NewInt(0),
|
|
|
|
PetersburgBlock: big.NewInt(0),
|
|
|
|
IstanbulBlock: big.NewInt(0),
|
|
|
|
MuirGlacierBlock: big.NewInt(0),
|
|
|
|
BerlinBlock: big.NewInt(0),
|
2022-01-20 13:22:01 +00:00
|
|
|
LondonBlock: big.NewInt(6),
|
2022-01-18 17:38:11 +00:00
|
|
|
ArrowGlacierBlock: big.NewInt(0),
|
|
|
|
Ethash: new(params.EthashConfig),
|
|
|
|
}
|
2022-01-18 17:14:38 +00:00
|
|
|
|
2022-01-17 12:30:53 +00:00
|
|
|
type Config struct {
|
2022-05-06 11:21:11 +00:00
|
|
|
dbConfig postgres.Config
|
|
|
|
DB *sqlx.DB
|
2022-06-03 13:28:02 +00:00
|
|
|
|
|
|
|
ChainCfg *params.ChainConfig
|
|
|
|
|
|
|
|
BlockNum, Trail uint64
|
|
|
|
SleepInterval uint
|
2022-01-17 12:30:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewConfig() (*Config, error) {
|
|
|
|
cfg := new(Config)
|
2022-06-03 13:28:02 +00:00
|
|
|
err := cfg.setupDB()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg.BlockNum = viper.GetUint64("validate.block-height")
|
|
|
|
if cfg.BlockNum < 1 {
|
|
|
|
return nil, fmt.Errorf("block height cannot be less the 1")
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg.Trail = viper.GetUint64("validate.trail")
|
|
|
|
cfg.SleepInterval = viper.GetUint("validate.sleepInterval")
|
|
|
|
|
|
|
|
chainConfigPath := viper.GetString("ethereum.chainConfig")
|
|
|
|
cfg.ChainCfg, err = statediff.LoadConfig(chainConfigPath)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return cfg, nil
|
2022-01-17 12:30:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Config) setupDB() error {
|
2022-05-06 11:21:11 +00:00
|
|
|
_ = viper.BindEnv("database.name", DATABASE_NAME)
|
|
|
|
_ = viper.BindEnv("database.hostname", DATABASE_HOSTNAME)
|
|
|
|
_ = viper.BindEnv("database.port", DATABASE_PORT)
|
|
|
|
_ = viper.BindEnv("database.user", DATABASE_USER)
|
|
|
|
_ = viper.BindEnv("database.password", DATABASE_PASSWORD)
|
|
|
|
_ = viper.BindEnv("database.maxIdle", DATABASE_MAX_IDLE_CONNECTIONS)
|
|
|
|
_ = viper.BindEnv("database.maxOpen", DATABASE_MAX_OPEN_CONNECTIONS)
|
|
|
|
_ = viper.BindEnv("database.maxLifetime", DATABASE_MAX_CONN_LIFETIME)
|
2022-01-17 12:30:53 +00:00
|
|
|
|
|
|
|
// DB Config
|
2022-05-06 11:21:11 +00:00
|
|
|
c.dbConfig.DatabaseName = viper.GetString("database.name")
|
|
|
|
c.dbConfig.Hostname = viper.GetString("database.hostname")
|
|
|
|
c.dbConfig.Port = viper.GetInt("database.port")
|
|
|
|
c.dbConfig.Username = viper.GetString("database.user")
|
|
|
|
c.dbConfig.Password = viper.GetString("database.password")
|
|
|
|
|
2022-01-17 12:30:53 +00:00
|
|
|
c.dbConfig.MaxIdle = viper.GetInt("database.maxIdle")
|
2022-05-06 11:21:11 +00:00
|
|
|
c.dbConfig.MaxConns = viper.GetInt("database.maxOpen")
|
|
|
|
c.dbConfig.MaxConnLifetime = time.Duration(viper.GetInt("database.maxLifetime"))
|
2022-01-17 12:30:53 +00:00
|
|
|
|
|
|
|
// Create DB
|
2022-05-06 11:21:11 +00:00
|
|
|
db, err := shared.NewDB(c.dbConfig.DbConnectionString(), c.dbConfig)
|
2022-01-17 12:30:53 +00:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("failed to create config: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
c.DB = db
|
|
|
|
return nil
|
|
|
|
}
|