Documentation ¶
Index ¶
- Constants
- Variables
- func ActorNameByCode(code cid.Cid) string
- func ConsensusMinerMinPower(p stabi.RegisteredSealProof) (stabi.StoragePower, error)
- func IsBuiltinActor(code cid.Cid) bool
- func IsPrincipal(code cid.Cid) bool
- func PoStProofWindowPoStPartitionSectors(p stabi.RegisteredPoStProof) (uint64, error)
- func RequestMinerControlAddrs(rt runtime.Runtime, minerAddr addr.Address) (ownerAddr addr.Address, workerAddr addr.Address, controlAddrs []addr.Address)
- func RequireNoErr(rt runtime.Runtime, err error, defaultExitCode exitcode.ExitCode, msg string, ...)
- func RequireParam(rt runtime.Runtime, predicate bool, msg string, args ...interface{})
- func RequireSuccess(rt runtime.Runtime, e exitcode.ExitCode, msg string, args ...interface{})
- func ResolveToIDAddr(rt runtime.Runtime, address addr.Address) (addr.Address, error)
- func SealProofSectorMaximumLifetime(p stabi.RegisteredSealProof) (stabi.ChainEpoch, error)
- func SealProofWindowPoStPartitionSectors(p stabi.RegisteredSealProof) (uint64, error)
- type ConfirmSectorProofsParams
- type Discard
- type MinerAddrs
- type PoStProofPolicy
- type SealProofPolicy
Constants ¶
const ( MethodSend = abi.MethodNum(0) MethodConstructor = abi.MethodNum(1) )
const EpochDurationSeconds = 30
The duration of a chain epoch. This is used for deriving epoch-denominated periods that are more naturally expressed in clock time. TODO: In lieu of a real configuration mechanism for this value, we'd like to make it a var so that implementations can override it at runtime. Doing so requires changing all the static references to it in this repo to go through late-binding function calls, or they'll see the "wrong" value. https://github.com/filecoin-project/specs-actors/issues/353 If EpochDurationSeconds is changed, update `BaselineExponent`, `lambda`, and // `expLamSubOne` in ./reward/reward_logic.go You can re-calculate these constants by changing the epoch duration in ./reward/reward_calc.py and running it.
const EpochsInDay = SecondsInDay / EpochDurationSeconds
const EpochsInHour = SecondsInHour / EpochDurationSeconds
const FirstNonSingletonActorId = 100
const SecondsInDay = 24 * SecondsInHour
const SecondsInHour = 60 * 60
const SectorQualityPrecision = 20
Precision used for making QA power calculations
Variables ¶
var ( SystemActorCodeID cid.Cid InitActorCodeID cid.Cid CronActorCodeID cid.Cid AccountActorCodeID cid.Cid StoragePowerActorCodeID cid.Cid StorageMinerActorCodeID cid.Cid StorageMarketActorCodeID cid.Cid PaymentChannelActorCodeID cid.Cid MultisigActorCodeID cid.Cid RewardActorCodeID cid.Cid VerifiedRegistryActorCodeID cid.Cid CallerTypesSignable []cid.Cid )
The built-in actor code IDs
var ( // Distinguished AccountActor that is the source of system implicit messages. SystemActorAddr = mustMakeAddress(0) InitActorAddr = mustMakeAddress(1) RewardActorAddr = mustMakeAddress(2) CronActorAddr = mustMakeAddress(3) StoragePowerActorAddr = mustMakeAddress(4) StorageMarketActorAddr = mustMakeAddress(5) VerifiedRegistryActorAddr = mustMakeAddress(6) // Distinguished AccountActor that is the destination of all burnt funds. BurntFundsActorAddr = mustMakeAddress(99) )
Addresses for singleton system actors.
var DealWeightMultiplier = big.NewInt(10)
Quality multiplier for unverified deals in a sector
var ExpectedLeadersPerEpoch = int64(5)
The expected number of block producers in each epoch.
var MethodsAccount = struct { Constructor abi.MethodNum PubkeyAddress abi.MethodNum }{MethodConstructor, 2}
var MethodsCron = struct { Constructor abi.MethodNum EpochTick abi.MethodNum }{MethodConstructor, 2}
var MethodsInit = struct { Constructor abi.MethodNum Exec abi.MethodNum }{MethodConstructor, 2}
var MethodsMarket = struct { Constructor abi.MethodNum AddBalance abi.MethodNum WithdrawBalance abi.MethodNum PublishStorageDeals abi.MethodNum VerifyDealsForActivation abi.MethodNum ActivateDeals abi.MethodNum OnMinerSectorsTerminate abi.MethodNum ComputeDataCommitment abi.MethodNum CronTick abi.MethodNum }{MethodConstructor, 2, 3, 4, 5, 6, 7, 8, 9}
var MethodsMiner = struct { Constructor abi.MethodNum ControlAddresses abi.MethodNum ChangeWorkerAddress abi.MethodNum ChangePeerID abi.MethodNum SubmitWindowedPoSt abi.MethodNum PreCommitSector abi.MethodNum ProveCommitSector abi.MethodNum ExtendSectorExpiration abi.MethodNum TerminateSectors abi.MethodNum DeclareFaults abi.MethodNum DeclareFaultsRecovered abi.MethodNum OnDeferredCronEvent abi.MethodNum CheckSectorProven abi.MethodNum AddLockedFund abi.MethodNum ReportConsensusFault abi.MethodNum WithdrawBalance abi.MethodNum ConfirmSectorProofsValid abi.MethodNum ChangeMultiaddrs abi.MethodNum CompactPartitions abi.MethodNum CompactSectorNumbers abi.MethodNum }{MethodConstructor, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20}
var MethodsMultisig = struct { Constructor abi.MethodNum Propose abi.MethodNum Approve abi.MethodNum Cancel abi.MethodNum AddSigner abi.MethodNum RemoveSigner abi.MethodNum SwapSigner abi.MethodNum ChangeNumApprovalsThreshold abi.MethodNum LockBalance abi.MethodNum }{MethodConstructor, 2, 3, 4, 5, 6, 7, 8, 9}
var MethodsPaych = struct { Constructor abi.MethodNum UpdateChannelState abi.MethodNum Settle abi.MethodNum Collect abi.MethodNum }{MethodConstructor, 2, 3, 4}
var MethodsPower = struct { Constructor abi.MethodNum CreateMiner abi.MethodNum UpdateClaimedPower abi.MethodNum EnrollCronEvent abi.MethodNum OnEpochTickEnd abi.MethodNum UpdatePledgeTotal abi.MethodNum OnConsensusFault abi.MethodNum SubmitPoRepForBulkVerify abi.MethodNum CurrentTotalPower abi.MethodNum }{MethodConstructor, 2, 3, 4, 5, 6, 7, 8, 9}
var MethodsReward = struct { Constructor abi.MethodNum AwardBlockReward abi.MethodNum ThisEpochReward abi.MethodNum UpdateNetworkKPI abi.MethodNum }{MethodConstructor, 2, 3, 4}
var MethodsVerifiedRegistry = struct { Constructor abi.MethodNum AddVerifier abi.MethodNum RemoveVerifier abi.MethodNum AddVerifiedClient abi.MethodNum UseBytes abi.MethodNum RestoreBytes abi.MethodNum }{MethodConstructor, 2, 3, 4, 5, 6}
var PoStProofPolicies = map[stabi.RegisteredPoStProof]*PoStProofPolicy{ stabi.RegisteredPoStProof_StackedDrgWindow2KiBV1: { WindowPoStPartitionSectors: 2, }, stabi.RegisteredPoStProof_StackedDrgWindow8MiBV1: { WindowPoStPartitionSectors: 2, }, stabi.RegisteredPoStProof_StackedDrgWindow512MiBV1: { WindowPoStPartitionSectors: 2, }, stabi.RegisteredPoStProof_StackedDrgWindow32GiBV1: { WindowPoStPartitionSectors: 2349, }, stabi.RegisteredPoStProof_StackedDrgWindow64GiBV1: { WindowPoStPartitionSectors: 2300, }, }
Partition sizes must match those used by the proofs library. See https://github.com/filecoin-project/rust-fil-proofs/blob/master/filecoin-proofs/src/constants.rs#L85
var QualityBaseMultiplier = big.NewInt(10)
Quality multiplier for committed capacity (no deals) in a sector
var SealProofPolicies = map[stabi.RegisteredSealProof]*SealProofPolicy{ stabi.RegisteredSealProof_StackedDrg2KiBV1: { SectorMaxLifetime: fiveYears, ConsensusMinerMinPower: stabi.NewStoragePower(0), }, stabi.RegisteredSealProof_StackedDrg8MiBV1: { SectorMaxLifetime: fiveYears, ConsensusMinerMinPower: stabi.NewStoragePower(16 << 20), }, stabi.RegisteredSealProof_StackedDrg512MiBV1: { SectorMaxLifetime: fiveYears, ConsensusMinerMinPower: stabi.NewStoragePower(1 << 30), }, stabi.RegisteredSealProof_StackedDrg32GiBV1: { SectorMaxLifetime: fiveYears, ConsensusMinerMinPower: stabi.NewStoragePower(100 << 40), }, stabi.RegisteredSealProof_StackedDrg64GiBV1: { SectorMaxLifetime: fiveYears, ConsensusMinerMinPower: stabi.NewStoragePower(200 << 40), }, }
var TokenPrecision = big.NewIntUnsigned(1_000_000_000_000_000_000)
Number of token units in an abstract "FIL" token. The network works purely in the indivisible token amounts. This constant converts to a fixed decimal with more human-friendly scale.
var TotalFilecoin = big.Mul(big.NewIntUnsigned(2_000_000_000), TokenPrecision)
The maximum supply of Filecoin that will ever exist (in token units)
var VerifiedDealWeightMultiplier = big.NewInt(100)
Quality multiplier for verified deals in a sector
Functions ¶
func ActorNameByCode ¶
func ActorNameByCode(code cid.Cid) string
ActorNameByCode returns the (string) name of the actor given a cid code.
func ConsensusMinerMinPower ¶ added in v0.9.4
func ConsensusMinerMinPower(p stabi.RegisteredSealProof) (stabi.StoragePower, error)
The minimum power of an individual miner to meet the threshold for leader election (in bytes). Motivation: - Limits sybil generation - Improves consensus fault detection - Guarantees a minimum fee for consensus faults - Ensures that a specific soundness for the power table Note: We may be able to reduce this in the future, addressing consensus faults with more complicated penalties, sybil generation with crypto-economic mechanism, and PoSt soundness by increasing the challenges for small miners.
func IsBuiltinActor ¶
func IsBuiltinActor(code cid.Cid) bool
IsBuiltinActor returns true if the code belongs to an actor defined in this repo.
func IsPrincipal ¶
func IsPrincipal(code cid.Cid) bool
Tests whether a code CID represents an actor that can be an external principal: i.e. an account or multisig. We could do something more sophisticated here: https://github.com/filecoin-project/specs-actors/issues/178
func PoStProofWindowPoStPartitionSectors ¶ added in v0.9.4
func PoStProofWindowPoStPartitionSectors(p stabi.RegisteredPoStProof) (uint64, error)
Returns the partition size, in sectors, associated with a Window PoSt proof type. The partition size is the number of sectors proved in a single PoSt proof.
func RequireNoErr ¶
func RequireNoErr(rt runtime.Runtime, err error, defaultExitCode exitcode.ExitCode, msg string, args ...interface{})
Aborts with a formatted message if err is not nil. The provided message will be suffixed by ": %s" and the provided args suffixed by the err.
func RequireParam ¶ added in v0.7.0
Aborts with an ErrIllegalArgument if predicate is not true.
func RequireSuccess ¶
Propagates a failed send by aborting the current method with the same exit code.
func ResolveToIDAddr ¶ added in v0.9.2
ResolveToIDAddr resolves the given address to it's ID address form. If an ID address for the given address dosen't exist yet, it tries to create one by sending a zero balance to the given address.
func SealProofSectorMaximumLifetime ¶ added in v0.9.4
func SealProofSectorMaximumLifetime(p stabi.RegisteredSealProof) (stabi.ChainEpoch, error)
SectorMaximumLifetime is the maximum duration a sector sealed with this proof may exist between activation and expiration
func SealProofWindowPoStPartitionSectors ¶ added in v0.9.4
func SealProofWindowPoStPartitionSectors(p stabi.RegisteredSealProof) (uint64, error)
Returns the partition size, in sectors, associated with a seal proof type. The partition size is the number of sectors proved in a single PoSt proof.
Types ¶
type ConfirmSectorProofsParams ¶ added in v0.5.4
type ConfirmSectorProofsParams struct {
Sectors []abi.SectorNumber
}
func (*ConfirmSectorProofsParams) MarshalCBOR ¶ added in v0.5.4
func (t *ConfirmSectorProofsParams) MarshalCBOR(w io.Writer) error
func (*ConfirmSectorProofsParams) UnmarshalCBOR ¶ added in v0.5.4
func (t *ConfirmSectorProofsParams) UnmarshalCBOR(r io.Reader) error
type MinerAddrs ¶
This type duplicates the Miner.ControlAddresses return type, to work around a circular dependency between actors.
func (*MinerAddrs) MarshalCBOR ¶
func (t *MinerAddrs) MarshalCBOR(w io.Writer) error
func (*MinerAddrs) UnmarshalCBOR ¶
func (t *MinerAddrs) UnmarshalCBOR(r io.Reader) error
type PoStProofPolicy ¶ added in v0.9.13
type PoStProofPolicy struct {
WindowPoStPartitionSectors uint64
}
Policy values associated with a PoSt proof type.
type SealProofPolicy ¶ added in v0.9.4
type SealProofPolicy struct { SectorMaxLifetime stabi.ChainEpoch ConsensusMinerMinPower stabi.StoragePower }
Policy values associated with a seal proof type.