Documentation ¶
Overview ¶
Package host is an implementation of the host module, and is responsible for participating in the storage ecosystem, turning available disk space an internet bandwidth into profit for the user.
Index ¶
- Constants
- Variables
- type ErrorCommunication
- type ErrorConnection
- type ErrorConsensus
- type ErrorInternal
- type Host
- func New(cs modules.ConsensusSet, g modules.Gateway, tpool modules.TransactionPool, ...) (*Host, error)
- func NewBlockedStartHost(deps modules.Dependencies, smDeps modules.Dependencies, ...) (*Host, <-chan error)
- func NewCustomHost(deps modules.Dependencies, cs modules.ConsensusSet, g modules.Gateway, ...) (*Host, error)
- func NewCustomTestHost(deps modules.Dependencies, smDeps modules.Dependencies, ...) (*Host, error)
- func (h *Host) Alerts() (crit, err, warn []modules.Alert)
- func (h *Host) Announce() error
- func (h *Host) AnnounceAddress(addr modules.NetAddress) error
- func (h *Host) Announcement() []byte
- func (h *Host) AuditStorageObligations()
- func (h *Host) BandwidthCounters() (uint64, uint64, time.Time, error)
- func (h *Host) BlockHeight() types.BlockHeight
- func (h *Host) CleanAndCompactDB() error
- func (h *Host) Close() error
- func (h *Host) ConnectabilityStatus() modules.HostConnectabilityStatus
- func (h *Host) ExternalSettings() modules.HostExternalSettings
- func (h *Host) FinancialMetrics() modules.HostFinancialMetrics
- func (h *Host) InternalSettings() modules.HostInternalSettings
- func (h *Host) ManagedExternalSettings() modules.HostExternalSettings
- func (h *Host) MoveTokenSectorsToStorageObligation(fcID types.FileContractID, renterRevision types.FileContractRevision, ...) ([]byte, error)
- func (h *Host) NetAddress() modules.NetAddress
- func (h *Host) NetworkMetrics() modules.HostNetworkMetrics
- func (h *Host) ProcessConsensusChange(cc modules.ConsensusChange)
- func (h *Host) PublicKey() types.SiaPublicKey
- func (h *Host) ReadyToServe() bool
- func (h *Host) SetInternalSettings(settings modules.HostInternalSettings) error
- func (h *Host) StorageObligation(obligationID types.FileContractID) (modules.StorageObligation, error)
- func (h *Host) StorageObligations() (sos []modules.StorageObligation)
- func (h *Host) WorkingStatus() modules.HostWorkingStatus
- type HostMock
- type StorageObligationSnapshot
- func (sos StorageObligationSnapshot) ContractSize() uint64
- func (sos StorageObligationSnapshot) MerkleRoot() crypto.Hash
- func (sos StorageObligationSnapshot) ProofDeadline() types.BlockHeight
- func (sos StorageObligationSnapshot) RecentRevision() types.FileContractRevision
- func (sos StorageObligationSnapshot) RevisionTxn() types.Transaction
- func (sos StorageObligationSnapshot) SectorRoots() []crypto.Hash
- func (sos StorageObligationSnapshot) UnallocatedCollateral() types.Currency
Constants ¶
const ( // AlertMSGHostInsufficientCollateral indicates that a host has insufficient // collateral budget remaining AlertMSGHostInsufficientCollateral = "host has insufficient collateral budget" )
Constants related to the host's alerts.
Variables ¶
var ( // ErrBadContractOutputCounts is returned if the presented file contract // revision has the wrong number of outputs for either the valid or the // missed proof outputs. ErrBadContractOutputCounts = ErrorCommunication("rejected for having an unexpected number of outputs") // ErrBadContractParent is returned when a file contract revision is // presented which has a parent id that doesn't match the file contract // which is supposed to be getting revised. ErrBadContractParent = ErrorCommunication("could not find contract's parent") // ErrBadFileMerkleRoot is returned if the renter incorrectly updates the // file merkle root during a file contract revision. ErrBadFileMerkleRoot = ErrorCommunication("rejected for bad file merkle root") // ErrBadFileSize is returned if the renter incorrectly download and // changes the file size during a file contract revision. ErrBadFileSize = ErrorCommunication("rejected for bad file size") // ErrBadModificationIndex is returned if the renter requests a change on a // sector root that is not in the file contract. ErrBadModificationIndex = ErrorCommunication("renter has made a modification that points to a nonexistent sector") // ErrBadParentID is returned if the renter incorrectly download and // provides the wrong parent id during a file contract revision. ErrBadParentID = ErrorCommunication("rejected for bad parent id") // ErrBadPayoutUnlockHashes is returned if the renter incorrectly sets the // payout unlock hashes during contract formation. ErrBadPayoutUnlockHashes = ErrorCommunication("rejected for bad unlock hashes in the payout") // ErrBadRevisionNumber number is returned if the renter incorrectly // download and does not increase the revision number during a file // contract revision. ErrBadRevisionNumber = ErrorCommunication("rejected for bad revision number") // ErrBadSectorSize is returned if the renter provides a sector to be // inserted that is the wrong size. ErrBadSectorSize = ErrorCommunication("renter has provided an incorrectly sized sector") // ErrBadUnlockConditions is returned if the renter incorrectly download // and does not provide the right unlock conditions in the payment // revision. ErrBadUnlockConditions = ErrorCommunication("rejected for bad unlock conditions") // ErrBadUnlockHash is returned if the renter incorrectly updates the // unlock hash during a file contract revision. ErrBadUnlockHash = ErrorCommunication("rejected for bad new unlock hash") // ErrBadWindowEnd is returned if the renter incorrectly download and // changes the window end during a file contract revision. ErrBadWindowEnd = ErrorCommunication("rejected for bad new window end") // ErrBadWindowStart is returned if the renter incorrectly updates the // window start during a file contract revision. ErrBadWindowStart = ErrorCommunication("rejected for bad new window start") // ErrEarlyWindow is returned if the file contract provided by the renter // has a storage proof window that is starting too near in the future. ErrEarlyWindow = ErrorCommunication("rejected for a window that starts too soon") // ErrEmptyObject is returned if the renter sends an empty or nil object // unexpectedly. ErrEmptyObject = ErrorCommunication("renter has unexpectedly send an empty/nil object") // ErrHighRenterMissedOutput is returned if the renter incorrectly download // and deducts an insufficient amount from the renter missed outputs during // a file contract revision. ErrHighRenterMissedOutput = ErrorCommunication("rejected for high paying renter missed output") // ErrHighRenterValidOutput is returned if the renter incorrectly download // and deducts an insufficient amount from the renter valid outputs during // a file contract revision. ErrHighRenterValidOutput = ErrorCommunication("rejected for high paying renter valid output") // ErrIllegalOffsetAndLength is returned if the renter tries perform a // modify operation that uses a troublesome combination of offset and // length. ErrIllegalOffsetAndLength = ErrorCommunication("renter is trying to do a modify with an illegal offset and length") // ErrInvalidPayoutSums is returned if a revision doesn't sum up to the same // total payout as the previous revision or contract. ErrInvalidPayoutSums = ErrorCommunication("renter provided a revision with an invalid total payout") // ErrLargeSector is returned if the renter sends a RevisionAction that has // data which creates a sector that is larger than what the host uses. ErrLargeSector = ErrorCommunication("renter has sent a sector that exceeds the host's sector size") // ErrLateRevision is returned if the renter is attempting to revise a // revision after the revision deadline. The host needs time to submit the // final revision to the blockchain to guarantee payment, and therefore // will not accept revisions once the window start is too close. ErrLateRevision = ErrorCommunication("renter is requesting revision after the revision deadline") // ErrLongDuration is returned if the renter proposes a file contract with // an expiration that is too far into the future according to the host's // settings. ErrLongDuration = ErrorCommunication("renter proposed a file contract with a too-long duration") // ErrLowHostMissedOutput is returned if the renter incorrectly updates the // host missed proof output during a file contract revision. ErrLowHostMissedOutput = ErrorCommunication("rejected for low paying host missed output") // ErrLowHostValidOutput is returned if the renter incorrectly updates the // host valid proof output during a file contract revision. ErrLowHostValidOutput = ErrorCommunication("rejected for low paying host valid output") // ErrLowTransactionFees is returned if the renter provides a transaction // that the host does not feel is able to make it onto the blockchain. ErrLowTransactionFees = ErrorCommunication("rejected for including too few transaction fees") // ErrLowVoidOutput is returned if the renter has not allocated enough // funds to the void output. ErrLowVoidOutput = ErrorCommunication("rejected for low value void output") // ErrMismatchedHostPayouts is returned if the renter incorrectly sets the // host valid and missed payouts to different values during contract // formation. ErrMismatchedHostPayouts = ErrorCommunication("rejected because host valid and missed payouts are not the same value") // ErrSmallWindow is returned if the renter suggests a storage proof window // that is too small. ErrSmallWindow = ErrorCommunication("rejected for small window size") // ErrUnknownModification is returned if the host receives a modification // action from the renter that it does not understand. ErrUnknownModification = ErrorCommunication("renter is attempting an action that the host does not understand") // ErrValidHostOutputAddressChanged is returned when the host's valid output // address changed even though it shouldn't. ErrValidHostOutputAddressChanged = ErrorCommunication("valid host output address changed") // ErrMissedHostOutputAddressChanged is returned when the host's missed // payout address changed even though it shouldn't. ErrMissedHostOutputAddressChanged = ErrorCommunication("missed host output address changed") // ErrVoidAddressChanged is returned if the void output address changed. ErrVoidAddressChanged = ErrorCommunication("lost collateral address was changed") // ErrValidRenterPayoutChanged is returned if the renter's valid payout // changed even though it shouldn't. ErrValidRenterPayoutChanged = ErrorCommunication("valid renter payout changed") // ErrMissedRenterPayoutChanged is returned if the renter's missed payout // changed even though it shouldn't. ErrMissedRenterPayoutChanged = ErrorCommunication("missed renter payout changed") // ErrValidHostPayoutChanged is returned if the host's valid payout changed // even though it shouldn't. ErrValidHostPayoutChanged = ErrorCommunication("valid host payout changed") // ErrVoidPayoutChanged is returned if the void payout changed even though // it wasn't expected to. ErrVoidPayoutChanged = ErrorCommunication("void payout shouldn't change") )
var ( // ErrNoStorageObligation is returned if the requested storage obligation // is not found in the database. ErrNoStorageObligation = errors.New("storage obligation not found in database") )
var ( // ErrObligationLocked is returned if the file contract being requested is // currently locked. The lock can be in place if there is a storage proof // being submitted, if there is another renter altering the contract, or if // there have been network connections with have not resolved yet. ErrObligationLocked = errors.New("the requested file contract is currently locked") )
var MaxAllowedUnreferencedSectorsToRemove = 256
MaxAllowedUnreferencedSectorsToRemove is the ceiling for sector removal when removing unconfirmed expired contracts
var UnconfirmedContractDataRetentionPeriod = types.BlocksPerDay * 27
UnconfirmedContractDataRetentionPeriod is the period any unconfirmed contract is taken into account when preserving sector references. The sectors referenced are included in the resulting reference list of host.getReferencedSectorIDs() TODO: decrease the retention period when contract renewal fix proves itself to be effective
Functions ¶
This section is empty.
Types ¶
type ErrorCommunication ¶ added in v1.0.3
type ErrorCommunication string
ErrorCommunication errors are meant to be returned if the host and the renter seem to be miscommunicating. For example, if the renter attempts to pay an insufficient price, there has been a communication error.
func (ErrorCommunication) Error ¶ added in v1.0.3
func (ec ErrorCommunication) Error() string
Error satisfies the Error interface for the ErrorCommunication type.
type ErrorConnection ¶ added in v1.0.3
type ErrorConnection string
ErrorConnection is meant to be used on errors where the network is returning unexpected errors. For example, sudden disconnects or connection write failures.
func (ErrorConnection) Error ¶ added in v1.0.3
func (ec ErrorConnection) Error() string
Error satisfies the Error interface for the ErrorConnection type.
type ErrorConsensus ¶ added in v1.0.3
type ErrorConsensus string
ErrorConsensus errors are meant to be used when there are problems related to consensus, such as an inability to submit a storage proof to the blockchain, or an inability to get a file contract revision on to the blockchain.
func (ErrorConsensus) Error ¶ added in v1.0.3
func (ec ErrorConsensus) Error() string
Error satisfies the Error interface for the ErrorConsensus type.
type ErrorInternal ¶ added in v1.0.3
type ErrorInternal string
ErrorInternal errors are meant to be used if an internal process in the host is malfunctioning, for example if the disk is failing.
func (ErrorInternal) Error ¶ added in v1.0.3
func (ec ErrorInternal) Error() string
Error satisfies the Error interface for the ErrorInternal type.
type Host ¶
type Host struct { // Should be called under mu.RLock and checked for not being nil. modules.StorageManager // contains filtered or unexported fields }
A Host contains all the fields necessary for storing files for clients and performing the storage proofs on the received files.
func New ¶
func New(cs modules.ConsensusSet, g modules.Gateway, tpool modules.TransactionPool, wallet modules.Wallet, address, persistDir string, hostAPIListener net.Listener, checkTokenExpirationFrequency time.Duration) (*Host, error)
New returns an initialized Host.
func NewBlockedStartHost ¶ added in v1.8.3
func NewBlockedStartHost(deps modules.Dependencies, smDeps modules.Dependencies, cs modules.ConsensusSet, g modules.Gateway, tpool modules.TransactionPool, wallet modules.Wallet, address, persistDir string, hostAPIListener net.Listener, checkTokenExpirationFrequency time.Duration, onlyFirstDir bool) (*Host, <-chan error)
NewBlockedStartHost creates and starts host module waiting for consensus sync before subscribing to consensus and starting the API. Returns host and error channel to catch startup errors
func NewCustomHost ¶ added in v1.5.0
func NewCustomHost(deps modules.Dependencies, cs modules.ConsensusSet, g modules.Gateway, tpool modules.TransactionPool, wallet modules.Wallet, address, persistDir string, hostAPIListener net.Listener, checkTokenExpirationFrequency time.Duration) (*Host, error)
NewCustomHost returns an initialized Host using the provided dependencies.
func NewCustomTestHost ¶ added in v1.5.0
func NewCustomTestHost(deps modules.Dependencies, smDeps modules.Dependencies, cs modules.ConsensusSet, g modules.Gateway, tpool modules.TransactionPool, wallet modules.Wallet, address, persistDir string, hostAPIListener net.Listener, checkTokenExpirationFrequency time.Duration, onlyFirstDir bool) (*Host, error)
NewCustomTestHost allows passing in both host dependencies and storage manager dependencies. Used solely for testing purposes, to allow dependency injection into the host's submodules.
func (*Host) AnnounceAddress ¶ added in v1.0.0
func (h *Host) AnnounceAddress(addr modules.NetAddress) error
AnnounceAddress submits a host announcement to the blockchain to announce a specific address. If there is no error, the host's address will be updated to the supplied address.
func (*Host) Announcement ¶ added in v1.6.0
Announcement returns host announcement. For use as ghost.
func (*Host) AuditStorageObligations ¶ added in v1.5.2
func (h *Host) AuditStorageObligations()
AuditStorageObligations locks the host, fetches the set of storage obligations in the host and checks if any old storage obligations are not marked correctly and removed if expired along with stale contract removal
func (*Host) BandwidthCounters ¶ added in v1.5.0
BandwidthCounters returns the Hosts's upload and download bandwidth
func (*Host) BlockHeight ¶ added in v1.5.0
func (h *Host) BlockHeight() types.BlockHeight
BlockHeight returns the host's current blockheight.
func (*Host) CleanAndCompactDB ¶ added in v1.9.3
CleanAndCompactDB is a function that cleans and compacts the host's contract database. This function is intended to be used for optimizing the host's database size and performance. It is not guaranteed to reduce the database size to a minimum, but it should help to free up some disk space and improve the database's performance. It does all the work under a general host module lock thus the host is effectively offline.
func (*Host) ConnectabilityStatus ¶ added in v1.2.0
func (h *Host) ConnectabilityStatus() modules.HostConnectabilityStatus
ConnectabilityStatus returns the connectability state of the host, whether the host can connect to itself on its configured netaddress.
func (*Host) ExternalSettings ¶ added in v1.0.0
func (h *Host) ExternalSettings() modules.HostExternalSettings
ExternalSettings returns the hosts external settings. These values cannot be set by the user (host is configured through InternalSettings), and are the values that get displayed to other hosts on the network.
func (*Host) FinancialMetrics ¶ added in v1.0.0
func (h *Host) FinancialMetrics() modules.HostFinancialMetrics
FinancialMetrics returns information about the financial commitments, rewards, and activities of the host.
func (*Host) InternalSettings ¶ added in v1.0.0
func (h *Host) InternalSettings() modules.HostInternalSettings
InternalSettings returns the settings of a host.
func (*Host) ManagedExternalSettings ¶ added in v1.6.0
func (h *Host) ManagedExternalSettings() modules.HostExternalSettings
ManagedExternalSettings returns the host's external settings. These values cannot be set by the user (host is configured through InternalSettings), and are the values that get displayed to other hosts on the network.
func (*Host) MoveTokenSectorsToStorageObligation ¶ added in v1.6.0
func (h *Host) MoveTokenSectorsToStorageObligation(fcID types.FileContractID, renterRevision types.FileContractRevision, sectorsWithTokens []types.SectorWithToken, renterSig []byte) ([]byte, error)
MoveTokenSectorsToStorageObligation moves sectors from temporary storage to storage obligation object and returns host signature.
func (*Host) NetAddress ¶ added in v1.0.0
func (h *Host) NetAddress() modules.NetAddress
NetAddress returns the address at which the host can be reached.
func (*Host) NetworkMetrics ¶ added in v1.0.0
func (h *Host) NetworkMetrics() modules.HostNetworkMetrics
NetworkMetrics returns information about the types of rpc calls that have been made to the host.
func (*Host) ProcessConsensusChange ¶ added in v1.0.0
func (h *Host) ProcessConsensusChange(cc modules.ConsensusChange)
ProcessConsensusChange will be called by the consensus set every time there is a change to the blockchain.
func (*Host) PublicKey ¶ added in v1.1.1
func (h *Host) PublicKey() types.SiaPublicKey
PublicKey returns the public key of the host that is used to facilitate relationships between the host and renter.
func (*Host) ReadyToServe ¶ added in v1.8.3
ReadyToServe tells if the host module is ready to serve API calls.
func (*Host) SetInternalSettings ¶ added in v1.0.0
func (h *Host) SetInternalSettings(settings modules.HostInternalSettings) error
SetInternalSettings updates the host's internal HostInternalSettings object.
func (*Host) StorageObligation ¶ added in v1.5.2
func (h *Host) StorageObligation(obligationID types.FileContractID) (modules.StorageObligation, error)
StorageObligation returns the storage obligation matching the id or an error if it does not exist.
func (*Host) StorageObligations ¶ added in v1.1.2
func (h *Host) StorageObligations() (sos []modules.StorageObligation)
StorageObligations fetches the set of storage obligations in the host and returns metadata on them.
func (*Host) WorkingStatus ¶ added in v1.2.0
func (h *Host) WorkingStatus() modules.HostWorkingStatus
WorkingStatus returns the working state of the host, where working is defined as having received more than workingStatusThreshold settings calls over the period of workingStatusFrequency.
type HostMock ¶ added in v1.6.0
type HostMock struct { CS modules.ConsensusSet Gateway modules.Gateway Miner modules.TestMiner Tpool modules.TransactionPool HostWallet modules.Wallet RenterWallet modules.Wallet Host *Host }
HostMock is almost full copy of the hostTester.
func NewHostMock ¶ added in v1.6.0
func NewHostMock(d modules.Dependencies, dirName string) (*HostMock, error)
NewHostMock creates new public host mock based on private therefore do not affect old tests.
type StorageObligationSnapshot ¶ added in v1.5.0
type StorageObligationSnapshot struct {
// contains filtered or unexported fields
}
StorageObligationSnapshot is a snapshot of a StorageObligation. A snapshot is a deep-copy and can be accessed without locking at the cost of being a frozen readonly representation of an SO which only exists in memory. Note that this snapshot only contains the properties required by the MDM to execute a program. This can be extended in the future to support other use cases.
func ZeroStorageObligationSnapshot ¶ added in v1.5.0
func ZeroStorageObligationSnapshot() StorageObligationSnapshot
ZeroStorageObligationSnapshot returns the storage obligation snapshot of an empty contract. All fields are set to the defaults.
func (StorageObligationSnapshot) ContractSize ¶ added in v1.5.0
func (sos StorageObligationSnapshot) ContractSize() uint64
ContractSize returns the size of the underlying contract, which is static and is the value of the contract size at the time the snapshot was taken.
func (StorageObligationSnapshot) MerkleRoot ¶ added in v1.5.0
func (sos StorageObligationSnapshot) MerkleRoot() crypto.Hash
MerkleRoot returns the merkle root, which is static and is the value of the merkle root at the time the snapshot was taken.
func (StorageObligationSnapshot) ProofDeadline ¶ added in v1.5.0
func (sos StorageObligationSnapshot) ProofDeadline() types.BlockHeight
ProofDeadline returns the proof deadline of the underlying contract.
func (StorageObligationSnapshot) RecentRevision ¶ added in v1.5.0
func (sos StorageObligationSnapshot) RecentRevision() types.FileContractRevision
RecentRevision returns the recent revision at the time the snapshot was taken.
func (StorageObligationSnapshot) RevisionTxn ¶ added in v1.5.0
func (sos StorageObligationSnapshot) RevisionTxn() types.Transaction
RevisionTxn returns the txn containing the filecontract revision.
func (StorageObligationSnapshot) SectorRoots ¶ added in v1.5.0
func (sos StorageObligationSnapshot) SectorRoots() []crypto.Hash
SectorRoots returns a static list of the sector roots present at the time the snapshot was taken.
func (StorageObligationSnapshot) UnallocatedCollateral ¶ added in v1.5.0
func (sos StorageObligationSnapshot) UnallocatedCollateral() types.Currency
UnallocatedCollateral returns the remaining collateral within the contract that hasn't been allocated yet. This means it is not yet moved to the void in case of a missed storage proof.
Source Files ¶
- alert.go
- announce.go
- consts.go
- dependencies.go
- errors.go
- financialmetrics.go
- host.go
- negotiate.go
- negotiatedownload.go
- negotiateformcontract.go
- negotiaterecentrevision.go
- negotiaterenewcontract.go
- negotiaterevisecontract.go
- negotiatesettings.go
- network.go
- newHostBlockedStartup.go
- newrpc.go
- payment.go
- persist.go
- pricing.go
- removeobsoletefiles.go
- rpcloop.go
- storagecleanup.go
- storageobligations.go
- storageobligationslock.go
- storageobligationstatus.go
- test_common.go
- update.go
- upnp.go