Documentation
¶
Index ¶
- Variables
- func SetGenesisTimestamp(ts int64)
- func Timestamp() int64
- func WithGenesisContext(ctx context.Context, g Genesis) context.Context
- type Account
- type Blockchain
- type BootstrapCandidate
- type Delegate
- type Genesis
- func (g *Genesis) Hash() hash.Hash256
- func (g *Genesis) IsAleutian(height uint64) bool
- func (g *Genesis) IsBering(height uint64) bool
- func (g *Genesis) IsCook(height uint64) bool
- func (g *Genesis) IsDardanelles(height uint64) bool
- func (g *Genesis) IsDaytona(height uint64) bool
- func (g *Genesis) IsEaster(height uint64) bool
- func (g *Genesis) IsFairbank(height uint64) bool
- func (g *Genesis) IsFbkMigration(height uint64) bool
- func (g *Genesis) IsGreenland(height uint64) bool
- func (g *Genesis) IsHawaii(height uint64) bool
- func (g *Genesis) IsIceland(height uint64) bool
- func (g *Genesis) IsPacific(height uint64) bool
- type Poll
- type RegistrationConsts
- type Rewarding
- func (r *Rewarding) AleutianEpochReward() *big.Int
- func (r *Rewarding) BlockReward() *big.Int
- func (r *Rewarding) DardanellesBlockReward() *big.Int
- func (r *Rewarding) EpochReward() *big.Int
- func (r *Rewarding) ExemptAddrsFromEpochReward() []address.Address
- func (r *Rewarding) FoundationBonus() *big.Int
- func (r *Rewarding) InitBalance() *big.Int
- type Staking
- type VoteWeightCalConsts
Constants ¶
This section is empty.
Variables ¶
var Default = defaultConfig()
Default contains the default genesis config
Functions ¶
func SetGenesisTimestamp ¶ added in v1.2.0
func SetGenesisTimestamp(ts int64)
SetGenesisTimestamp sets the genesis timestamp
Types ¶
type Account ¶ added in v0.5.0
type Account struct {
// InitBalanceMap is the address and initial balance mapping before the first block.
InitBalanceMap map[string]string `yaml:"initBalances"`
}
Account contains the configs for account protocol
type Blockchain ¶ added in v0.5.0
type Blockchain struct {
// Timestamp is the timestamp of the genesis block
Timestamp int64
// BlockGasLimit is the total gas limit could be consumed in a block
BlockGasLimit uint64 `yaml:"blockGasLimit"`
// ActionGasLimit is the per action gas limit cap
ActionGasLimit uint64 `yaml:"actionGasLimit"`
// BlockInterval is the interval between two blocks
BlockInterval time.Duration `yaml:"blockInterval"`
// NumSubEpochs is the number of sub epochs in one epoch of block production
NumSubEpochs uint64 `yaml:"numSubEpochs"`
// DardanellesNumSubEpochs is the number of sub epochs starts from dardanelles height in one epoch of block production
DardanellesNumSubEpochs uint64 `yaml:"dardanellesNumSubEpochs"`
// NumDelegates is the number of delegates that participate into one epoch of block production
NumDelegates uint64 `yaml:"numDelegates"`
// NumCandidateDelegates is the number of candidate delegates, who may be selected as a delegate via roll dpos
NumCandidateDelegates uint64 `yaml:"numCandidateDelegates"`
// TimeBasedRotation is the flag to enable rotating delegates' time slots on a block height
TimeBasedRotation bool `yaml:"timeBasedRotation"`
// PacificBlockHeight is the start height of using the logic of Pacific version
// TODO: PacificBlockHeight is not added into protobuf definition for backward compatibility
PacificBlockHeight uint64 `yaml:"pacificHeight"`
// AleutianBlockHeight is the start height of adding bloom filter of all events into block header
AleutianBlockHeight uint64 `yaml:"aleutianHeight"`
// BeringBlockHeight is the start height of evm upgrade
BeringBlockHeight uint64 `yaml:"beringHeight"`
// CookBlockHeight is the start height of native staking
CookBlockHeight uint64 `yaml:"cookHeight"`
// DardanellesBlockHeight is the start height of 5s block internal
DardanellesBlockHeight uint64 `yaml:"dardanellesHeight"`
// DaytonaBlockHeight is the height to fix low gas for read native staking contract
DaytonaBlockHeight uint64 `yaml:"daytonaBlockHeight"`
// EasterBlockHeight is the start height of probation for slashing
EasterBlockHeight uint64 `yaml:"easterHeight"`
// FbkMigrationBlockHeight is the start height for fairbank migration
FbkMigrationBlockHeight uint64 `yaml:"fbkMigrationHeight"`
// FairbankBlockHeight is the start height to switch to native staking V2
FairbankBlockHeight uint64 `yaml:"fairbankHeight"`
// GreenlandBlockHeight is the start height of storing latest 720 block meta and rewarding/staking bucket pool
GreenlandBlockHeight uint64 `yaml:"greenlandHeight"`
// HawaiiBlockHeight is the start height to
// 1. fix GetBlockHash in EVM
// 2. add revert message to log
// 3. fix change to same candidate in staking protocol
// 4. fix sorted map in StateDBAdapter
// 5. use pending nonce in EVM
HawaiiBlockHeight uint64 `yaml:"hawaiiHeight"`
// IcelandBlockHeight is the start height to support chainID opcode in EVM
IcelandBlockHeight uint64 `yaml:"icelandHeight"`
}
Blockchain contains blockchain level configs
type BootstrapCandidate ¶ added in v0.11.0
type BootstrapCandidate struct {
OwnerAddress string `yaml:"ownerAddress"`
OperatorAddress string `yaml:"operatorAddress"`
RewardAddress string `yaml:"rewardAddress"`
Name string `yaml:"name"`
SelfStakingTokens string `yaml:"selfStakingTokens"`
}
BootstrapCandidate is the candidate data need to be provided to bootstrap candidate.
type Delegate ¶ added in v0.5.0
type Delegate struct {
// OperatorAddrStr is the address who will operate the node
OperatorAddrStr string `yaml:"operatorAddr"`
// RewardAddrStr is the address who will get the reward when operator produces blocks
RewardAddrStr string `yaml:"rewardAddr"`
// VotesStr is the score for the operator to rank and weight for rewardee to split epoch reward
VotesStr string `yaml:"votes"`
}
Delegate defines a delegate with address and votes
func (*Delegate) OperatorAddr ¶ added in v0.5.0
OperatorAddr is the address of operator
func (*Delegate) RewardAddr ¶ added in v0.5.0
RewardAddr is the address of rewardee, which is allowed to be nil
type Genesis ¶ added in v0.5.0
type Genesis struct {
Blockchain `yaml:"blockchain"`
Account `yaml:"account"`
Poll `yaml:"poll"`
Rewarding `yaml:"rewarding"`
Staking `yaml:"staking"`
}
Genesis is the root level of genesis config. Genesis config is the network-wide blockchain config. All the nodes participating into the same network should use EXACTLY SAME genesis config.
func ExtractGenesisContext ¶ added in v1.2.1
ExtractGenesisContext extracts genesis from context if available
func MustExtractGenesisContext ¶ added in v1.2.1
MustExtractGenesisContext extracts genesis from context if available, else panic
func New ¶ added in v0.5.0
New constructs a genesis config. It loads the default values, and could be overwritten by values defined in the yaml config files
func (*Genesis) IsAleutian ¶ added in v1.2.1
IsAleutian checks whether height is equal to or larger than aleutian height
func (*Genesis) IsBering ¶ added in v1.2.1
IsBering checks whether height is equal to or larger than bering height
func (*Genesis) IsCook ¶ added in v1.2.1
IsCook checks whether height is equal to or larger than cook height
func (*Genesis) IsDardanelles ¶ added in v1.2.1
IsDardanelles checks whether height is equal to or larger than dardanelles height
func (*Genesis) IsDaytona ¶ added in v1.2.1
IsDaytona checks whether height is equal to or larger than daytona height
func (*Genesis) IsEaster ¶ added in v1.2.1
IsEaster checks whether height is equal to or larger than easter height
func (*Genesis) IsFairbank ¶ added in v1.2.1
IsFairbank checks whether height is equal to or larger than fairbank height
func (*Genesis) IsFbkMigration ¶ added in v1.2.1
IsFbkMigration checks whether height is equal to or larger than fbk migration height
func (*Genesis) IsGreenland ¶ added in v1.2.1
IsGreenland checks whether height is equal to or larger than greenland height
func (*Genesis) IsHawaii ¶ added in v1.2.1
IsHawaii checks whether height is equal to or larger than hawaii height
type Poll ¶ added in v0.5.0
type Poll struct {
// PollMode is different based on chain type or poll input data source
PollMode string `yaml:"pollMode"`
// EnableGravityChainVoting is a flag whether read voting from gravity chain
EnableGravityChainVoting bool `yaml:"enableGravityChainVoting"`
// GravityChainStartHeight is the height in gravity chain where the init poll result stored
GravityChainStartHeight uint64 `yaml:"gravityChainStartHeight"`
// GravityChainCeilingHeight is the height in gravity chain where the poll is no longer needed
GravityChainCeilingHeight uint64 `yaml:"gravityChainCeilingHeight"`
// GravityChainHeightInterval the height interval on gravity chain to pull delegate information
GravityChainHeightInterval uint64 `yaml:"gravityChainHeightInterval"`
// RegisterContractAddress is the address of register contract
RegisterContractAddress string `yaml:"registerContractAddress"`
// StakingContractAddress is the address of staking contract
StakingContractAddress string `yaml:"stakingContractAddress"`
// NativeStakingContractAddress is the address of native staking contract
NativeStakingContractAddress string `yaml:"nativeStakingContractAddress"`
// NativeStakingContractCode is the code of native staking contract
NativeStakingContractCode string `yaml:"nativeStakingContractCode"`
// ConsortiumCommitteeCode is the code of consortiumCommittee contract
ConsortiumCommitteeContractCode string `yaml:"consortiumCommitteeContractCode"`
// VoteThreshold is the vote threshold amount in decimal string format
VoteThreshold string `yaml:"voteThreshold"`
// ScoreThreshold is the score threshold amount in decimal string format
ScoreThreshold string `yaml:"scoreThreshold"`
// SelfStakingThreshold is self-staking vote threshold amount in decimal string format
SelfStakingThreshold string `yaml:"selfStakingThreshold"`
// Delegates is a list of delegates with votes
Delegates []Delegate `yaml:"delegates"`
// ProbationEpochPeriod is a duration of probation after delegate's productivity is lower than threshold
ProbationEpochPeriod uint64 `yaml:"probationEpochPeriod"`
// ProbationIntensityRate is a intensity rate of probation range from [0, 100], where 100 is hard-probation
ProbationIntensityRate uint32 `yaml:"probationIntensityRate"`
// UnproductiveDelegateMaxCacheSize is a max cache size of upd which is stored into state DB (probationEpochPeriod <= UnproductiveDelegateMaxCacheSize)
UnproductiveDelegateMaxCacheSize uint64 `yaml:unproductiveDelegateMaxCacheSize`
}
Poll contains the configs for poll protocol
type RegistrationConsts ¶ added in v0.11.0
type RegistrationConsts struct {
Fee string `yaml:"fee"`
MinSelfStake string `yaml:"minSelfStake"`
}
RegistrationConsts contains the configs for candidate registration
type Rewarding ¶ added in v0.5.0
type Rewarding struct {
// InitBalanceStr is the initial balance of the rewarding protocol in decimal string format
InitBalanceStr string `yaml:"initBalance"`
// BlockReward is the block reward amount in decimal string format
BlockRewardStr string `yaml:"blockReward"`
// DardanellesBlockReward is the block reward amount starts from dardanelles height in decimal string format
DardanellesBlockRewardStr string `yaml:"dardanellesBlockReward"`
// EpochReward is the epoch reward amount in decimal string format
EpochRewardStr string `yaml:"epochReward"`
// AleutianEpochRewardStr is the epoch reward amount in decimal string format after aleutian fork
AleutianEpochRewardStr string `yaml:"aleutianEpochReward"`
// NumDelegatesForEpochReward is the number of top candidates that will share a epoch reward
NumDelegatesForEpochReward uint64 `yaml:"numDelegatesForEpochReward"`
// ExemptAddrStrsFromEpochReward is the list of addresses in encoded string format that exempt from epoch reward
ExemptAddrStrsFromEpochReward []string `yaml:"exemptAddrsFromEpochReward"`
// FoundationBonusStr is the bootstrap bonus in decimal string format
FoundationBonusStr string `yaml:"foundationBonus"`
// NumDelegatesForFoundationBonus is the number of top candidate that will get the bootstrap bonus
NumDelegatesForFoundationBonus uint64 `yaml:"numDelegatesForFoundationBonus"`
// FoundationBonusLastEpoch is the last epoch number that bootstrap bonus will be granted
FoundationBonusLastEpoch uint64 `yaml:"foundationBonusLastEpoch"`
// FoundationBonusP2StartEpoch is the start epoch number for part 2 foundation bonus
FoundationBonusP2StartEpoch uint64 `yaml:"foundationBonusP2StartEpoch"`
// FoundationBonusP2EndEpoch is the end epoch number for part 2 foundation bonus
FoundationBonusP2EndEpoch uint64 `yaml:"foundationBonusP2EndEpoch"`
// ProductivityThreshold is the percentage number that a delegate's productivity needs to reach not to get probation
ProductivityThreshold uint64 `yaml:"productivityThreshold"`
}
Rewarding contains the configs for rewarding protocol
func (*Rewarding) AleutianEpochReward ¶ added in v0.7.1
AleutianEpochReward returns the epoch reward amount after Aleutian fork
func (*Rewarding) BlockReward ¶ added in v0.5.0
BlockReward returns the block reward amount
func (*Rewarding) DardanellesBlockReward ¶ added in v0.10.0
DardanellesBlockReward returns the block reward amount after dardanelles fork
func (*Rewarding) EpochReward ¶ added in v0.5.0
EpochReward returns the epoch reward amount
func (*Rewarding) ExemptAddrsFromEpochReward ¶ added in v0.5.0
ExemptAddrsFromEpochReward returns the list of addresses that exempt from epoch reward
func (*Rewarding) FoundationBonus ¶ added in v0.5.0
FoundationBonus returns the bootstrap bonus amount rewarded per epoch
func (*Rewarding) InitBalance ¶ added in v0.5.0
InitBalance returns the init balance of the rewarding fund
type Staking ¶ added in v0.11.0
type Staking struct {
VoteWeightCalConsts VoteWeightCalConsts `yaml:"voteWeightCalConsts"`
RegistrationConsts RegistrationConsts `yaml:"registrationConsts"`
WithdrawWaitingPeriod time.Duration `yaml:"withdrawWaitingPeriod"`
MinStakeAmount string `yaml:"minStakeAmount"`
BootstrapCandidates []BootstrapCandidate `yaml:"bootstrapCandidates"`
}
Staking contains the configs for staking protocol
type VoteWeightCalConsts ¶ added in v0.11.0
type VoteWeightCalConsts struct {
DurationLg float64 `yaml:"durationLg"`
AutoStake float64 `yaml:"autoStake"`
SelfStake float64 `yaml:"selfStake"`
}
VoteWeightCalConsts contains the configs for calculating vote weight