Documentation ¶
Index ¶
- Constants
- Variables
- func AVAXAssetID(avmGenesisBytes []byte) (ids.ID, error)
- func Aliases(genesisBytes []byte) (map[string][]string, map[ids.ID][]string, error)
- func FromConfig(config *Config) ([]byte, ids.ID, error)
- func FromFile(networkID uint32, filepath string, stakingCfg *StakingConfig) ([]byte, ids.ID, error)
- func FromFlag(networkID uint32, genesisContent string, stakingCfg *StakingConfig) ([]byte, ids.ID, error)
- func GetCheckpoints(networkID uint32, chainID ids.ID) set.Set[ids.ID]
- func GetValidators(networkID uint32) set.Set[ids.NodeID]
- func VMGenesis(genesisBytes []byte, vmID ids.ID) (*pchaintxs.Tx, error)
- type Allocation
- type Bootstrapper
- type Config
- type LockedAmount
- type Params
- type Staker
- type StakingConfig
- type TxFeeConfig
- type UnparsedAllocation
- type UnparsedConfig
- type UnparsedStaker
Constants ¶
const ( VMRQKeyStr = "vmRQiZeXEXYMyJhEiqdC2z5JhuDbxL8ix9UVvjgMu2Er1NepE" VMRQKeyFormattedStr = secp256k1.PrivateKeyPrefix + VMRQKeyStr EWOQKeyStr = "ewoqjP7PxY4yr3iLTpLisriqt94hdyDFNgchSxGGztUrTXtNN" EWOQKeyFormattedStr = secp256k1.PrivateKeyPrefix + EWOQKeyStr )
Variables ¶
var ( PChainAliases = []string{"P", "platform"} XChainAliases = []string{"X", "avm"} CChainAliases = []string{"C", "evm"} VMAliases = map[ids.ID][]string{ constants.PlatformVMID: {"platform"}, constants.AVMID: {"avm"}, constants.EVMID: {"evm"}, secp256k1fx.ID: {"secp256k1fx"}, nftfx.ID: {"nftfx"}, propertyfx.ID: {"propertyfx"}, } )
var ( VMRQKey *secp256k1.PrivateKey EWOQKey *secp256k1.PrivateKey // LocalParams are the params used for local networks LocalParams = Params{ TxFeeConfig: TxFeeConfig{ CreateAssetTxFee: units.MilliAvax, StaticFeeConfig: txfee.StaticConfig{ TxFee: units.MilliAvax, CreateSubnetTxFee: 100 * units.MilliAvax, TransformSubnetTxFee: 100 * units.MilliAvax, CreateBlockchainTxFee: 100 * units.MilliAvax, AddPrimaryNetworkValidatorFee: 0, AddPrimaryNetworkDelegatorFee: 0, AddSubnetValidatorFee: units.MilliAvax, AddSubnetDelegatorFee: units.MilliAvax, }, DynamicFeeConfig: gas.Config{ Weights: gas.Dimensions{ gas.Bandwidth: 1, gas.DBRead: 1, gas.DBWrite: 1, gas.Compute: 1, }, MaxCapacity: 1_000_000, MaxPerSecond: 250_000, TargetPerSecond: 125_000, MinPrice: 1, ExcessConversionConstant: 5_410_106, }, ValidatorFeeConfig: validatorfee.Config{ Capacity: 20_000, Target: 10_000, MinPrice: gas.Price(1 * units.NanoAvax), ExcessConversionConstant: 865_617, }, }, StakingConfig: StakingConfig{ UptimeRequirement: .8, MinValidatorStake: 2 * units.KiloAvax, MaxValidatorStake: 3 * units.MegaAvax, MinDelegatorStake: 25 * units.Avax, MinDelegationFee: 20000, MinStakeDuration: 24 * time.Hour, MaxStakeDuration: 365 * 24 * time.Hour, RewardConfig: reward.Config{ MaxConsumptionRate: .12 * reward.PercentDenominator, MinConsumptionRate: .10 * reward.PercentDenominator, MintingPeriod: 365 * 24 * time.Hour, SupplyCap: 720 * units.MegaAvax, }, }, } )
var ( // FujiParams are the params used for the fuji testnet FujiParams = Params{ TxFeeConfig: TxFeeConfig{ CreateAssetTxFee: 10 * units.MilliAvax, StaticFeeConfig: txfee.StaticConfig{ TxFee: units.MilliAvax, CreateSubnetTxFee: 100 * units.MilliAvax, TransformSubnetTxFee: 1 * units.Avax, CreateBlockchainTxFee: 100 * units.MilliAvax, AddPrimaryNetworkValidatorFee: 0, AddPrimaryNetworkDelegatorFee: 0, AddSubnetValidatorFee: units.MilliAvax, AddSubnetDelegatorFee: units.MilliAvax, }, DynamicFeeConfig: gas.Config{ Weights: gas.Dimensions{ gas.Bandwidth: 1, gas.DBRead: 1, gas.DBWrite: 1, gas.Compute: 1, }, MaxCapacity: 1_000_000, MaxPerSecond: 250_000, TargetPerSecond: 125_000, MinPrice: 1, ExcessConversionConstant: 5_410_106, }, ValidatorFeeConfig: validatorfee.Config{ Capacity: 20_000, Target: 10_000, MinPrice: gas.Price(512 * units.NanoAvax), ExcessConversionConstant: 51_937_021, }, }, StakingConfig: StakingConfig{ UptimeRequirement: .8, MinValidatorStake: 1 * units.Avax, MaxValidatorStake: 3 * units.MegaAvax, MinDelegatorStake: 1 * units.Avax, MinDelegationFee: 20000, MinStakeDuration: 24 * time.Hour, MaxStakeDuration: 365 * 24 * time.Hour, RewardConfig: reward.Config{ MaxConsumptionRate: .12 * reward.PercentDenominator, MinConsumptionRate: .10 * reward.PercentDenominator, MintingPeriod: 365 * 24 * time.Hour, SupplyCap: 720 * units.MegaAvax, }, }, } )
var ( // MainnetParams are the params used for mainnet MainnetParams = Params{ TxFeeConfig: TxFeeConfig{ CreateAssetTxFee: 10 * units.MilliAvax, StaticFeeConfig: txfee.StaticConfig{ TxFee: units.MilliAvax, CreateSubnetTxFee: 1 * units.Avax, TransformSubnetTxFee: 10 * units.Avax, CreateBlockchainTxFee: 1 * units.Avax, AddPrimaryNetworkValidatorFee: 0, AddPrimaryNetworkDelegatorFee: 0, AddSubnetValidatorFee: units.MilliAvax, AddSubnetDelegatorFee: units.MilliAvax, }, DynamicFeeConfig: gas.Config{ Weights: gas.Dimensions{ gas.Bandwidth: 1, gas.DBRead: 1, gas.DBWrite: 1, gas.Compute: 1, }, MaxCapacity: 1_000_000, MaxPerSecond: 250_000, TargetPerSecond: 125_000, MinPrice: 1, ExcessConversionConstant: 5_410_106, }, ValidatorFeeConfig: validatorfee.Config{ Capacity: 20_000, Target: 10_000, MinPrice: gas.Price(512 * units.NanoAvax), ExcessConversionConstant: 1_246_488_515, }, }, StakingConfig: StakingConfig{ UptimeRequirement: .8, MinValidatorStake: 2 * units.KiloAvax, MaxValidatorStake: 3 * units.MegaAvax, MinDelegatorStake: 25 * units.Avax, MinDelegationFee: 20000, MinStakeDuration: 2 * 7 * 24 * time.Hour, MaxStakeDuration: 365 * 24 * time.Hour, RewardConfig: reward.Config{ MaxConsumptionRate: .12 * reward.PercentDenominator, MinConsumptionRate: .10 * reward.PercentDenominator, MintingPeriod: 365 * 24 * time.Hour, SupplyCap: 720 * units.MegaAvax, }, }, } )
Functions ¶
func FromConfig ¶
FromConfig returns:
- The byte representation of the genesis state of the platform chain (ie the genesis state of the network)
- The asset ID of AVAX
func FromFile ¶ added in v1.7.2
FromFile returns the genesis data of the Platform Chain.
Since an Avalanche network has exactly one Platform Chain, and the Platform Chain defines the genesis state of the network (who is staking, which chains exist, etc.), defining the genesis state of the Platform Chain is the same as defining the genesis state of the network.
FromFile accepts: 1) The ID of the new network. [networkID] 2) The location of a custom genesis config to load. filepath
If filepath is empty or the given network ID is Mainnet, Testnet, or Local, returns error. If filepath is non-empty and networkID isn't Mainnet, Testnet, or Local, loads the network genesis data from the config at filepath.
FromFile returns:
- The byte representation of the genesis state of the platform chain (ie the genesis state of the network)
- The asset ID of AVAX
func FromFlag ¶ added in v1.7.2
func FromFlag(networkID uint32, genesisContent string, stakingCfg *StakingConfig) ([]byte, ids.ID, error)
FromFlag returns the genesis data of the Platform Chain.
Since an Avalanche network has exactly one Platform Chain, and the Platform Chain defines the genesis state of the network (who is staking, which chains exist, etc.), defining the genesis state of the Platform Chain is the same as defining the genesis state of the network.
FromFlag accepts: 1) The ID of the new network. [networkID] 2) The content of a custom genesis config to load. [genesisContent]
If [genesisContent] is empty or the given network ID is Mainnet, Testnet, or Local, returns error. If [genesisContent] is non-empty and networkID isn't Mainnet, Testnet, or Local, loads the network genesis data from [genesisContent].
FromFlag returns:
- The byte representation of the genesis state of the platform chain (ie the genesis state of the network)
- The asset ID of AVAX
func GetCheckpoints ¶ added in v1.11.5
GetCheckpoints returns all known checkpoints for the chain on the requested network.
func GetValidators ¶ added in v1.11.5
GetValidators returns recent validators for the requested network.
Types ¶
type Allocation ¶ added in v1.0.0
type Allocation struct { ETHAddr ids.ShortID `json:"ethAddr"` AVAXAddr ids.ShortID `json:"avaxAddr"` InitialAmount uint64 `json:"initialAmount"` UnlockSchedule []LockedAmount `json:"unlockSchedule"` }
func (Allocation) Compare ¶ added in v1.10.18
func (a Allocation) Compare(other Allocation) int
func (Allocation) Unparse ¶ added in v1.0.0
func (a Allocation) Unparse(networkID uint32) (UnparsedAllocation, error)
type Bootstrapper ¶ added in v1.10.3
Represents the relationship between the nodeID and the nodeIP. The bootstrapper is sometimes called "anchor" or "beacon" node.
func GetBootstrappers ¶ added in v1.10.18
func GetBootstrappers(networkID uint32) []Bootstrapper
GetBootstrappers returns all default bootstrappers for the provided network.
func SampleBootstrappers ¶ added in v1.10.3
func SampleBootstrappers(networkID uint32, count int) []Bootstrapper
SampleBootstrappers returns the some beacons this node should connect to
type Config ¶
type Config struct { NetworkID uint32 `json:"networkID"` Allocations []Allocation `json:"allocations"` StartTime uint64 `json:"startTime"` InitialStakeDuration uint64 `json:"initialStakeDuration"` InitialStakeDurationOffset uint64 `json:"initialStakeDurationOffset"` InitialStakedFunds []ids.ShortID `json:"initialStakedFunds"` InitialStakers []Staker `json:"initialStakers"` CChainGenesis string `json:"cChainGenesis"` Message string `json:"message"` }
Config contains the genesis addresses used to construct a genesis
var ( // MainnetConfig is the config that should be used to generate the mainnet // genesis. MainnetConfig Config // FujiConfig is the config that should be used to generate the fuji // genesis. FujiConfig Config // LocalConfig is the config that should be used to generate a local // genesis. LocalConfig Config )
func GetConfigContent ¶ added in v1.7.2
GetConfigContent loads a *Config from a provided environment variable
func GetConfigFile ¶ added in v1.1.4
GetConfigFile loads a *Config from a provided filepath.
func (*Config) InitialSupply ¶ added in v1.0.0
func (Config) Unparse ¶ added in v1.0.0
func (c Config) Unparse() (UnparsedConfig, error)
type LockedAmount ¶ added in v1.0.0
type Params ¶ added in v1.0.0
type Params struct { StakingConfig TxFeeConfig }
type Staker ¶ added in v1.0.0
type StakingConfig ¶ added in v1.5.0
type StakingConfig struct { // Staking uptime requirements UptimeRequirement float64 `json:"uptimeRequirement"` // Minimum stake, in nAVAX, required to validate the primary network MinValidatorStake uint64 `json:"minValidatorStake"` // Maximum stake, in nAVAX, allowed to be placed on a single validator in // the primary network MaxValidatorStake uint64 `json:"maxValidatorStake"` // Minimum stake, in nAVAX, that can be delegated on the primary network MinDelegatorStake uint64 `json:"minDelegatorStake"` // Minimum delegation fee, in the range [0, 1000000], that can be charged // for delegation on the primary network. MinDelegationFee uint32 `json:"minDelegationFee"` // MinStakeDuration is the minimum amount of time a validator can validate // for in a single period. MinStakeDuration time.Duration `json:"minStakeDuration"` // MaxStakeDuration is the maximum amount of time a validator can validate // for in a single period. MaxStakeDuration time.Duration `json:"maxStakeDuration"` // RewardConfig is the config for the reward function. RewardConfig reward.Config `json:"rewardConfig"` }
func GetStakingConfig ¶ added in v1.5.0
func GetStakingConfig(networkID uint32) StakingConfig
type TxFeeConfig ¶ added in v1.5.0
type TxFeeConfig struct { CreateAssetTxFee uint64 `json:"createAssetTxFee"` StaticFeeConfig txfee.StaticConfig `json:"staticFeeConfig"` DynamicFeeConfig gas.Config `json:"dynamicFeeConfig"` ValidatorFeeConfig validatorfee.Config `json:"validatorFeeConfig"` }
func GetTxFeeConfig ¶ added in v1.5.0
func GetTxFeeConfig(networkID uint32) TxFeeConfig
type UnparsedAllocation ¶ added in v1.0.0
type UnparsedAllocation struct { ETHAddr string `json:"ethAddr"` AVAXAddr string `json:"avaxAddr"` InitialAmount uint64 `json:"initialAmount"` UnlockSchedule []LockedAmount `json:"unlockSchedule"` }
func (UnparsedAllocation) Parse ¶ added in v1.0.0
func (ua UnparsedAllocation) Parse() (Allocation, error)
type UnparsedConfig ¶ added in v1.0.0
type UnparsedConfig struct { NetworkID uint32 `json:"networkID"` Allocations []UnparsedAllocation `json:"allocations"` StartTime uint64 `json:"startTime"` InitialStakeDuration uint64 `json:"initialStakeDuration"` InitialStakeDurationOffset uint64 `json:"initialStakeDurationOffset"` InitialStakedFunds []string `json:"initialStakedFunds"` InitialStakers []UnparsedStaker `json:"initialStakers"` CChainGenesis string `json:"cChainGenesis"` Message string `json:"message"` }
UnparsedConfig contains the genesis addresses used to construct a genesis
func (UnparsedConfig) Parse ¶ added in v1.0.0
func (uc UnparsedConfig) Parse() (Config, error)
type UnparsedStaker ¶ added in v1.0.0
type UnparsedStaker struct { NodeID ids.NodeID `json:"nodeID"` RewardAddress string `json:"rewardAddress"` DelegationFee uint32 `json:"delegationFee"` Signer *signer.ProofOfPossession `json:"signer,omitempty"` }
func (UnparsedStaker) Parse ¶ added in v1.0.0
func (us UnparsedStaker) Parse() (Staker, error)