Documentation ¶
Overview ¶
Package shardingconfig defines types and utilities that deal with Harmony sharding configuration schedule.
Index ¶
Constants ¶
const ( // MainNetHTTPPattern is the http pattern for mainnet. MainNetHTTPPattern = "https://api.s%d.t.hmny.io" // MainNetWSPattern is the websocket pattern for mainnet. MainNetWSPattern = "wss://ws.s%d.t.hmny.io" )
const ( // PangaeaHTTPPattern is the http pattern for pangaea. PangaeaHTTPPattern = "https://api.s%d.os.hmny.io" // PangaeaWSPattern is the websocket pattern for pangaea. PangaeaWSPattern = "wss://ws.s%d.os.hmny.io" )
const ( // PartnerHTTPPattern is the http pattern for partner. PartnerHTTPPattern = "https://api.s%d.ps.hmny.io" // PartnerWSPattern is the websocket pattern for partner. PartnerWSPattern = "wss://ws.s%d.ps.hmny.io" )
const ( // StressNetHTTPPattern is the http pattern for stressnet. StressNetHTTPPattern = "https://api.s%d.stn.hmny.io" // StressNetWSPattern is the websocket pattern for stressnet. StressNetWSPattern = "wss://ws.s%d.stn.hmny.io" )
const ( // TestNetHTTPPattern is the http pattern for testnet. TestNetHTTPPattern = "https://api.s%d.b.hmny.io" // TestNetWSPattern is the websocket pattern for testnet. TestNetWSPattern = "wss://ws.s%d.b.hmny.io" )
const (
// RewardFrequency the number of blocks between each aggregated reward distribution
RewardFrequency = 64
)
const (
// VLBPE is a Very Large Block Per Epoch
VLBPE = 1000000000000
)
Variables ¶
var LocalnetSchedule localnetSchedule
LocalnetSchedule is the local testnet sharding configuration schedule.
var MainnetSchedule mainnetSchedule
MainnetSchedule is the mainnet sharding configuration schedule.
var PangaeaSchedule pangaeaSchedule
PangaeaSchedule is the Pangaea sharding configuration schedule.
var PartnerSchedule partnerSchedule
PartnerSchedule is the long-running public partner sharding configuration schedule.
var StressNetSchedule stressnetSchedule
StressNetSchedule is the long-running public stressNet sharding configuration schedule.
var TestnetSchedule testnetSchedule
TestnetSchedule is the long-running public testnet sharding configuration schedule.
Functions ¶
func BLS ¶
func BLS(pubkeys []string) []bls_cosi.PublicKeyWrapper
Types ¶
type Allowlist ¶
type Allowlist struct { MaxLimitPerShard int BLSPublicKeys []bls_cosi.PublicKeyWrapper }
type Instance ¶
type Instance interface { // NumShards returns the number of shards in the network. NumShards() uint32 // NumNodesPerShard returns number of nodes in each shard. NumNodesPerShard() int // NumHarmonyOperatedNodesPerShard returns number of nodes in each shard // that are operated by Harmony. NumHarmonyOperatedNodesPerShard() int // HarmonyVotePercent returns total percentage of voting power harmony nodes possess. HarmonyVotePercent() numeric.Dec // ExternalVotePercent returns total percentage of voting power external validators possess. ExternalVotePercent() numeric.Dec // HmyAccounts returns a list of Harmony accounts HmyAccounts() []genesis.DeployAccount // FnAccounts returns a list of Foundational node accounts FnAccounts() []genesis.DeployAccount // FindAccount returns the deploy account based on the blskey FindAccount(blsPubKey string) (bool, *genesis.DeployAccount) // ReshardingEpoch returns a list of Epoch while off-chain resharding happens ReshardingEpoch() []*big.Int // BlocksPerEpoch returns the number of blocks per epoch. BlocksPerEpoch() uint64 // HIP-16: The absolute number of maximum effective slots per shard limit for each validator. 0 means no limit. SlotsLimit() int // ExternalAllowlist returns the list of external leader keys in allowlist(HIP18) ExternalAllowlist() []bls.PublicKeyWrapper // ExternalAllowlistLimit returns the maximum number of external leader keys on each shard(HIP18) ExternalAllowlistLimit() int // FeeCollector returns a mapping of address to decimal % of fee FeeCollectors() FeeCollectors // HIP30RecoveryAddress returns the address to which // HIP30EmissionSplit % income is sent HIP30RecoveryAddress() ethCommon.Address // HIP30EmissionFraction is the percentage of the emission // sent to the Recovery Address HIP30EmissionFraction() numeric.Dec }
Instance is one sharding configuration instance.
func MustNewInstance ¶
func MustNewInstance( numShards uint32, numNodesPerShard, numHarmonyOperatedNodesPerShard int, slotsLimitPercent float32, harmonyVotePercent numeric.Dec, hmyAccounts []genesis.DeployAccount, fnAccounts []genesis.DeployAccount, allowlist Allowlist, feeCollectors FeeCollectors, emissionFractionToRecovery numeric.Dec, recoveryAddress ethCommon.Address, reshardingEpoch []*big.Int, blocksPerEpoch uint64, ) Instance
MustNewInstance creates a new sharding configuration based upon given parameters. It panics if parameter validation fails. It is intended to be used for static initialization.
func NewInstance ¶
func NewInstance( numShards uint32, numNodesPerShard, numHarmonyOperatedNodesPerShard, slotsLimit int, harmonyVotePercent numeric.Dec, hmyAccounts []genesis.DeployAccount, fnAccounts []genesis.DeployAccount, allowlist Allowlist, feeCollectors FeeCollectors, emissionFractionToRecovery numeric.Dec, recoveryAddress ethCommon.Address, reshardingEpoch []*big.Int, blocksE uint64, ) (Instance, error)
NewInstance creates and validates a new sharding configuration based upon given parameters.
type Schedule ¶
type Schedule interface { InstanceForEpoch(epoch *big.Int) Instance // CalcEpochNumber returns the epoch number based on the block number CalcEpochNumber(blockNum uint64) *big.Int // IsLastBlock check if the block is the last block in the epoch // NOTE: This method is very critical for the epoch transition logic and other checks. IsLastBlock(blockNum uint64) bool // EpochLastBlock returns the last block number of an epoch // NOTE: This method id important for a few rpcs and validator APR calculation EpochLastBlock(epochNum uint64) uint64 // VDFDifficulty returns number of iterations for VDF calculation VdfDifficulty() int // GetNetworkID() return networkID type. GetNetworkID() NetworkID // GetShardingStructure returns sharding structure. GetShardingStructure(int, int) []map[string]interface{} // IsSkippedEpoch returns if epoch was skipped on shard chain IsSkippedEpoch(uint32, *big.Int) bool // RewardFrequency returns the frequency of block reward RewardFrequency() uint64 }
Schedule returns the sharding configuration instance for the given epoch.
func NewFixedSchedule ¶
NewFixedSchedule returns a sharding configuration schedule that uses the given config instance for all epochs. Useful for testing.