mirror of
https://github.com/tendermint/tendermint.git
synced 2026-01-11 07:20:19 +00:00
* ci: Fix linter complaint (#9645)
Fixes a very silly linter complaint that makes absolutely no sense and is blocking the merging of several PRs.
---
#### PR checklist
- [x] Tests written/updated, or no tests needed
- [x] `CHANGELOG_PENDING.md` updated, or no changelog entry needed
- [x] Updated relevant documentation (`docs/`) and code comments, or no
documentation updates needed
(cherry picked from commit 83b7f4ad5b)
# Conflicts:
# .github/workflows/lint.yml
# .golangci.yml
# cmd/tendermint/commands/debug/util.go
* Resolve conflicts
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* ci: Sync golangci-lint config with main
Minus the spelling configuration that restricts spelling to US English
only.
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* make format
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* Remove usage of deprecated io/ioutil package
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* Remove unused mockBlockStore
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* blockchain/v2: Remove unused method
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* Bulk fix lints
Signed-off-by: Thane Thomson <connect@thanethomson.com>
* lint: Ignore auto-generated query PEG
Signed-off-by: Thane Thomson <connect@thanethomson.com>
Signed-off-by: Thane Thomson <connect@thanethomson.com>
Co-authored-by: Thane Thomson <connect@thanethomson.com>
70 lines
2.1 KiB
Go
70 lines
2.1 KiB
Go
package main
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/BurntSushi/toml"
|
|
|
|
"github.com/tendermint/tendermint/test/e2e/app"
|
|
)
|
|
|
|
// Config is the application configuration.
|
|
type Config struct {
|
|
ChainID string `toml:"chain_id"`
|
|
Listen string
|
|
Protocol string
|
|
Dir string
|
|
Mode string `toml:"mode"`
|
|
PersistInterval uint64 `toml:"persist_interval"`
|
|
SnapshotInterval uint64 `toml:"snapshot_interval"`
|
|
RetainBlocks uint64 `toml:"retain_blocks"`
|
|
ValidatorUpdates map[string]map[string]uint8 `toml:"validator_update"`
|
|
PrivValServer string `toml:"privval_server"`
|
|
PrivValKey string `toml:"privval_key"`
|
|
PrivValState string `toml:"privval_state"`
|
|
Misbehaviors map[string]string `toml:"misbehaviors"`
|
|
KeyType string `toml:"key_type"`
|
|
}
|
|
|
|
// App extracts out the application specific configuration parameters
|
|
func (cfg *Config) App() *app.Config {
|
|
return &app.Config{
|
|
Dir: cfg.Dir,
|
|
SnapshotInterval: cfg.SnapshotInterval,
|
|
RetainBlocks: cfg.RetainBlocks,
|
|
KeyType: cfg.KeyType,
|
|
ValidatorUpdates: cfg.ValidatorUpdates,
|
|
PersistInterval: cfg.PersistInterval,
|
|
}
|
|
}
|
|
|
|
// LoadConfig loads the configuration from disk.
|
|
func LoadConfig(file string) (*Config, error) {
|
|
cfg := &Config{
|
|
Listen: "unix:///var/run/app.sock",
|
|
Protocol: "socket",
|
|
PersistInterval: 1,
|
|
}
|
|
_, err := toml.DecodeFile(file, &cfg)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("failed to load config from %q: %w", file, err)
|
|
}
|
|
return cfg, cfg.Validate()
|
|
}
|
|
|
|
// Validate validates the configuration. We don't do exhaustive config
|
|
// validation here, instead relying on Testnet.Validate() to handle it.
|
|
//
|
|
//nolint:goconst
|
|
func (cfg Config) Validate() error {
|
|
switch {
|
|
case cfg.ChainID == "":
|
|
return errors.New("chain_id parameter is required")
|
|
case cfg.Listen == "" && cfg.Protocol != "builtin":
|
|
return errors.New("listen parameter is required")
|
|
default:
|
|
return nil
|
|
}
|
|
}
|