* first commit * gaia cleanup * ... * staking multihooks * missing module function return args * bank module name constant * working, module interface for x/ * got this thing compiling * make test compiles and passes * remove expanded simulation invariants * genesis issue * continued * continued * register crisis routes thought mm * begin blocker to mm * end blocker to mm * empty routes not initialized * move gaia initChainer sanity check to baseapp * remove codecs from module manager * reorging genesis stuff * module manager passed by reference/bugfixes from working last commit int int * move invariant checks from gaia to crisis * typo * basic refactors cmd/gaia/init * working * MultiStakingHooks from types to x/staking/types int * default module manager order of operations from input modules * working * typo * add AppModuleBasic * moduleBasicManager / non-test code compiles * working attempting to get tests passing * make test passes * sim random genesis fix * export bug * ... * genutil module * genutil working * refactored - happy with non-testing code in cmd/ * ... * lint fixes * comment improvement * cli test fix * compile housing * working through compile errors * working gettin' compilin' * non-test code compiles * move testnet to its own module * reworking tests int * bez staging PR 1 comments * concise module function-of names * moved all tests from genesis_test.go to other genutil tests * genaccounts package, add genutil and genaccounts to app.go * docs for genutil genaccounts * genaccounts iterate fn * non-test code with genaccounts/ now compiles * working test compiling * debugging tests * resolved all make test compile errors * test debuggin * resolved all unit tests, introduced param module * cli-test compile fixes * staking initialization bug * code comment improvements, changelog entries * BasicGaiaApp -> ModuleBasics * highlevel explanation in types/module.go * @alexanderbez comment revisions * @fedekunze PR comments * @alexanderbez PR comments (x2) * @cwgoes comments (minor updates) * @fedekunze suggestions * panic on init with multiple validator updates from different modules * initchain panic makes validate genesis fail int * AppModuleGenesis seperation int * test * remove init panic logic in validate genesis replaced with TODO * set maxprocs to match system's GOMAXPROCS * Update circleci * Cap maxprocs in CI to 4 * @alexanderbez recent comments addressed * less blocks in twouble sims int * runsim error output flag * -e on import_export as well * error out int * Try to fix failures * runsim
104 lines
3.4 KiB
Go
104 lines
3.4 KiB
Go
package auth
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/cosmos/cosmos-sdk/x/params"
|
|
"github.com/cosmos/cosmos-sdk/x/params/subspace"
|
|
)
|
|
|
|
// DefaultParamspace defines the default auth module parameter subspace
|
|
const DefaultParamspace = ModuleName
|
|
|
|
// Default parameter values
|
|
const (
|
|
DefaultMaxMemoCharacters uint64 = 256
|
|
DefaultTxSigLimit uint64 = 7
|
|
DefaultTxSizeCostPerByte uint64 = 10
|
|
DefaultSigVerifyCostED25519 uint64 = 590
|
|
DefaultSigVerifyCostSecp256k1 uint64 = 1000
|
|
)
|
|
|
|
// Parameter keys
|
|
var (
|
|
KeyMaxMemoCharacters = []byte("MaxMemoCharacters")
|
|
KeyTxSigLimit = []byte("TxSigLimit")
|
|
KeyTxSizeCostPerByte = []byte("TxSizeCostPerByte")
|
|
KeySigVerifyCostED25519 = []byte("SigVerifyCostED25519")
|
|
KeySigVerifyCostSecp256k1 = []byte("SigVerifyCostSecp256k1")
|
|
)
|
|
|
|
var _ subspace.ParamSet = &Params{}
|
|
|
|
// Params defines the parameters for the auth module.
|
|
type Params struct {
|
|
MaxMemoCharacters uint64 `json:"max_memo_characters"`
|
|
TxSigLimit uint64 `json:"tx_sig_limit"`
|
|
TxSizeCostPerByte uint64 `json:"tx_size_cost_per_byte"`
|
|
SigVerifyCostED25519 uint64 `json:"sig_verify_cost_ed25519"`
|
|
SigVerifyCostSecp256k1 uint64 `json:"sig_verify_cost_secp256k1"`
|
|
}
|
|
|
|
// NewParams creates a new Params object
|
|
func NewParams(maxMemoCharacters, txSigLimit, txSizeCostPerByte,
|
|
sigVerifyCostED25519, sigVerifyCostSecp256k1 uint64) Params {
|
|
|
|
return Params{
|
|
MaxMemoCharacters: maxMemoCharacters,
|
|
TxSigLimit: txSigLimit,
|
|
TxSizeCostPerByte: txSizeCostPerByte,
|
|
SigVerifyCostED25519: sigVerifyCostED25519,
|
|
SigVerifyCostSecp256k1: sigVerifyCostSecp256k1,
|
|
}
|
|
}
|
|
|
|
// ParamKeyTable for auth module
|
|
func ParamKeyTable() params.KeyTable {
|
|
return params.NewKeyTable().RegisterParamSet(&Params{})
|
|
}
|
|
|
|
// ParamSetPairs implements the ParamSet interface and returns all the key/value pairs
|
|
// pairs of auth module's parameters.
|
|
// nolint
|
|
func (p *Params) ParamSetPairs() subspace.ParamSetPairs {
|
|
return subspace.ParamSetPairs{
|
|
{KeyMaxMemoCharacters, &p.MaxMemoCharacters},
|
|
{KeyTxSigLimit, &p.TxSigLimit},
|
|
{KeyTxSizeCostPerByte, &p.TxSizeCostPerByte},
|
|
{KeySigVerifyCostED25519, &p.SigVerifyCostED25519},
|
|
{KeySigVerifyCostSecp256k1, &p.SigVerifyCostSecp256k1},
|
|
}
|
|
}
|
|
|
|
// Equal returns a boolean determining if two Params types are identical.
|
|
func (p Params) Equal(p2 Params) bool {
|
|
bz1 := moduleCdc.MustMarshalBinaryLengthPrefixed(&p)
|
|
bz2 := moduleCdc.MustMarshalBinaryLengthPrefixed(&p2)
|
|
return bytes.Equal(bz1, bz2)
|
|
}
|
|
|
|
// DefaultParams returns a default set of parameters.
|
|
func DefaultParams() Params {
|
|
return Params{
|
|
MaxMemoCharacters: DefaultMaxMemoCharacters,
|
|
TxSigLimit: DefaultTxSigLimit,
|
|
TxSizeCostPerByte: DefaultTxSizeCostPerByte,
|
|
SigVerifyCostED25519: DefaultSigVerifyCostED25519,
|
|
SigVerifyCostSecp256k1: DefaultSigVerifyCostSecp256k1,
|
|
}
|
|
}
|
|
|
|
// String implements the stringer interface.
|
|
func (p Params) String() string {
|
|
var sb strings.Builder
|
|
sb.WriteString("Params: \n")
|
|
sb.WriteString(fmt.Sprintf("MaxMemoCharacters: %d\n", p.MaxMemoCharacters))
|
|
sb.WriteString(fmt.Sprintf("TxSigLimit: %d\n", p.TxSigLimit))
|
|
sb.WriteString(fmt.Sprintf("TxSizeCostPerByte: %d\n", p.TxSizeCostPerByte))
|
|
sb.WriteString(fmt.Sprintf("SigVerifyCostED25519: %d\n", p.SigVerifyCostED25519))
|
|
sb.WriteString(fmt.Sprintf("SigVerifyCostSecp256k1: %d\n", p.SigVerifyCostSecp256k1))
|
|
return sb.String()
|
|
}
|