2018-06-12 23:12:59 +00:00
|
|
|
// Package params defines important configuration options to be used when instantiating
|
|
|
|
// objects within the sharding package. For example, it defines objects such as a
|
2018-06-13 17:37:23 +00:00
|
|
|
// Config that will be useful when creating new shard instances.
|
2018-06-12 23:12:59 +00:00
|
|
|
package params
|
|
|
|
|
|
|
|
import (
|
2018-07-23 16:29:00 +00:00
|
|
|
"math"
|
2018-06-12 23:12:59 +00:00
|
|
|
"math/big"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
)
|
|
|
|
|
2018-06-13 17:37:23 +00:00
|
|
|
// DefaultConfig contains default configs for node to use in the sharded universe.
|
|
|
|
var DefaultConfig = &Config{
|
2018-06-12 23:12:59 +00:00
|
|
|
SMCAddress: common.HexToAddress("0x0"),
|
|
|
|
PeriodLength: 5,
|
|
|
|
NotaryDeposit: new(big.Int).Exp(big.NewInt(10), big.NewInt(21), nil), // 1000 ETH
|
|
|
|
NotaryLockupLength: 16128,
|
|
|
|
ProposerLockupLength: 48,
|
|
|
|
NotaryCommitteeSize: 135,
|
|
|
|
NotaryQuorumSize: 90,
|
|
|
|
NotaryChallengePeriod: 25,
|
2018-07-23 16:29:00 +00:00
|
|
|
CollationSizeLimit: int64(math.Pow(float64(2), float64(20))),
|
2018-06-12 23:12:59 +00:00
|
|
|
}
|
|
|
|
|
2018-06-13 17:37:23 +00:00
|
|
|
// DefaultChainConfig contains default chain configs of an individual shard.
|
|
|
|
var DefaultChainConfig = &ChainConfig{}
|
2018-06-12 23:12:59 +00:00
|
|
|
|
2018-06-13 17:37:23 +00:00
|
|
|
// Config contains configs for node to participate in the sharded universe.
|
|
|
|
type Config struct {
|
2018-06-12 23:12:59 +00:00
|
|
|
SMCAddress common.Address // SMCAddress is the address of SMC in mainchain.
|
|
|
|
PeriodLength int64 // PeriodLength is num of blocks in period.
|
|
|
|
NotaryDeposit *big.Int // NotaryDeposit is a required deposit size in wei.
|
|
|
|
NotaryLockupLength int64 // NotaryLockupLength to lockup notary deposit from time of deregistration.
|
|
|
|
ProposerLockupLength int64 // ProposerLockupLength to lockup proposer deposit from time of deregistration.
|
|
|
|
NotaryCommitteeSize int64 // NotaryCommitSize sampled per block from the notaries pool per period per shard.
|
|
|
|
NotaryQuorumSize int64 // NotaryQuorumSize votes the collation needs to get accepted to the canonical chain.
|
|
|
|
NotaryChallengePeriod int64 // NotaryChallengePeriod is the duration a notary has to store collations for.
|
2018-07-23 16:29:00 +00:00
|
|
|
CollationSizeLimit int64 // CollationSizeLimit is the maximum size the serialized blobs in a collation can take.
|
2018-06-12 23:12:59 +00:00
|
|
|
}
|
|
|
|
|
2018-06-13 17:37:23 +00:00
|
|
|
// ChainConfig contains chain config of an individual shard. Still to be designed.
|
|
|
|
type ChainConfig struct{}
|