Documentation ¶
Overview ¶
Package modules contains definitions for all of the major modules of Sia, as well as some helper functions for performing actions that are common to multiple modules.
Index ¶
- Constants
- Variables
- func AddCommas(v uint64) string
- func BackupSkylink(skylink string, baseSector []byte, reader io.Reader, writer io.Writer) error
- func BandwidthUnits(bps uint64) string
- func BuildBaseSector(layoutBytes, fanoutBytes, metadataBytes, fileBytes []byte) ([]byte, uint64)
- func CalculateFee(ts []types.Transaction) types.Currency
- func CreateAnnouncement(addr NetAddress, pk types.SiaPublicKey, sk crypto.SecretKey) (signedAnnouncement []byte, err error)
- func CurrencyUnits(c types.Currency) string
- func DecodeFanout(sl SkyfileLayout, fanoutBytes []byte) (piecesPerChunk, chunkRootsSize, numChunks uint64, err error)
- func DecryptBaseSector(baseSector []byte, sk skykey.Skykey) (skykey.Skykey, error)
- func DeriveFanoutKey(sl *SkyfileLayout, fileSkykey skykey.Skykey) (crypto.CipherKey, error)
- func EnsurePrefix(str, prefix string) string
- func EnsureSuffix(str, suffix string) string
- func ExtractSegment(pieces [][]byte, segmentIndex int, segmentSize uint64) [][]byte
- func FilesizeUnits(size uint64) string
- func GenerateContractKeyPair(renterSeed EphemeralRenterSeed, txn types.Transaction) (sk crypto.SecretKey, pk crypto.PublicKey)
- func GenerateContractKeyPairWithOutputID(renterSeed EphemeralRenterSeed, inputParentID types.SiacoinOutputID) (sk crypto.SecretKey, pk crypto.PublicKey)
- func HealthPercentage(health float64) float64
- func IsConsensusConflict(err error) bool
- func IsContractNotRecognizedErr(err error) bool
- func IsEncryptedBaseSector(baseSector []byte) bool
- func IsEncryptedLayout(sl SkyfileLayout) bool
- func IsHostsFault(err error) bool
- func IsOOSErr(err error) bool
- func MDMAppendCollateral(pt *RPCPriceTable) types.Currency
- func MDMAppendCost(pt *RPCPriceTable, duration types.BlockHeight) (types.Currency, types.Currency)
- func MDMAppendMemory() uint64
- func MDMBandwidthCost(pt RPCPriceTable, uploadBandwidth, downloadBandwidth uint64) types.Currency
- func MDMCopyCost(pt RPCPriceTable, contractSize uint64) types.Currency
- func MDMDropSectorsCollateral() types.Currency
- func MDMDropSectorsCost(pt *RPCPriceTable, numSectorsDropped uint64) types.Currency
- func MDMDropSectorsMemory() uint64
- func MDMDropSectorsTime(numSectorsDropped uint64) uint64
- func MDMHasSectorCollateral() types.Currency
- func MDMHasSectorCost(pt *RPCPriceTable) types.Currency
- func MDMHasSectorMemory() uint64
- func MDMInitCost(pt *RPCPriceTable, programLen, numInstructions uint64) types.Currency
- func MDMInitMemory() uint64
- func MDMMemoryCost(pt *RPCPriceTable, usedMemory, time uint64) types.Currency
- func MDMReadCollateral() types.Currency
- func MDMReadCost(pt *RPCPriceTable, readLength uint64) types.Currency
- func MDMReadMemory() uint64
- func MDMReadRegistryCollateral() types.Currency
- func MDMReadRegistryCost(pt *RPCPriceTable) (_, _ types.Currency)
- func MDMReadRegistryMemory() uint64
- func MDMRevisionCollateral() types.Currency
- func MDMRevisionCost(pt *RPCPriceTable) types.Currency
- func MDMRevisionMemory() uint64
- func MDMSubscribeCost(pt *RPCPriceTable, nFound, nEntries uint64) types.Currency
- func MDMSubscriptionMemoryCost(pt *RPCPriceTable, nEntries uint64) types.Currency
- func MDMSwapCost(pt *RPCPriceTable, contractSize uint64) types.Currency
- func MDMSwapSectorCollateral() types.Currency
- func MDMSwapSectorCost(pt *RPCPriceTable) types.Currency
- func MDMSwapSectorMemory() uint64
- func MDMTruncateCost(pt *RPCPriceTable, contractSize uint64) types.Currency
- func MDMUpdateRegistryCollateral() types.Currency
- func MDMUpdateRegistryCost(pt *RPCPriceTable) (_, _ types.Currency)
- func MDMUpdateRegistryMemory() uint64
- func MDMWriteCost(pt *RPCPriceTable, writeLength uint64) types.Currency
- func NewMultipartReader(reader io.Reader, subFiles SkyfileSubfiles) (*multipart.Reader, error)
- func NewRenterSession(conn net.Conn, hostPublicKey types.SiaPublicKey) (*RenterHostSession, LoopChallengeRequest, error)
- func NewSiaMux(siaMuxDir, siaDir, tcpaddress, wsaddress string) (*siamux.SiaMux, error)
- func ParseSkyfileMetadata(baseSector []byte) (sl SkyfileLayout, fanoutBytes []byte, sm SkyfileMetadata, ...)
- func PeekErr(errChan <-chan error) (err error)
- func PrintAlerts(alerts []Alert, as AlertSeverity)
- func RPCRead(r io.Reader, obj interface{}) error
- func RPCReadMaxLen(r io.Reader, obj interface{}, maxLen uint64) error
- func RPCWrite(w io.Writer, obj interface{}) error
- func RPCWriteAll(w io.Writer, objs ...interface{}) error
- func RPCWriteError(w io.Writer, err error) error
- func ReadNegotiationAcceptance(r io.Reader) error
- func ReadRPCID(r io.Reader, aead cipher.AEAD) (rpcID types.Specifier, err error)
- func ReadRPCMessage(r io.Reader, aead cipher.AEAD, obj interface{}, maxLen uint64) error
- func ReadRPCRequest(r io.Reader, aead cipher.AEAD, req interface{}, maxLen uint64) error
- func ReadRPCResponse(r io.Reader, aead cipher.AEAD, resp interface{}, maxLen uint64) error
- func RenewBaseCosts(lastRev types.FileContractRevision, pt *RPCPriceTable, ...) (basePrice, baseCollateral types.Currency)
- func RenterPayoutsPreTax(host HostDBEntry, funding, txnFee, basePrice, baseCollateral types.Currency, ...) (renterPayout, hostPayout, hostCollateral types.Currency, err error)
- func RestoreSkylink(r io.Reader) (string, []byte, error)
- func RoundRegistrySize(size uint64) uint64
- func SeedToString(seed Seed, did mnemonics.DictionaryID) (string, error)
- func SiaPKToMuxPK(spk types.SiaPublicKey) (mk mux.ED25519PublicKey)
- func SkyfileMetadataBytes(sm SkyfileMetadata) ([]byte, error)
- func SkylinkFromSysPath(path string) string
- func SkylinkToSysPath(skylinkStr string) string
- func V154MDMReadRegistryCost(pt *RPCPriceTable) (_ types.Currency)
- func V154MDMUpdateRegistryCost(pt *RPCPriceTable) (_, _ types.Currency)
- func ValidatePathString(path string, isRoot bool) error
- func ValidateSkyfileMetadata(metadata SkyfileMetadata) error
- func VerifyFileContractRevisionTransactionSignatures(fcr types.FileContractRevision, tsigs []types.TransactionSignature, ...) error
- func VerifyRenewalTransactionSignatures(fcr types.FileContractRevision, fc types.FileContract, ...) error
- func WriteNegotiationAcceptance(w io.Writer) error
- func WriteNegotiationRejection(w io.Writer, err error) error
- func WriteNegotiationStop(w io.Writer) error
- func WriteRPCMessage(w io.Writer, aead cipher.AEAD, obj interface{}) error
- func WriteRPCRequest(w io.Writer, aead cipher.AEAD, rpcID types.Specifier, req interface{}) error
- func WriteRPCResponse(w io.Writer, aead cipher.AEAD, resp interface{}, err error) error
- type AccountBalanceRequest
- type AccountBalanceResponse
- type AccountID
- func (aid *AccountID) FromSPK(spk types.SiaPublicKey)
- func (aid AccountID) IsZeroAccount() bool
- func (aid *AccountID) LoadString(s string) error
- func (aid AccountID) MarshalSia(w io.Writer) error
- func (aid AccountID) PK() (pk crypto.PublicKey)
- func (aid AccountID) SPK() (spk types.SiaPublicKey)
- func (aid *AccountID) UnmarshalSia(r io.Reader) error
- type Alert
- type AlertID
- type AlertSeverity
- type Alerter
- type Allowance
- type AppFee
- type AppFeeByTimestamp
- type AppUID
- type BlockFacts
- type BlockManager
- type BudgetLimit
- type CPUMiner
- type CombinedChunkID
- type ConsensusChange
- type ConsensusChangeDiffs
- type ConsensusChangeID
- type ConsensusConflict
- type ConsensusSet
- type ConsensusSetSubscriber
- type ContractParams
- type ContractSignedIdentifier
- type ContractUtility
- type ContractWatchStatus
- type ContractorChurnStatus
- type ContractorSpending
- type DataSourceID
- type DelayedSiacoinOutputDiff
- type Dependencies
- type DiffDirection
- type DirListFunc
- type DirectoryInfo
- type DownloadAction
- type DownloadID
- type DownloadInfo
- type EncryptionManager
- type EphemeralRenterSeed
- type ErasureCoder
- type ErasureCoderIdentifier
- type ErasureCoderType
- type Explorer
- type FeeManager
- type FeeUID
- type File
- type FileContractDiff
- type FileInfo
- type FileListFunc
- type FilePlacement
- type FileUploadParams
- type FilterMode
- type FundAccountRequest
- type FundAccountResponse
- type Gateway
- type GenericAlerter
- type HalfLifeDistribution
- type Host
- type HostAnnouncement
- type HostConnectabilityStatus
- type HostDB
- type HostDBEntry
- type HostDBScan
- type HostDBScans
- type HostExternalSettings
- type HostFinancialMetrics
- type HostInternalSettings
- type HostNetworkMetrics
- type HostOldExternalSettings
- type HostScoreBreakdown
- type HostWorkingStatus
- type Instruction
- func NewAppendInstruction(dataOffset uint64, merkleProof bool) Instruction
- func NewDropSectorsInstruction(numSectorsOffset uint64, merkleProof bool) Instruction
- func NewHasSectorInstruction(merkleRootOffset uint64) Instruction
- func NewReadOffsetInstruction(lengthOffset, offsetOffset uint64, merkleProof bool) Instruction
- func NewReadRegistryInstruction(pubKeyOff, pubKeyLen, tweakOff uint64) Instruction
- func NewReadSectorInstruction(lengthOffset, offsetOffset, merkleRootOffset uint64, merkleProof bool) Instruction
- func NewRevisionInstruction(merkleRootOffset uint64) Instruction
- func NewSwapSectorInstruction(sector1Offset, sector2Offset uint64, merkleProof bool) Instruction
- func NewUpdateRegistryInstruction(...) Instruction
- func RPCHasSectorInstruction(merkleRootOffset uint64) Instruction
- func RPCIReadSector(rootOff, offsetOff, lengthOff uint64, merkleProof bool) Instruction
- type InstructionSpecifier
- type KeyManager
- type LoopChallengeRequest
- type LoopContractAdditions
- type LoopContractSignatures
- type LoopFormContractRequest
- type LoopKeyExchangeRequest
- type LoopKeyExchangeResponse
- type LoopLockRequest
- type LoopLockResponse
- type LoopReadRequest
- type LoopReadRequestSection
- type LoopReadResponse
- type LoopRenewAndClearContractRequest
- type LoopRenewAndClearContractSignatures
- type LoopRenewContractRequest
- type LoopSectorRootsRequest
- type LoopSectorRootsResponse
- type LoopSettingsResponse
- type LoopWriteAction
- type LoopWriteMerkleProof
- type LoopWriteRequest
- type LoopWriteResponse
- type MDMCancellationToken
- type MDMInstructionRevisionResponse
- type MemoryManagerStatus
- type MemoryStatus
- type MerkleRootSet
- type Miner
- type MountInfo
- type MountOptions
- type NetAddress
- type PartialChunk
- type PassthroughErasureCoder
- func (pec *PassthroughErasureCoder) Encode(data []byte) ([][]byte, error)
- func (pec *PassthroughErasureCoder) EncodeShards(pieces [][]byte) ([][]byte, error)
- func (pec *PassthroughErasureCoder) Identifier() ErasureCoderIdentifier
- func (pec *PassthroughErasureCoder) MinPieces() int
- func (pec *PassthroughErasureCoder) NumPieces() int
- func (pec *PassthroughErasureCoder) Reconstruct(pieces [][]byte) error
- func (pec *PassthroughErasureCoder) Recover(pieces [][]byte, n uint64, w io.Writer) error
- func (pec *PassthroughErasureCoder) SupportsPartialEncoding() (uint64, bool)
- func (pec *PassthroughErasureCoder) Type() ErasureCoderType
- type PayByContractRequest
- type PayByContractResponse
- type PayByEphemeralAccountRequest
- type PaymentDetails
- type PaymentProcessor
- type PaymentProvider
- type PaymentRequest
- type Peer
- type PeerConn
- type ProcessedInput
- type ProcessedOutput
- type ProcessedTransaction
- type ProductionDependencies
- func (*ProductionDependencies) AtLeastOne() uint64
- func (pd *ProductionDependencies) CreateFile(s string) (File, error)
- func (pd *ProductionDependencies) Destruct()
- func (*ProductionDependencies) DialTimeout(addr NetAddress, timeout time.Duration) (net.Conn, error)
- func (*ProductionDependencies) Disrupt(string) bool
- func (*ProductionDependencies) Listen(s1, s2 string) (net.Listener, error)
- func (*ProductionDependencies) LoadFile(meta persist.Metadata, data interface{}, filename string) error
- func (*ProductionDependencies) LookupIP(host string) ([]net.IP, error)
- func (*ProductionDependencies) MkdirAll(s string, fm os.FileMode) error
- func (*ProductionDependencies) NebulousAddress() types.UnlockHash
- func (*ProductionDependencies) NewLogger(s string) (*persist.Logger, error)
- func (pd *ProductionDependencies) Open(s string) (File, error)
- func (*ProductionDependencies) OpenDatabase(m persist.Metadata, s string) (*persist.BoltDatabase, error)
- func (pd *ProductionDependencies) OpenFile(s string, i int, fm os.FileMode) (File, error)
- func (*ProductionDependencies) RandRead(b []byte) (int, error)
- func (*ProductionDependencies) ReadFile(s string) ([]byte, error)
- func (pd *ProductionDependencies) RemoveFile(s string) error
- func (pd *ProductionDependencies) RenameFile(s1 string, s2 string) error
- func (*ProductionDependencies) Resolver() Resolver
- func (*ProductionDependencies) SaveFileSync(meta persist.Metadata, data interface{}, filename string) error
- func (*ProductionDependencies) Sleep(d time.Duration)
- func (*ProductionDependencies) Symlink(s1, s2 string) error
- func (*ProductionDependencies) WriteFile(s string, b []byte, fm os.FileMode) error
- type ProductionFile
- type ProductionResolver
- type Program
- type ProgramBuilder
- func (pb *ProgramBuilder) AddAppendInstruction(data []byte, merkleProof bool) error
- func (pb *ProgramBuilder) AddDropSectorsInstruction(numSectors uint64, merkleProof bool)
- func (pb *ProgramBuilder) AddHasSectorInstruction(merkleRoot crypto.Hash)
- func (pb *ProgramBuilder) AddReadOffsetInstruction(length, offset uint64, merkleProof bool)
- func (pb *ProgramBuilder) AddReadRegistryInstruction(spk types.SiaPublicKey, tweak crypto.Hash) (types.Currency, error)
- func (pb *ProgramBuilder) AddReadSectorInstruction(length, offset uint64, merkleRoot crypto.Hash, merkleProof bool)
- func (pb *ProgramBuilder) AddRevisionInstruction()
- func (pb *ProgramBuilder) AddSwapSectorInstruction(sector1Idx, sector2Idx uint64, merkleProof bool)
- func (pb *ProgramBuilder) AddUpdateRegistryInstruction(spk types.SiaPublicKey, rv SignedRegistryValue) error
- func (pb *ProgramBuilder) Cost(finalized bool) (cost, storage, collateral types.Currency)
- func (pb *ProgramBuilder) Program() (Program, ProgramData)
- func (pb *ProgramBuilder) V154AddReadRegistryInstruction(spk types.SiaPublicKey, tweak crypto.Hash) (types.Currency, error)
- func (pb *ProgramBuilder) V154AddUpdateRegistryInstruction(spk types.SiaPublicKey, rv SignedRegistryValue) error
- type ProgramData
- type RPCBudget
- type RPCError
- type RPCExecuteProgramRequest
- type RPCExecuteProgramResponse
- type RPCExecuteProgramRevisionSigningRequest
- type RPCExecuteProgramRevisionSigningResponse
- type RPCFunc
- type RPCLatestRevisionRequest
- type RPCLatestRevisionResponse
- type RPCPriceTable
- type RPCRegistrySubscriptionNotificationEntryUpdate
- type RPCRegistrySubscriptionNotificationType
- type RPCRegistrySubscriptionRequest
- type RPCRenewContractCollateralResponse
- type RPCRenewContractHostSignatures
- type RPCRenewContractRenterSignatures
- type RPCRenewContractRequest
- type RPCTrackedPriceTableResponse
- type RPCUpdatePriceTableResponse
- type RSCode
- func (rs *RSCode) Encode(data []byte) ([][]byte, error)
- func (rs *RSCode) EncodeShards(pieces [][]byte) ([][]byte, error)
- func (rs *RSCode) Identifier() ErasureCoderIdentifier
- func (rs *RSCode) MinPieces() int
- func (rs *RSCode) NumPieces() int
- func (rs *RSCode) Reconstruct(pieces [][]byte) error
- func (rs *RSCode) Recover(pieces [][]byte, n uint64, w io.Writer) error
- func (rs *RSCode) SupportsPartialEncoding() (uint64, bool)
- func (rs *RSCode) Type() ErasureCoderType
- type RSSubCode
- func (rs *RSSubCode) Encode(data []byte) ([][]byte, error)
- func (rs *RSSubCode) EncodeShards(pieces [][]byte) ([][]byte, error)
- func (rs *RSSubCode) Identifier() ErasureCoderIdentifier
- func (rs *RSSubCode) Reconstruct(pieces [][]byte) error
- func (rs *RSSubCode) Recover(pieces [][]byte, n uint64, w io.Writer) error
- func (rs *RSSubCode) SupportsPartialEncoding() (uint64, bool)
- func (rs *RSSubCode) Type() ErasureCoderType
- type Receipt
- type RecoverableContract
- type RegistryValue
- type Renter
- type RenterContract
- type RenterDownloadParameters
- type RenterHostSession
- func (s *RenterHostSession) ReadRPCID() (rpcID types.Specifier, err error)
- func (s *RenterHostSession) ReadRequest(req interface{}, maxLen uint64) error
- func (s *RenterHostSession) ReadResponse(resp interface{}, maxLen uint64) error
- func (s *RenterHostSession) WriteRequest(rpcID types.Specifier, req interface{}) error
- func (s *RenterHostSession) WriteResponse(resp interface{}, err error) error
- type RenterPriceEstimation
- type RenterSeed
- type RenterSettings
- type RenterStats
- type RequestTimeDistribution
- type Resolver
- type RevisionAction
- type Seed
- type SiaPath
- func (sp SiaPath) AddSuffix(suffix uint) SiaPath
- func (sp SiaPath) Dir() (SiaPath, error)
- func (sp SiaPath) Equals(siaPath SiaPath) bool
- func (sp *SiaPath) FromSysPath(siaFilePath, dir string) (err error)
- func (sp SiaPath) IsEmpty() bool
- func (sp SiaPath) IsRoot() bool
- func (sp SiaPath) Join(s string) (SiaPath, error)
- func (sp *SiaPath) LoadString(s string) error
- func (sp *SiaPath) LoadSysPath(dir, path string) error
- func (sp SiaPath) MarshalJSON() ([]byte, error)
- func (sp SiaPath) Name() string
- func (sp SiaPath) Rebase(oldBase, newBase SiaPath) (SiaPath, error)
- func (sp SiaPath) SiaDirMetadataSysPath(dir string) string
- func (sp SiaPath) SiaDirSysPath(dir string) string
- func (sp SiaPath) SiaFileSysPath(dir string) string
- func (sp SiaPath) SiaPartialsFileSysPath(dir string) string
- func (sp SiaPath) String() string
- func (sp *SiaPath) UnmarshalJSON(b []byte) error
- func (sp SiaPath) Validate(isRoot bool) error
- type SiacoinOutputDiff
- type SiadConfig
- type SiafundOutputDiff
- type SiafundPoolDiff
- type SignedRegistryValue
- type SkyfileBackupHeader
- type SkyfileFormat
- type SkyfileLayout
- type SkyfileMetadata
- type SkyfileMultipartUploadParameters
- type SkyfilePinParameters
- type SkyfileSubfileMetadata
- func (sm SkyfileSubfileMetadata) IsDir() bool
- func (sm SkyfileSubfileMetadata) IsHTML() bool
- func (sm SkyfileSubfileMetadata) ModTime() time.Time
- func (sm SkyfileSubfileMetadata) Mode() os.FileMode
- func (sm SkyfileSubfileMetadata) Name() string
- func (sm SkyfileSubfileMetadata) Size() int64
- func (sm SkyfileSubfileMetadata) Sys() interface{}
- type SkyfileSubfiles
- type SkyfileUploadParameters
- type SkyfileUploadReader
- func NewSkyfileMultipartReader(reader *multipart.Reader, fanoutReader *multipart.Reader, ...) SkyfileUploadReader
- func NewSkyfileMultipartReaderFromRequest(req *http.Request, sup SkyfileUploadParameters) (SkyfileUploadReader, error)
- func NewSkyfileReader(reader io.Reader, sup SkyfileUploadParameters) SkyfileUploadReader
- type Skylink
- func (sl *Skylink) Bitfield() uint16
- func (sl *Skylink) Bytes() []byte
- func (sl Skylink) DataSourceID() DataSourceID
- func (sl Skylink) IsSkylinkV1() bool
- func (sl *Skylink) LoadBytes(data []byte) error
- func (sl *Skylink) LoadString(s string) error
- func (sl Skylink) MerkleRoot() crypto.Hash
- func (sl Skylink) OffsetAndFetchSize() (offset uint64, fetchSize uint64, err error)
- func (sl Skylink) String() string
- func (sl Skylink) Version() uint16
- type SkynetPerformanceStats
- type SkynetPortal
- type SkynetStats
- type StorageFolderMetadata
- type StorageManager
- type StorageObligation
- type Streamer
- type TestMiner
- type TransactionBuilder
- type TransactionPool
- type TransactionPoolDiff
- type TransactionPoolSubscriber
- type TransactionSetID
- type UnconfirmedTransactionSet
- type UniqueID
- type UnspentOutput
- type UploadedBackup
- type UploadsStatus
- type ValuedTransaction
- type Wallet
- type WalletSettings
- type WalletTransactionID
- type WithdrawalMessage
- func (wm *WithdrawalMessage) Validate(blockHeight, expiry types.BlockHeight, hash crypto.Hash, sig crypto.Signature) error
- func (wm *WithdrawalMessage) ValidateExpiry(blockHeight, expiry types.BlockHeight) error
- func (wm *WithdrawalMessage) ValidateSignature(hash crypto.Hash, sig crypto.Signature) error
- type Worker
- type WorkerAccountStatus
- type WorkerGenericJobsStatus
- type WorkerHasSectorJobsStatus
- type WorkerPool
- type WorkerPoolStatus
- type WorkerPriceTableStatus
- type WorkerReadJobsStatus
- type WorkerReadRegistryJobStatus
- type WorkerStatus
- type WorkerUpdateRegistryJobStatus
Constants ¶
const ( // SeverityUnknown is the value of an uninitialized severity and should never // be used. SeverityUnknown = iota // SeverityWarning warns the user about potential issues which might require // preventive actions. SeverityWarning // SeverityError should be used for information about the system where // immediate action is recommended to avoid further issues like loss of data. SeverityError // SeverityCritical should be used for critical errors. e.g. a lack of funds // causing data to get lost without immediate action. SeverityCritical )
The following consts are the different types of severity levels available in the alert system.
const ( // AlertIDWalletLockedDuringMaintenance is the id of the alert that is // registered if the wallet is locked during a contract renewal or formation. AlertIDWalletLockedDuringMaintenance = "wallet-locked" // AlertIDRenterAllowanceLowFunds is the id of the alert that is registered if at least one // contract failed to renew/form due to low allowance. AlertIDRenterAllowanceLowFunds = "low-funds" // AlertIDRenterContractRenewalError is the id of the alert that is // registered if at least once contract renewal or refresh failed AlertIDRenterContractRenewalError = "contract-renewal-error" // AlertIDGatewayOffline is the id of the alert that is registered upon a // call to 'gateway.Offline' if the value returned is 'false' and // unregistered when it returns 'true'. AlertIDGatewayOffline = "gateway-offline" // AlertIDHostDiskTrouble is the id of the alert that is registered when the // host is encountering problems interacting with one or more of his disks AlertIDHostDiskTrouble = "host-disk-trouble" // AlertIDHostInsufficientCollateral is the id of the alert that is // registered if the host has insufficient collateral budget left to form or // renew a contract AlertIDHostInsufficientCollateral = "host-insufficient-collateral" )
The following consts are a list of AlertIDs. All IDs used throughout Sia should be unique and listed here.
const ( // HostDir names the directory that contains the host persistence. HostDir = "host" // HostSettingsFile is the name of the host's persistence file. HostSettingsFile = "host.json" // HostSiaMuxSubscriberName is the name used by the host to register a // listener on the SiaMux. HostSiaMuxSubscriberName = "host" // HostWALFile is the name of the file the host's wal is stored in. HostWALFile = "host.wal" // HostRegistryFile is the name of the file the host's registry is stored // in. HostRegistryFile = "registry.dat" )
const ( // MDMMaxBatchBufferSize is the maximum number of bytes the ExecuteProgram // RPC will buffer in favor of batching fast instructions. MDMMaxBatchBufferSize = 1 << 16 // 64 kib // MDMCancellationTokenLen is the length of a program's cancellation token // in bytes. MDMCancellationTokenLen = 16 )
const ( // MDMTimeAppend is the time for executing an 'Append' instruction. MDMTimeAppend = 10000 // MDMTimeCommit is the time used for executing managedFinalize. // TODO: This should scale with the number of added + removed sectors. MDMTimeCommit = 50e3 // MDMTimeDropSectorsBase is the base time for executing a 'DropSectors' // instruction. MDMTimeDropSectorsBase = 1 // MDMTimeDropSingleSector is the time for dropping a single sector. MDMTimeDropSingleSector = 1 // MDMTimeHasSector is the time for executing a 'HasSector' instruction. MDMTimeHasSector = 1 // MDMTimeInitProgram is the base time for initializing a program. `1` // because no disk IO is involved. MDMTimeInitProgram = 1 // MDMTimeInitSingleInstruction is the time it takes to initialize a single // instruction. MDMTimeInitSingleInstruction = 1 // MDMTimeReadOffset is the time for executing a 'ReadOffset' instruction. MDMTimeReadOffset = 1000 // MDMTimeReadSector is the time for executing a 'ReadSector' instruction. MDMTimeReadSector = 1000 // MDMTimeRevision is the time for executing a 'Revision' instruction. MDMTimeRevision = 1 // MDMTimeSwapSector is the time for executing an 'SwapSector' instruction. MDMTimeSwapSector = 1 // MDMTimeWriteSector is the time for executing a 'WriteSector' instruction. MDMTimeWriteSector = 10000 // MDMTimeUpdateRegistry is the time for executing an 'UpdateRegistry' // instruction. MDMTimeUpdateRegistry = 10000 // MDMTimeReadRegistry is the time for executing an 'ReadRegistry' // instruction. MDMTimeReadRegistry = 1000 // RPCIAppendLen is the expected length of the 'Args' of an Append // instructon. RPCIAppendLen = 9 // RPCIDropSectorsLen is the expected length of the 'Args' of a DropSectors // Instruction. RPCIDropSectorsLen = 9 // RPCIHasSectorLen is the expected length of the 'Args' of a HasSector // instruction. RPCIHasSectorLen = 8 // RPCIReadSectorLen is the expected length of the 'Args' of a ReadSector // instruction. RPCIReadSectorLen = 25 // RPCIReadOffsetLen is the expected length of the 'Args' of a ReadOffset // instruction. RPCIReadOffsetLen = 17 // RPCIRevisionLen is the expected length of the 'Args' of a Revision // instruction. RPCIRevisionLen = 0 // RPCISwapSectorLen is the expected length of the 'Args' of an SwapSector // instructon. RPCISwapSectorLen = 17 // 2 uint64 offsets + merkle proof flag // RPCIUpdateRegistryLen is the expected length of the 'Args' of an // UpdateRegistry instruction. // tweakOffset + revisionOffset + signatureOffset + pubKeyOffset + // pubKeyLength + dataOffset + dataLength = 7 * 8 bytes = 56 byte RPCIUpdateRegistryLen = 56 // RPCIReadRegistryLen is the expected length of the 'Args' of an // ReadRegistry instruction. // tweakOffset + pubKeyOffset + pubKeyLength = 3 * 8 bytes = 24 byte RPCIReadRegistryLen = 24 )
const ( // MinimumSupportedRenterHostProtocolVersion is the minimum version of Sia // that supports the currently used version of the renter-host protocol. MinimumSupportedRenterHostProtocolVersion = "1.4.1" // V1420HostOutOfStorageErrString is the string used by hosts since before // version 1.4.2 to indicate that they have run out of storage. // // Any update to this string needs to be done by making a new variable. This // variable should not be changed. IsOOSErr() needs to be updated to include // the new string while also still checking the old string as well to // preserve compatibility. V1420HostOutOfStorageErrString = "not enough storage remaining to accept sector" // V1420ContractNotRecognizedErrString is the string used by hosts since // before version 1.4.2 to indicate that they do not recognize the // contract that the renter is trying to update. // // Any update to this string needs to be done by making a new variable. This // variable should not be changed. IsContractNotRecognizedErr() needs to be // updated to include the new string while also still checking the old // string as well to preserve compatibility. V1420ContractNotRecognizedErrString = "no record of that contract" )
const ( // AcceptResponse is the response given to an RPC call to indicate // acceptance, i.e. that the sender wishes to continue communication. AcceptResponse = "accept" // StopResponse is the response given to an RPC call to indicate graceful // termination, i.e. that the sender wishes to cease communication, but // not due to an error. StopResponse = "stop" )
const ( // NegotiateDownloadTime defines the amount of time that the renter and // host have to negotiate a download request batch. The time is set high // enough that two nodes behind Tor have a reasonable chance of completing // the negotiation. NegotiateDownloadTime = 600 * time.Second // NegotiateFileContractRevisionTime defines the minimum amount of time // that the renter and host have to negotiate a file contract revision. The // time is set high enough that a full 4MB can be piped through a // connection that is running over Tor. NegotiateFileContractRevisionTime = 600 * time.Second // NegotiateFileContractTime defines the amount of time that the renter and // host have to negotiate a file contract. The time is set high enough that // a node behind Tor has a reasonable chance at making the multiple // required round trips to complete the negotiation. NegotiateFileContractTime = 360 * time.Second // NegotiateMaxDownloadActionRequestSize defines the maximum size that a // download request can be. Note, this is not a max size for the data that // can be requested, but instead is a max size for the definition of the // data being requested. NegotiateMaxDownloadActionRequestSize = 50e3 // NegotiateMaxErrorSize indicates the maximum number of bytes that can be // used to encode an error being sent during negotiation. NegotiateMaxErrorSize = 256 // NegotiateMaxFileContractRevisionSize specifies the maximum size that a // file contract revision is allowed to have when being sent over the wire // during negotiation. NegotiateMaxFileContractRevisionSize = 3e3 // NegotiateMaxFileContractSetLen determines the maximum allowed size of a // transaction set that can be sent when trying to negotiate a file // contract. The transaction set will contain all of the unconfirmed // dependencies of the file contract, meaning that it can be quite large. // The transaction pool's size limit for transaction sets has been chosen // as a reasonable guideline for determining what is too large. NegotiateMaxFileContractSetLen = TransactionSetSizeLimit - 1e3 // NegotiateMaxHostExternalSettingsLen is the maximum allowed size of an // encoded HostExternalSettings. NegotiateMaxHostExternalSettingsLen = 16000 // NegotiateMaxSiaPubkeySize defines the maximum size that a SiaPubkey is // allowed to be when being sent over the wire during negotiation. NegotiateMaxSiaPubkeySize = 1e3 // NegotiateMaxTransactionSignatureSize defines the maximum size that a // transaction signature is allowed to be when being sent over the wire // during negotiation. NegotiateMaxTransactionSignatureSize = 2e3 // NegotiateMaxTransactionSignaturesSize defines the maximum size that a // transaction signature slice is allowed to be when being sent over the // wire during negotiation. NegotiateMaxTransactionSignaturesSize = 5e3 // NegotiateRecentRevisionTime establishes the minimum amount of time that // the connection deadline is expected to be set to when a recent file // contract revision is being requested from the host. The deadline is long // enough that the connection should be successful even if both parties are // running Tor. NegotiateRecentRevisionTime = 120 * time.Second // NegotiateRenewContractTime defines the minimum amount of time that the // renter and host have to negotiate a final contract renewal. The time is // high enough that the negotiation can occur over a Tor connection, and // that both the host and the renter can have time to process large Merkle // tree calculations that may be involved with renewing a file contract. NegotiateRenewContractTime = 600 * time.Second )
const ( // KeySize is the size of a registered key. KeySize = crypto.PublicKeySize // TweakSize is the size of the tweak which can be used to register multiple // values for the same pubkey. TweakSize = crypto.HashSize // RegistryDataSize is the amount of arbitrary data in bytes a renter can // register in the registry. It's RegistryEntrySize - all the fields besides // the data that get persisted. RegistryDataSize = 113 // RegistryEntrySize is the size of a marshaled registry value on disk. RegistryEntrySize = 256 // FileIDVersion is the current version we expect in a FileID. FileIDVersion = 1 )
const ( // DefaultDirPerm defines the default permissions used for a new dir if no // permissions are supplied. Changing this value is a compatibility issue // since users expect dirs to have these permissions. DefaultDirPerm = 0755 // DefaultFilePerm defines the default permissions used for a new file if no // permissions are supplied. Changing this value is a compatibility issue // since users expect files to have these permissions. DefaultFilePerm = 0644 )
Filesystem related consts.
const ( // RenterDir is the name of the directory that is used to store the // renter's persistent data. RenterDir = "renter" // FileSystemRoot is the name of the directory that is used as the root of // the renter's filesystem. FileSystemRoot = "fs" // CombinedChunksRoot is the name of the directory that contains combined // chunks consisting of multiple partial chunks. CombinedChunksRoot = "combinedchunks" // EstimatedFileContractTransactionSetSize is the estimated blockchain size // of a transaction set between a renter and a host that contains a file // contract. This transaction set will contain a setup transaction from each // the host and the renter, and will also contain a file contract and file // contract revision that have each been signed by all parties. EstimatedFileContractTransactionSetSize = 2048 // EstimatedFileContractRevisionAndProofTransactionSetSize is the // estimated blockchain size of a transaction set used by the host to // provide the storage proof at the end of the contract duration. EstimatedFileContractRevisionAndProofTransactionSetSize = 5000 // StreamDownloadSize is the size of downloaded in a single streaming download // request. StreamDownloadSize = uint64(1 << 16) // 64 KiB // StreamUploadSize is the size of downloaded in a single streaming upload // request. StreamUploadSize = uint64(1 << 16) // 64 KiB )
const ( // SubscriptionEntrySize is the estimated size of a single subscribed to // entry takes up in memory. This is a conservative estimation to prevent // DoS attacks on the host. SubscriptionEntrySize = 512 // RenewDecodeMaxLen is the maximum length for decoding received objects // read during a contract renewal. RenewDecodeMaxLen = 1 << 18 // 256 kib )
const ( SubscriptionRequestInvalid = iota SubscriptionRequestSubscribe SubscriptionRequestUnsubscribe SubscriptionRequestExtend SubscriptionRequestPrepay SubscriptionRequestStop )
Subcription request related enum.
const ( SubscriptionResponseInvalid = iota SubscriptionResponseRegistryValue SubscriptionResponseSubscriptionSuccess SubscriptionResponseUnsubscribeSuccess )
Subcription response related enum.
const ( // SkyfileLayoutSize describes the amount of space within the first sector // of a skyfile used to describe the rest of the skyfile. SkyfileLayoutSize = 99 // SkyfileVersion establishes the current version for creating skyfiles. // The skyfile versions are different from the siafile versions. SkyfileVersion = 1 )
const ( // MetadataHeader defines the header for the backup MetadataHeader = "Skyfile Backup\n" // MetadataVersion defines the version for the backup MetadataVersion = "v1.5.5\n" )
const ( // ContractManagerDir is the standard name used for the directory that // contains all files directly related to the contract manager. ContractManagerDir = "contractmanager" // StorageManagerDir is standard name used for the directory that contains // all of the storage manager files. StorageManagerDir = "storagemanager" )
const ( // TransactionSetSizeLimit defines the largest set of dependent unconfirmed // transactions that will be accepted by the transaction pool. TransactionSetSizeLimit = 250e3 // TransactionSizeLimit defines the size of the largest transaction that // will be accepted by the transaction pool according to the IsStandard // rules. TransactionSizeLimit = 32e3 )
const ( // PublicKeysPerSeed define the number of public keys that get pregenerated // for a seed at startup when searching for balances in the blockchain. PublicKeysPerSeed = 2500 // SeedChecksumSize is the number of bytes that are used to checksum // addresses to prevent accidental spending. SeedChecksumSize = 6 // WalletDir is the directory that contains the wallet persistence. WalletDir = "wallet" )
const ( // DefaultMaxDuration defines the maximum number of blocks into the future // that the host will accept for the duration of an incoming file contract // obligation. 6 months is chosen because hosts are expected to be // long-term entities, and because we want to have a set of hosts that // support 6 month contracts when Sia leaves beta. DefaultMaxDuration = 144 * 30 * 6 // 6 months. )
const ( // ExplorerDir is the name of the directory that is typically used for the // explorer. ExplorerDir = "explorer" )
const ( // FCSignedIdentiferSize is the size of a ContractSignedIdentifier FCSignedIdentiferSize = 80 // 32 bytes identifier, 32 bytes signature, 16 bytes prefix )
const ( // FeeManagerDir is the name of the directory that is used to store the // FeeManager's persistent data FeeManagerDir = "feemanager" )
const ( // GatewayDir is the name of the directory used to store the gateway's // persistent data. GatewayDir = "gateway" )
const MaxEncodedNetAddressLength = 266
MaxEncodedNetAddressLength is the maximum length of a NetAddress encoded with the encode package. 266 was chosen because the maximum length for the hostname is 254 + 1 for the separating colon + 5 for the port + 8 byte string length prefix.
const ( // MinerDir is the name of the directory that is used to store the miner's // persistent data. MinerDir = "miner" )
const RPCMinLen = 4096
RPCMinLen is the minimum size of an RPC message. If an encoded message would be smaller than RPCMinLen, it is padded with random data.
const (
// SiaMuxDir is the name of the siamux dir
SiaMuxDir = "siamux"
)
const ( // SkylinkMaxFetchSize defines the maximum fetch size that is supported by // the skylink format. This is intentionally the same number as // modules.SectorSize on the release build. We could not use // modules.SectorSize directly because during testing that value is too // small to properly test the link format. SkylinkMaxFetchSize = 1 << 22 )
const ( // StackSize is the size of the buffer used to store the stack trace. StackSize = 64e6 // 64MB )
const (
// WithdrawalNonceSize is the size of the nonce in the WithdralMessage
WithdrawalNonceSize = 8
)
Variables ¶
var ( // ConsensusChangeBeginning is a special consensus change id that tells the // consensus set to provide all consensus changes starting from the very // first diff, which includes the genesis block diff. ConsensusChangeBeginning = ConsensusChangeID{} // ConsensusChangeRecent is a special consensus change id that tells the // consensus set to provide the most recent consensus change, instead of // starting from a specific value (which may not be known to the caller). ConsensusChangeRecent = ConsensusChangeID{1} // ErrBlockKnown is an error indicating that a block is already in the // database. ErrBlockKnown = errors.New("block already present in database") // ErrBlockUnsolved indicates that a block did not meet the required POW // target. ErrBlockUnsolved = errors.New("block does not meet target") // ErrInvalidConsensusChangeID indicates that ConsensusSetPersistSubscribe // was called with a consensus change id that is not recognized. Most // commonly, this means that the consensus set was deleted or replaced and // now the module attempting the subscription has desynchronized. This error // should be handled by the module, and not reported to the user. ErrInvalidConsensusChangeID = errors.New("consensus subscription has invalid id - files are inconsistent") // ErrNonExtendingBlock indicates that a block is valid but does not result // in a fork that is the heaviest known fork - the consensus set has not // changed as a result of seeing the block. ErrNonExtendingBlock = errors.New("block does not extend the longest fork") )
var ( // RenterDefaultDataPieces is the number of data pieces per erasure-coded // chunk used in the renter. RenterDefaultDataPieces = build.Select(build.Var{ Dev: 1, Standard: 10, Testing: 1, }).(int) // RenterDefaultParityPieces is the number of parity pieces per // erasure-coded chunk used in the renter. RenterDefaultParityPieces = build.Select(build.Var{ Dev: 1, Standard: 20, Testing: 4, }).(int) // ECReedSolomon is the marshaled type of the reed solomon coder. ECReedSolomon = ErasureCoderType{0, 0, 0, 1} // ECReedSolomonSubShards64 is the marshaled type of the reed solomon coder // for files where every 64 bytes of an encoded piece can be decoded // separately. ECReedSolomonSubShards64 = ErasureCoderType{0, 0, 0, 2} // ECPassthrough defines the erasure coder type for an erasure coder that // does nothing. ECPassthrough = ErasureCoderType{0, 0, 0, 3} )
var ( // Hostv112PersistMetadata is the header of the v112 host persist file. Hostv112PersistMetadata = persist.Metadata{ Header: "Sia Host", Version: "0.5", } // Hostv120PersistMetadata is the header of the v120 host persist file. Hostv120PersistMetadata = persist.Metadata{ Header: "Sia Host", Version: "1.2.0", } // Hostv143PersistMetadata is the header of the v143 host persist file. Hostv143PersistMetadata = persist.Metadata{ Header: "Sia Host", Version: "1.4.3", } // Hostv151PersistMetadata is the header of the v151 host persist file. Hostv151PersistMetadata = persist.Metadata{ Header: "Sia Host", Version: "1.5.1", } )
var ( // DefaultMaxDownloadBatchSize defines the maximum number of bytes that the // host will allow to be requested by a single download request. 17 MiB has // been chosen because it's 4 full sectors plus some wiggle room. 17 MiB is // a conservative default, most hosts will be fine with a number like 65 // MiB. DefaultMaxDownloadBatchSize = 17 * (1 << 20) // DefaultMaxReviseBatchSize defines the maximum number of bytes that the // host will allow to be sent during a single batch update in a revision // RPC. 17 MiB has been chosen because it's four full sectors, plus some // wiggle room for the extra data or a few delete operations. The whole // batch will be held in memory, so the batch size should only be increased // substantially if the host has a lot of memory. Additionally, the whole // batch is sent in one network connection. Additionally, the renter can // steal funds for upload bandwidth all the way out to the size of a batch. // 17 MiB is a conservative default, most hosts are likely to be just fine // with a number like 65 MiB. DefaultMaxReviseBatchSize = 17 * (1 << 20) // DefaultWindowSize is the size of the proof of storage window requested // by the host. The host will not delete any obligations until the window // has closed and buried under several confirmations. For release builds, // the default is set to 144 blocks, or about 1 day. This gives the host // flexibility to experience downtime without losing file contracts. The // optimal default, especially as the network matures, is probably closer // to 36 blocks. An experienced or high powered host should not be // frustrated by lost coins due to long periods of downtime. DefaultWindowSize = build.Select(build.Var{ Dev: types.BlockHeight(36), Standard: types.BlockHeight(144), Testing: types.BlockHeight(5), }).(types.BlockHeight) // DefaultBaseRPCPrice is the default price of talking to the host. It is // roughly equal to the default bandwidth cost of exchanging a pair of // 4096-byte messages. DefaultBaseRPCPrice = types.SiacoinPrecision.Mul64(100).Div64(1e9) // 100 nS // DefaultCollateral defines the amount of money that the host puts up as // collateral per-byte by default. The collateral should be considered as // an absolute instead of as a percentage, because low prices result in // collaterals which may be significant by percentage, but insignificant // overall. A default of 25 KS / TB / Month has been chosen, which is 2.5x // the default price for storage. The host is expected to put up a // significant amount of collateral as a commitment to faithfulness, // because this guarantees that the incentives are aligned for the host to // keep the data even if the price of siacoin fluctuates, the price of raw // storage fluctuates, or the host realizes that there is unexpected // opportunity cost in being a host. DefaultCollateral = types.SiacoinPrecision.Mul64(100).Div(BlockBytesPerMonthTerabyte) // 100 SC / TB / Month // DefaultMaxCollateral defines the maximum amount of collateral that the // host is comfortable putting into a single file contract. 10e3 is a // relatively small file contract, but millions of siacoins could be locked // away by only a few hundred file contracts. As the ecosystem matures, it // is expected that the safe default for this value will increase quite a // bit. DefaultMaxCollateral = types.SiacoinPrecision.Mul64(5e3) // DefaultContractPrice defines the default price of creating a contract // with the host. The current default is 0.1. This was chosen since it is // the minimum fee estimation of the transactionpool for a filecontract // transaction. DefaultContractPrice = types.SiacoinPrecision.Div64(100).Div64(1e3).Mul64(EstimatedFileContractRevisionAndProofTransactionSetSize) // DefaultDownloadBandwidthPrice defines the default price of upload // bandwidth. The default is set to 10 siacoins per gigabyte, because // download bandwidth is expected to be plentiful but also in-demand. DefaultDownloadBandwidthPrice = types.SiacoinPrecision.Mul64(25).Div(BytesPerTerabyte) // 25 SC / TB // DefaultEphemeralAccountExpiry defines the default maximum amount of // time an ephemeral account can be inactive before it expires and gets // deleted. DefaultEphemeralAccountExpiry = time.Minute * 60 * 24 * 7 // 1 week // DefaultMaxEphemeralAccountBalance defines the default maximum amount of // money that the host will allow to deposit into a single ephemeral account DefaultMaxEphemeralAccountBalance = types.SiacoinPrecision // DefaultSectorAccessPrice defines the default price of a sector access. It // is roughly equal to the cost of downloading 64 KiB. DefaultSectorAccessPrice = types.SiacoinPrecision.Mul64(2).Div64(1e6) // 2 uS // DefaultStoragePrice defines the starting price for hosts selling // storage. We try to match a number that is both reasonably profitable and // reasonably competitive. DefaultStoragePrice = types.SiacoinPrecision.Mul64(50).Div(BlockBytesPerMonthTerabyte) // 50 SC / TB / Month // DefaultUploadBandwidthPrice defines the default price of upload // bandwidth. The default is set to 1 siacoin per GB, because the host is // presumed to have a large amount of downstream bandwidth. Furthermore, // the host is typically only downloading data if it is planning to store // the data, meaning that the host serves to profit from accepting the // data. DefaultUploadBandwidthPrice = types.SiacoinPrecision.Mul64(1).Div(BytesPerTerabyte) // 1 SC / TB // CompatV1412DefaultEphemeralAccountExpiry defines the default account // expiry used up until v1.4.12. This constant is added to ensure changing // the default does not break legacy checks. CompatV1412DefaultEphemeralAccountExpiry = time.Minute * 60 * 24 * 7 // 1 week // CompatV1412DefaultMaxEphemeralAccountBalance defines the default maximum // ephemeral account balance used up until v1.4.12. This constant is added // to ensure changing the default does not break legacy checks. CompatV1412DefaultMaxEphemeralAccountBalance = types.SiacoinPrecision )
var ( // BlockBytesPerMonthTerabyte is the conversion rate between block-bytes and month-TB. BlockBytesPerMonthTerabyte = BytesPerTerabyte.Mul64(uint64(types.BlocksPerMonth)) // BytesPerTerabyte is the conversion rate between bytes and terabytes. BytesPerTerabyte = types.NewCurrency64(1e12) // MaxBaseRPCPriceVsBandwidth is the max ratio for sane pricing between the // MinBaseRPCPrice and the MinDownloadBandwidthPrice. This ensures that 1 // million base RPC charges are at most 1% of the cost to download 4TB. This // ratio should be used by checking that the MinBaseRPCPrice is less than or // equal to the MinDownloadBandwidthPrice multiplied by this constant MaxBaseRPCPriceVsBandwidth = uint64(40e3) // MaxSectorAccessPriceVsBandwidth is the max ratio for sane pricing between // the MinSectorAccessPrice and the MinDownloadBandwidthPrice. This ensures // that 1 million base accesses are at most 10% of the cost to download 4TB. // This ratio should be used by checking that the MinSectorAccessPrice is // less than or equal to the MinDownloadBandwidthPrice multiplied by this // constant MaxSectorAccessPriceVsBandwidth = uint64(400e3) )
var ( // HostConnectabilityStatusChecking is returned from ConnectabilityStatus() // if the host is still determining if it is connectable. HostConnectabilityStatusChecking = HostConnectabilityStatus("checking") // HostConnectabilityStatusConnectable is returned from // ConnectabilityStatus() if the host is connectable at its configured // netaddress. HostConnectabilityStatusConnectable = HostConnectabilityStatus("connectable") // HostConnectabilityStatusNotConnectable is returned from // ConnectabilityStatus() if the host is not connectable at its configured // netaddress. HostConnectabilityStatusNotConnectable = HostConnectabilityStatus("not connectable") // HostWorkingStatusChecking is returned from WorkingStatus() if the host is // still determining if it is working, that is, if settings calls are // incrementing. HostWorkingStatusChecking = HostWorkingStatus("checking") // HostWorkingStatusNotWorking is returned from WorkingStatus() if the host // has not received any settings calls over the duration of // workingStatusFrequency. HostWorkingStatusNotWorking = HostWorkingStatus("not working") // HostWorkingStatusWorking is returned from WorkingStatus() if the host has // received more than workingThreshold settings calls over the duration of // workingStatusFrequency. HostWorkingStatusWorking = HostWorkingStatus("working") )
var ( // MDMProgramWriteResponseTime defines the amount of time that the host // allows to write the output of an instruction to the stream. The time is // set high enough that a renter behind Tor has a reasonable chance of // completing the read. MDMProgramWriteResponseTime = build.Select(build.Var{ Standard: time.Minute, Dev: 30 * time.Second, Testing: 3 * time.Second, }).(time.Duration) // SpecifierAppend is the specifier for the Append instruction. SpecifierAppend = InstructionSpecifier{'A', 'p', 'p', 'e', 'n', 'd'} // SpecifierDropSectors is the specifier for the DropSectors instruction. SpecifierDropSectors = InstructionSpecifier{'D', 'r', 'o', 'p', 'S', 'e', 'c', 't', 'o', 'r', 's'} // SpecifierHasSector is the specifier for the HasSector instruction. SpecifierHasSector = InstructionSpecifier{'H', 'a', 's', 'S', 'e', 'c', 't', 'o', 'r'} // SpecifierReadOffset is the specifier for the ReadOffset instruction. SpecifierReadOffset = InstructionSpecifier{'R', 'e', 'a', 'd', 'O', 'f', 'f', 's', 'e', 't'} // SpecifierReadSector is the specifier for the ReadSector instruction. SpecifierReadSector = InstructionSpecifier{'R', 'e', 'a', 'd', 'S', 'e', 'c', 't', 'o', 'r'} // SpecifierRevision is the specifier for the Revision instruction. SpecifierRevision = InstructionSpecifier{'R', 'e', 'v', 'i', 's', 'i', 'o', 'n'} // SpecifierSwapSector is the specifier for the SwapSector instruction. SpecifierSwapSector = InstructionSpecifier{'S', 'w', 'a', 'p', 'S', 'e', 'c', 't', 'o', 'r'} // SpecifierUpdateRegistry is the specifier for the UpdateRegistry // instruction. SpecifierUpdateRegistry = InstructionSpecifier{'U', 'p', 'd', 'a', 't', 'e', 'R', 'e', 'g', 'i', 's', 't', 'r', 'y'} // SpecifierReadRegistry is the specifier for the ReadRegistry // instruction. SpecifierReadRegistry = InstructionSpecifier{'R', 'e', 'a', 'd', 'R', 'e', 'g', 'i', 's', 't', 'r', 'y'} // ErrInsufficientBandwidthBudget is returned when bandwidth can no longer // be paid for with the provided budget. ErrInsufficientBandwidthBudget = errors.New("insufficient budget for bandwidth") // ErrMDMInsufficientBudget is the error returned if the remaining budget of // an MDM program is not sufficient to execute the next instruction. ErrMDMInsufficientBudget = errors.New("remaining budget is insufficient") // ErrMDMInsufficientCollateralBudget is the error returned if the remaining // collateral budget of an MDM program is not sufficient to execute the next // instruction. ErrMDMInsufficientCollateralBudget = errors.New("remaining collateral budget is insufficient") )
var ( // ActionDelete is the specifier for a RevisionAction that deletes a // sector. ActionDelete = types.NewSpecifier("Delete") // ActionInsert is the specifier for a RevisionAction that inserts a // sector. ActionInsert = types.NewSpecifier("Insert") // ActionModify is the specifier for a RevisionAction that modifies sector // data. ActionModify = types.NewSpecifier("Modify") // ErrAnnNotAnnouncement indicates that the provided host announcement does // not use a recognized specifier, indicating that it's either not a host // announcement or it's not a recognized version of a host announcement. ErrAnnNotAnnouncement = errors.New("provided data does not form a recognized host announcement") // ErrAnnUnrecognizedSignature is returned when the signature in a host // announcement is not a type of signature that is recognized. ErrAnnUnrecognizedSignature = errors.New("the signature provided in the host announcement is not recognized") // ErrMaxVirtualSectors is returned when a sector cannot be added because // the maximum number of virtual sectors for that sector id already exist. ErrMaxVirtualSectors = errors.New("sector collides with a physical sector that already has the maximum allowed number of virtual sectors") // ErrRevisionCoveredFields is returned if there is a covered fields object // in a transaction signature which has the 'WholeTransaction' field set to // true, meaning that miner fees cannot be added to the transaction without // invalidating the signature. ErrRevisionCoveredFields = errors.New("file contract revision transaction signature does not allow miner fees to be added") // ErrRevisionSigCount is returned when a file contract revision has the // wrong number of transaction signatures. ErrRevisionSigCount = errors.New("file contract revision has the wrong number of transaction signatures") // ErrStopResponse is the error returned by ReadNegotiationAcceptance when // it reads the StopResponse string. ErrStopResponse = errors.New("sender wishes to stop communicating") // PrefixHostAnnouncement is used to indicate that a transaction's // Arbitrary Data field contains a host announcement. The encoded // announcement will follow this prefix. PrefixHostAnnouncement = types.NewSpecifier("HostAnnouncement") // PrefixFileContractIdentifier is used to indicate that a transaction's // Arbitrary Data field contains a file contract identifier. The identifier // and its signature will follow this prefix. PrefixFileContractIdentifier = types.NewSpecifier("FCIdentifier") // RPCDownload is the specifier for downloading a file from a host. RPCDownload = types.NewSpecifier("Download" + types.RuneToString(2)) // RPCFormContract is the specifier for forming a contract with a host. RPCFormContract = types.NewSpecifier("FormContract" + types.RuneToString(2)) // RPCRenewContractRHP2 is the specifier to renewing an existing contract. RPCRenewContractRHP2 = types.NewSpecifier("RenewContract" + types.RuneToString(2)) // RPCReviseContract is the specifier for revising an existing file // contract. RPCReviseContract = types.NewSpecifier("ReviseContract" + types.RuneToString(2)) // RPCSettings is the specifier for requesting settings from the host. RPCSettings = types.NewSpecifier("Settings" + types.RuneToString(2)) // SectorSize defines how large a sector should be in bytes. The sector // size needs to be a power of two to be compatible with package // merkletree. 4MB has been chosen for the live network because large // sectors significantly reduce the tracking overhead experienced by the // renter and the host. SectorSize = build.Select(build.Var{ Dev: SectorSizeDev, Standard: SectorSizeStandard, Testing: SectorSizeTesting, }).(uint64) // SectorSizeDev defines how large a sector should be in Dev builds. SectorSizeDev = uint64(1 << SectorSizeScalingDev) // SectorSizeStandard defines how large a sector should be in Standard // builds. SectorSizeStandard = uint64(1 << SectorSizeScalingStandard) // SectorSizeTesting defines how large a sector should be in Testing builds. SectorSizeTesting = uint64(1 << SectorSizeScalingTesting) // SectorSizeScalingDev defines the power of 2 to which we scale sector // sizes in Dev builds. SectorSizeScalingDev = 18 // 256 KiB // SectorSizeScalingStandard defines the power of 2 to which we scale sector // sizes in Standard builds. SectorSizeScalingStandard = 22 // 4 MiB // SectorSizeScalingTesting defines the power of 2 to which we scale sector // sizes in Testing builds. SectorSizeScalingTesting = 12 // 4 KiB )
var ( RPCLoopEnter = types.NewSpecifier("LoopEnter") RPCLoopExit = types.NewSpecifier("LoopExit") RPCLoopFormContract = types.NewSpecifier("LoopFormContract") RPCLoopLock = types.NewSpecifier("LoopLock") RPCLoopRead = types.NewSpecifier("LoopRead") RPCLoopRenewContract = types.NewSpecifier("LoopRenew") RPCLoopRenewClearContract = types.NewSpecifier("LoopRenewClear") RPCLoopSectorRoots = types.NewSpecifier("LoopSectorRoots") RPCLoopSettings = types.NewSpecifier("LoopSettings") RPCLoopUnlock = types.NewSpecifier("LoopUnlock") RPCLoopWrite = types.NewSpecifier("LoopWrite") )
New RPC IDs
var ( CipherChaCha20Poly1305 = types.NewSpecifier("ChaCha20Poly1305") CipherNoOverlap = types.NewSpecifier("NoOverlap") )
RPC ciphers
var ( WriteActionAppend = types.NewSpecifier("Append") WriteActionTrim = types.NewSpecifier("Trim") WriteActionSwap = types.NewSpecifier("Swap") WriteActionUpdate = types.NewSpecifier("Update") )
Write actions
var ( // ErrSizeTooLarge is returned for file sizes that exceed the sector size. ErrSizeTooLarge = errors.New("file size exceeds sector size") // ErrZeroSize is returned for zero-length files. ErrZeroSize = errors.New("file size of zero") )
var ( // ErrUnknownPaymentMethod occurs when the payment method specified in the // PaymentRequest object is unknown. The possible options are outlined below // under "Payment identifiers". ErrUnknownPaymentMethod = errors.New("unknown payment method") // ErrInvalidPaymentMethod occurs when the payment method is not accepted // for a specific RPC. ErrInvalidPaymentMethod = errors.New("invalid payment method") // ErrInsufficientPaymentForRPC is returned when the provided payment was // lower than the cost of the RPC. ErrInsufficientPaymentForRPC = errors.New("Insufficient payment, the provided payment did not cover the cost of the RPC.") // ErrExpiredRPCPriceTable is returned when the renter performs an RPC call // and the current block height exceeds the expiry block height of the RPC // price table. ErrExpiredRPCPriceTable = errors.New("Expired RPC price table, ensure you have the latest prices by calling the updatePriceTable RPC.") // ErrWithdrawalsInactive occurs when the host is not synced yet. If that is // the case the account manager does not allow trading money from the // ephemeral accounts. ErrWithdrawalsInactive = errors.New("ephemeral account withdrawals are inactive because the host is not synced") // ErrWithdrawalExpired occurs when the withdrawal message's expiry block // height is in the past. ErrWithdrawalExpired = errors.New("ephemeral account withdrawal message expired") // ErrWithdrawalExtremeFuture occurs when the withdrawal message's expiry // block height is too far into the future. ErrWithdrawalExtremeFuture = errors.New("ephemeral account withdrawal message expires too far into the future") // ErrWithdrawalInvalidSignature occurs when the signature provided with the // withdrawal message was invalid. ErrWithdrawalInvalidSignature = errors.New("ephemeral account withdrawal message signature is invalid") )
var ( PayByContract = types.NewSpecifier("PayByContract") PayByEphemeralAccount = types.NewSpecifier("PayByEphemAcc") )
Payment identifiers
var ( // DefaultAllowance is the set of default allowance settings that will be // used when allowances are not set or not fully set DefaultAllowance = Allowance{ Funds: types.SiacoinPrecision.Mul64(2500), Hosts: uint64(PriceEstimationScope), Period: 2 * types.BlocksPerMonth, RenewWindow: types.BlocksPerMonth, ExpectedStorage: 1e12, ExpectedUpload: uint64(200e9) / uint64(types.BlocksPerMonth), ExpectedDownload: uint64(100e9) / uint64(types.BlocksPerMonth), ExpectedRedundancy: 3.0, MaxPeriodChurn: uint64(250e9), } // ErrHostFault indicates if an error is the host's fault. ErrHostFault = errors.New("host has returned an error") // ErrDownloadCancelled is the error set when a download was cancelled // manually by the user. ErrDownloadCancelled = errors.New("download was cancelled") // ErrNotEnoughWorkersInWorkerPool is an error that is returned whenever an // operation expects a certain number of workers but there aren't that many // available. ErrNotEnoughWorkersInWorkerPool = errors.New("not enough workers in worker pool") // PriceEstimationScope is the number of hosts that get queried by the // renter when providing price estimates. Especially for the 'Standard' // variable, there should be congruence with the number of contracts being // used in the renter allowance. PriceEstimationScope = build.Select(build.Var{ Standard: int(50), Dev: int(12), Testing: int(4), }).(int) // BackupKeySpecifier is a specifier that is hashed with the wallet seed to // create a key for encrypting backups. BackupKeySpecifier = types.NewSpecifier("backupkey") )
var ( // RPCAccountBalance specifier RPCAccountBalance = types.NewSpecifier("AccountBalance") // RPCUpdatePriceTable specifier RPCUpdatePriceTable = types.NewSpecifier("UpdatePriceTable") // RPCExecuteProgram specifier RPCExecuteProgram = types.NewSpecifier("ExecuteProgram") // RPCFundAccount specifier RPCFundAccount = types.NewSpecifier("FundAccount") // RPCLatestRevision specifier RPCLatestRevision = types.NewSpecifier("LatestRevision") // RPCRegistrySubscription specifier RPCRegistrySubscription = types.NewSpecifier("Subscription") // RPCRenewContract specifier RPCRenewContract = types.NewSpecifier("RenewContract") )
var ( // GlobalRateLimits is the global object for regulating ratelimits // throughout siad. It is set using the gateway module. GlobalRateLimits = ratelimit.NewRateLimit(0, 0, 0) // ConfigName is the name of the config file on disk ConfigName = "siad.config" )
var ( // ErrEmptyPath is an error when a path is empty ErrEmptyPath = errors.New("path must be a nonempty string") // ErrInvalidSiaPath is the error for an invalid SiaPath ErrInvalidSiaPath = errors.New("invalid SiaPath") // ErrInvalidPathString is the error for an invalid path ErrInvalidPathString = errors.New("invalid path string") // SiaDirExtension is the extension for siadir metadata files on disk SiaDirExtension = ".siadir" // SiaFileExtension is the extension for siafiles on disk SiaFileExtension = ".sia" // PartialsSiaFileExtension is the extension for siafiles which contain // combined chunks. PartialsSiaFileExtension = ".csia" // CombinedChunkExtension is the extension for a combined chunk on disk. CombinedChunkExtension = ".cc" // UnfinishedChunkExtension is the extension for an unfinished combined chunk // and is appended to the file in addition to CombinedChunkExtension. UnfinishedChunkExtension = ".unfinished" // ChunkMetadataExtension is the extension of a metadata file for a combined // chunk. ChunkMetadataExtension = ".ccmd" )
var ( // BackupFolder is the Sia folder where all of the renter's snapshot // siafiles are stored by default. BackupFolder = NewGlobalSiaPath("/snapshots") // HomeFolder is the Sia folder that is used to store all of the user // accessible data. HomeFolder = NewGlobalSiaPath("/home") // SkynetFolder is the Sia folder where all of the skyfiles are stored by // default. SkynetFolder = NewGlobalSiaPath("/var/skynet") // UserFolder is the Sia folder that is used to store the renter's siafiles. UserFolder = NewGlobalSiaPath("/home/user") // VarFolder is the Sia folder that contains the skynet folder. VarFolder = NewGlobalSiaPath("/var") )
var ( // ErrIllegalFormName is returned when the multipart form contains a part // under an illegal form name, only 'files[]' or 'file' are allowed. ErrIllegalFormName = errors.New("multipart file submitted under an illegal form name, allowed values are 'files[]' and 'file'") // ErrEmptyFilename is returned when the multipart form contains a part // with an empty filename ErrEmptyFilename = errors.New("no filename provided") // SkyfileMetadata is cancelled before the metadata became available ErrSkyfileMetadataUnavailable = errors.New("metadata unavailable") )
var ( // BaseSectorNonceDerivation is the specifier used to derive a nonce for base // sector encryption BaseSectorNonceDerivation = types.NewSpecifier("BaseSectorNonce") // FanoutNonceDerivation is the specifier used to derive a nonce for // fanout encryption. FanoutNonceDerivation = types.NewSpecifier("FanoutNonce") // ExtendedSuffix is the suffix that is added to a skyfile siapath if it is // a large file upload ExtendedSuffix = "-extended" )
var ( // SkyfileFormatNotSpecified is the default format for the endpoint when the // format isn't specified explicitly. SkyfileFormatNotSpecified = SkyfileFormat("") // SkyfileFormatConcat returns the skyfiles in a concatenated manner. SkyfileFormatConcat = SkyfileFormat("concat") // SkyfileFormatTar returns the skyfiles as a .tar. SkyfileFormatTar = SkyfileFormat("tar") // SkyfileFormatTarGz returns the skyfiles as a .tar.gz. SkyfileFormatTarGz = SkyfileFormat("targz") // SkyfileFormatZip returns the skyfiles as a .zip. SkyfileFormatZip = SkyfileFormat("zip") )
var ( // ErrDuplicateTransactionSet is the error that gets returned if a // duplicate transaction set is given to the transaction pool. ErrDuplicateTransactionSet = errors.New("transaction set contains only duplicate transactions") // ErrInvalidArbPrefix is the error that gets returned if a transaction is // submitted to the transaction pool which contains a prefix that is not // recognized. This helps prevent miners on old versions from mining // potentially illegal transactions in the event of a soft-fork. ErrInvalidArbPrefix = errors.New("transaction contains non-standard arbitrary data") // ErrLargeTransaction is the error that gets returned if a transaction // provided to the transaction pool is larger than what is allowed by the // IsStandard rules. ErrLargeTransaction = errors.New("transaction is too large for this transaction pool") // ErrLargeTransactionSet is the error that gets returned if a transaction // set given to the transaction pool is larger than the limit placed by the // IsStandard rules of the transaction pool. ErrLargeTransactionSet = errors.New("transaction set is too large for this transaction pool") // PrefixNonSia defines the prefix that should be appended to any // transactions that use the arbitrary data for reasons outside of the // standard Sia protocol. This will prevent these transactions from being // rejected by the IsStandard set of rules, but also means that the data // will never be used within the formal Sia protocol. PrefixNonSia = types.NewSpecifier("NonSia") // TransactionPoolDir is the name of the directory that is used to store // the transaction pool's persistent data. TransactionPoolDir = "transactionpool" )
var ( // ErrBadEncryptionKey is returned if the incorrect encryption key to a // file is provided. ErrBadEncryptionKey = errors.New("provided encryption key is incorrect") // ErrIncompleteTransactions is returned if the wallet has incomplete // transactions being built that are using all of the current outputs, and // therefore the wallet is unable to spend money despite it not technically // being 'unconfirmed' yet. ErrIncompleteTransactions = errors.New("wallet has coins spent in incomplete transactions - not enough remaining coins") // ErrLockedWallet is returned when an action cannot be performed due to // the wallet being locked. ErrLockedWallet = errors.New("wallet must be unlocked before it can be used") // ErrLowBalance is returned if the wallet does not have enough funds to // complete the desired action. ErrLowBalance = errors.New("insufficient balance") // ErrWalletShutdown is returned when a method can't continue execution due // to the wallet shutting down. ErrWalletShutdown = errors.New("wallet is shutting down") )
var ( // BootstrapPeers is a list of peers that can be used to find other peers - // when a client first connects to the network, the only options for // finding peers are either manual entry of peers or to use a hardcoded // bootstrap point. While the bootstrap point could be a central service, // it can also be a list of peers that are known to be stable. We have // chosen to hardcode known-stable peers. // // These peers have been verified to be v1.3.7 or higher BootstrapPeers = build.Select(build.Var{ Standard: []NetAddress{ "95.78.166.67:9981", "68.199.121.249:9981", "24.194.148.158:9981", "82.231.193.206:9981", "185.216.208.214:9981", "165.73.59.75:9981", "81.5.154.29:9981", "68.133.15.97:9981", "223.19.102.54:9981", "136.52.23.122:9981", "45.56.21.129:9981", "109.172.42.157:9981", "188.244.40.69:9985", "176.37.126.147:9981", "68.96.80.134:9981", "92.255.195.111:9981", "88.202.201.30:9981", "76.103.83.241:9981", "77.132.24.85:9981", "81.167.50.168:9981", "91.206.15.126:9981", "91.231.94.22:9981", "212.105.168.207:9981", "94.113.86.207:9981", "188.242.52.10:9981", "94.137.140.40:9981", "137.74.1.200:9981", "85.27.163.135:9981", "46.246.68.66:9981", "92.70.88.30:9981", "188.68.37.232:9981", "153.210.37.241:9981", "24.20.240.181:9981", "92.154.126.211:9981", "45.50.26.222:9981", "41.160.218.190:9981", "23.175.0.151:9981", "109.248.206.13:9981", "222.161.26.222:9981", "68.97.208.223:9981", "71.190.208.128:9981", "69.120.2.164:9981", "37.204.141.163:9981", "188.243.111.129:9981", "78.46.64.86:9981", "188.244.40.69:9981", "87.237.42.180:9981", "212.42.213.179:9981", "62.216.59.236:9981", "80.56.227.209:9981", "202.181.196.157:9981", "188.242.52.10:9986", "188.242.52.10:9988", "81.24.30.12:9981", "109.233.59.68:9981", "77.162.159.137:9981", "176.240.111.223:9981", "126.28.73.206:9981", "178.63.11.62:9981", "174.84.49.170:9981", "185.6.124.16:9981", "81.24.30.13:9981", "31.208.123.118:9981", "85.69.198.249:9981", "5.9.147.103:9981", "77.168.231.70:9981", "81.24.30.14:9981", "82.253.237.216:9981", "161.53.40.130:9981", "34.209.55.245:9981", }, Dev: []NetAddress(nil), Testing: []NetAddress(nil), }).([]NetAddress) )
var ErrCSIDoesNotMatchSeed = errors.New("ContractSignedIdentifier signature bytes not equal")
ErrCSIDoesNotMatchSeed is returned when a ContractSignedIdentifier was not created with the current seed used by the renter.
var ( // ErrInvalidDefaultPath is returned when the specified default path is not // valid, e.g. the file it points to does not exist. ErrInvalidDefaultPath = errors.New("invalid default path provided") )
var ( // ErrSkylinkIncorrectSize is returned when a string could not be decoded // into a Skylink due to it having an incorrect size. ErrSkylinkIncorrectSize = errors.New("skylink has incorrect size") )
var ( // NegotiateSettingsTime establishes the minimum amount of time that the // connection deadline is expected to be set to when settings are being // requested from the host. The deadline is long enough that the connection // should be successful even if both parties are on Tor. NegotiateSettingsTime = build.Select(build.Var{ Dev: 120 * time.Second, Standard: 120 * time.Second, Testing: 3 * time.Second, }).(time.Duration) )
var ProdDependencies = new(ProductionDependencies)
ProdDependencies act as a global instance of the production dependencies to avoid having to instantiate new dependencies every time we want to pass production dependencies.
var ( // RPCChallengePrefix is the prefix prepended to the challenge data // supplied by the host when proving ownership of a contract's secret key. RPCChallengePrefix = types.NewSpecifier("challenge") )
var (
RPCLoopReadStop = types.NewSpecifier("ReadStop")
)
Read interrupt
var ( // SafeMutexDelay is the recommended timeout for the deadlock detecting // mutex. This value is DEPRECATED, as safe mutexes are no longer // recommended. Instead, the locking conventions should be followed and a // traditional mutex or a demote mutex should be used. SafeMutexDelay time.Duration )
var ( // SubscriptionPeriod is the duration by which a period gets extended after // a payment. SubscriptionPeriod = build.Select(build.Var{ Dev: time.Minute, Standard: 5 * time.Minute, Testing: 5 * time.Second, }).(time.Duration) )
var ZeroAccountID = AccountID{""}
ZeroAccountID is the only account id that is allowed to be invalid.
Functions ¶
func AddCommas ¶ added in v1.5.5
AddCommas produces a string form of the given number in base 10 with commas after every three orders of magnitude.
e.g. AddCommas(834142) -> 834,142
This code was pulled from the 'humanize' package at github.com/dustin/go-humanize - thanks Dustin!
func BackupSkylink ¶ added in v1.5.4
BackupSkylink backs up a skylink by writing skylink and baseSector to a header and then writing the header and the reader data to the writer.
func BandwidthUnits ¶ added in v1.5.5
BandwidthUnits takes bps (bits per second) as an argument and converts them into a more human-readable string with a unit.
func BuildBaseSector ¶ added in v1.5.4
BuildBaseSector will take all of the elements of the base sector and copy them into a freshly created base sector.
func CalculateFee ¶ added in v1.0.0
func CalculateFee(ts []types.Transaction) types.Currency
CalculateFee returns the fee-per-byte of a transaction set.
func CreateAnnouncement ¶ added in v1.0.0
func CreateAnnouncement(addr NetAddress, pk types.SiaPublicKey, sk crypto.SecretKey) (signedAnnouncement []byte, err error)
CreateAnnouncement will take a host announcement and encode it, returning the exact []byte that should be added to the arbitrary data of a transaction.
func CurrencyUnits ¶ added in v1.5.5
CurrencyUnits converts a types.Currency to a string with human-readable units. The unit used will be the largest unit that results in a value greater than 1. The value is rounded to 4 significant digits.
func DecodeFanout ¶ added in v1.5.4
func DecodeFanout(sl SkyfileLayout, fanoutBytes []byte) (piecesPerChunk, chunkRootsSize, numChunks uint64, err error)
DecodeFanout will take the fanout bytes from a baseSector and decode them.
func DecryptBaseSector ¶ added in v1.5.4
DecryptBaseSector attempts to decrypt the baseSector. If it has the necessary Skykey, it will decrypt the baseSector in-place.It returns the file-specific skykey to be used for decrypting the rest of the associated skyfile.
func DeriveFanoutKey ¶ added in v1.5.4
DeriveFanoutKey returns the crypto.CipherKey that should be used for decrypting the fanout stream from the skyfile stored using this layout.
func EnsurePrefix ¶ added in v1.5.0
EnsurePrefix checks if `str` starts with `prefix` and adds it if that's not the case.
func EnsureSuffix ¶ added in v1.5.0
EnsureSuffix checks if `str` ends with `suffix` and adds it if that's not the case.
func ExtractSegment ¶ added in v1.5.1
ExtractSegment is a convenience method that extracts the data of the segment at segmentIndex from pieces.
func FilesizeUnits ¶ added in v1.4.2
FilesizeUnits returns a string that displays a filesize in human-readable units.
func GenerateContractKeyPair ¶ added in v1.5.5
func GenerateContractKeyPair(renterSeed EphemeralRenterSeed, txn types.Transaction) (sk crypto.SecretKey, pk crypto.PublicKey)
GenerateContractKeyPair generates a secret and a public key for a contract to be used in its unlock conditions.
func GenerateContractKeyPairWithOutputID ¶ added in v1.5.5
func GenerateContractKeyPairWithOutputID(renterSeed EphemeralRenterSeed, inputParentID types.SiacoinOutputID) (sk crypto.SecretKey, pk crypto.PublicKey)
GenerateContractKeyPairWithOutputID generates a secret and a public key for a contract to be used in its unlock conditions.
func HealthPercentage ¶ added in v1.4.2
HealthPercentage returns the health in a more human understandable format out of 100%
The percentage is out of 1.25, this is to account for the RepairThreshold of 0.25 and assumes that the worst health is 1.5. Since we do not repair until the health is worse than the RepairThreshold, a health of 0 - 0.25 is full health. Likewise, a health that is greater than 1.25 is essentially 0 health.
func IsConsensusConflict ¶ added in v1.4.2
IsConsensusConflict returns true iff err is a ConsensusConflict.
func IsContractNotRecognizedErr ¶ added in v1.4.2
IsContractNotRecognizedErr is a helper function to determine whether an error from a host is a indicating that they do not recognize a contract that the renter is updating.
Note: To preserve compatibility, this function needsd to be extended exclusively by adding more checks, the existing checks should not be altered or removed.
func IsEncryptedBaseSector ¶ added in v1.5.4
IsEncryptedBaseSector returns true if and only if the the baseSector is encrypted.
func IsEncryptedLayout ¶ added in v1.5.4
func IsEncryptedLayout(sl SkyfileLayout) bool
IsEncryptedLayout returns true if and only if the the layout indicates that it is from an encrypted base sector.
func IsHostsFault ¶ added in v1.3.3
IsHostsFault indicates if a returned error is the host's fault.
func IsOOSErr ¶ added in v1.4.1
IsOOSErr is a helper function to determine whether an error from a host is indicating that they are out of storage.
Note: To preserve compatibility, this function needsd to be extended exclusively by adding more checks, the existing checks should not be altered or removed.
func MDMAppendCollateral ¶ added in v1.4.8
func MDMAppendCollateral(pt *RPCPriceTable) types.Currency
MDMAppendCollateral returns the additional collateral a 'Append' instruction requires the host to put up.
func MDMAppendCost ¶ added in v1.4.4
func MDMAppendCost(pt *RPCPriceTable, duration types.BlockHeight) (types.Currency, types.Currency)
MDMAppendCost is the cost of executing an 'Append' instruction.
func MDMAppendMemory ¶ added in v1.4.4
func MDMAppendMemory() uint64
MDMAppendMemory returns the additional memory consumption of a 'Append' instruction.
func MDMBandwidthCost ¶ added in v1.4.9
func MDMBandwidthCost(pt RPCPriceTable, uploadBandwidth, downloadBandwidth uint64) types.Currency
MDMBandwidthCost computes the total bandwidth cost given a price table and used up- and download bandwidth.
func MDMCopyCost ¶ added in v1.4.4
func MDMCopyCost(pt RPCPriceTable, contractSize uint64) types.Currency
MDMCopyCost is the cost of executing a 'Copy' instruction.
func MDMDropSectorsCollateral ¶ added in v1.4.8
MDMDropSectorsCollateral returns the additional collateral a 'DropSectors' instruction requires the host to put up.
func MDMDropSectorsCost ¶ added in v1.4.4
func MDMDropSectorsCost(pt *RPCPriceTable, numSectorsDropped uint64) types.Currency
MDMDropSectorsCost is the cost of executing a 'DropSectors' instruction for a certain number of dropped sectors.
func MDMDropSectorsMemory ¶ added in v1.4.8
func MDMDropSectorsMemory() uint64
MDMDropSectorsMemory returns the additional memory consumption of a `DropSectors` instruction
func MDMDropSectorsTime ¶ added in v1.4.8
MDMDropSectorsTime returns the time for a `DropSectors` instruction given `numSectorsDropped`.
func MDMHasSectorCollateral ¶ added in v1.4.8
MDMHasSectorCollateral returns the additional collateral a 'HasSector' instruction requires the host to put up.
func MDMHasSectorCost ¶ added in v1.4.4
func MDMHasSectorCost(pt *RPCPriceTable) types.Currency
MDMHasSectorCost is the cost of executing a 'HasSector' instruction.
func MDMHasSectorMemory ¶ added in v1.4.4
func MDMHasSectorMemory() uint64
MDMHasSectorMemory returns the additional memory consumption of a 'HasSector' instruction.
func MDMInitCost ¶ added in v1.4.4
func MDMInitCost(pt *RPCPriceTable, programLen, numInstructions uint64) types.Currency
MDMInitCost is the cost of instantiating the MDM.
func MDMInitMemory ¶ added in v1.4.8
func MDMInitMemory() uint64
MDMInitMemory returns the memory consumed by a program before considering the size of the program input.
func MDMMemoryCost ¶ added in v1.4.4
func MDMMemoryCost(pt *RPCPriceTable, usedMemory, time uint64) types.Currency
MDMMemoryCost computes the memory cost given a price table, memory and time.
func MDMReadCollateral ¶ added in v1.4.8
MDMReadCollateral returns the additional collateral a 'Read' instruction requires the host to put up.
func MDMReadCost ¶ added in v1.4.4
func MDMReadCost(pt *RPCPriceTable, readLength uint64) types.Currency
MDMReadCost is the cost of executing a 'Read' instruction. It is defined as: 'readBaseCost' + 'readLengthCost' * `readLength`
func MDMReadMemory ¶ added in v1.4.4
func MDMReadMemory() uint64
MDMReadMemory returns the additional memory consumption of a 'Read' instruction.
func MDMReadRegistryCollateral ¶ added in v1.5.1
MDMReadRegistryCollateral returns the additional collateral a 'ReadRegistry' instruction requires the host to put up.
func MDMReadRegistryCost ¶ added in v1.5.1
func MDMReadRegistryCost(pt *RPCPriceTable) (_, _ types.Currency)
MDMReadRegistryCost is the cost of executing a 'ReadRegistry' instruction.
func MDMReadRegistryMemory ¶ added in v1.5.1
func MDMReadRegistryMemory() uint64
MDMReadRegistryMemory returns the additional memory consumption of a 'ReadRegistry' instruction.
func MDMRevisionCollateral ¶ added in v1.5.0
MDMRevisionCollateral returns the additional collateral a 'Revision' instruction requires the host to put up.
func MDMRevisionCost ¶ added in v1.5.0
func MDMRevisionCost(pt *RPCPriceTable) types.Currency
MDMRevisionCost is the cost of executing a 'Revision' instruction.
func MDMRevisionMemory ¶ added in v1.5.0
func MDMRevisionMemory() uint64
MDMRevisionMemory returns the additional memory consumption of a 'Revision' instruction.
func MDMSubscribeCost ¶ added in v1.5.5
func MDMSubscribeCost(pt *RPCPriceTable, nFound, nEntries uint64) types.Currency
MDMSubscribeCost returns the cost of subscribing to nEntries registry entries and retrieving nFound of them. Subscribing involves paying for 10 years of storage + the memory cost.
func MDMSubscriptionMemoryCost ¶ added in v1.5.5
func MDMSubscriptionMemoryCost(pt *RPCPriceTable, nEntries uint64) types.Currency
MDMSubscriptionMemoryCost computes the memory cost of subscribing to an entry.
func MDMSwapCost ¶ added in v1.4.4
func MDMSwapCost(pt *RPCPriceTable, contractSize uint64) types.Currency
MDMSwapCost is the cost of executing a 'Swap' instruction.
func MDMSwapSectorCollateral ¶ added in v1.5.0
MDMSwapSectorCollateral returns the additional collateral a 'SwapSector' instruction requires the host to put up.
func MDMSwapSectorCost ¶ added in v1.5.0
func MDMSwapSectorCost(pt *RPCPriceTable) types.Currency
MDMSwapSectorCost is the cost of executing a 'SwapSector' instruction.
func MDMSwapSectorMemory ¶ added in v1.5.0
func MDMSwapSectorMemory() uint64
MDMSwapSectorMemory returns the additional memory consumption of a 'SwapSector' instruction.
func MDMTruncateCost ¶ added in v1.4.4
func MDMTruncateCost(pt *RPCPriceTable, contractSize uint64) types.Currency
MDMTruncateCost is the cost of executing a 'Truncate' instruction.
func MDMUpdateRegistryCollateral ¶ added in v1.5.1
MDMUpdateRegistryCollateral returns the additional collateral a 'UpdateRegistry' instruction requires the host to put up.
func MDMUpdateRegistryCost ¶ added in v1.5.1
func MDMUpdateRegistryCost(pt *RPCPriceTable) (_, _ types.Currency)
MDMUpdateRegistryCost is the cost of executing a 'UpdateRegistry' instruction.
func MDMUpdateRegistryMemory ¶ added in v1.5.1
func MDMUpdateRegistryMemory() uint64
MDMUpdateRegistryMemory returns the additional memory consumption of a 'UpdateRegistry' instruction.
func MDMWriteCost ¶ added in v1.4.4
func MDMWriteCost(pt *RPCPriceTable, writeLength uint64) types.Currency
MDMWriteCost is the cost of executing a 'Write' instruction of a certain length.
func NewMultipartReader ¶ added in v1.5.5
NewMultipartReader creates a multipart.Reader from an io.Reader and the provided subfiles. This reader can then be used to create a NewSkyfileMultipartReader.
func NewRenterSession ¶ added in v1.4.0
func NewRenterSession(conn net.Conn, hostPublicKey types.SiaPublicKey) (*RenterHostSession, LoopChallengeRequest, error)
NewRenterSession returns a new renter-side session of the renter-host protocol.
func ParseSkyfileMetadata ¶ added in v1.5.4
func ParseSkyfileMetadata(baseSector []byte) (sl SkyfileLayout, fanoutBytes []byte, sm SkyfileMetadata, baseSectorPayload []byte, err error)
ParseSkyfileMetadata will pull the metadata (including layout and fanout) out of a skyfile.
func PeekErr ¶ added in v1.4.2
PeekErr checks if a chan error has an error waiting to be returned. If it has it will return that error. Otherwise it returns 'nil'.
func PrintAlerts ¶ added in v1.5.5
func PrintAlerts(alerts []Alert, as AlertSeverity)
PrintAlerts is a helper function to print details of a slice of alerts with given severity description to command line
func RPCReadMaxLen ¶ added in v1.5.5
RPCReadMaxLen tries to read the given object from the stream. It will allocate at most maxLen bytes for the object.
func RPCWriteAll ¶ added in v1.4.5
RPCWriteAll writes the given objects to the stream.
func RPCWriteError ¶ added in v1.4.5
RPCWriteError writes the given error to the stream.
func ReadNegotiationAcceptance ¶ added in v1.0.0
ReadNegotiationAcceptance reads an accept/reject response from r (usually a net.Conn). If the response is not AcceptResponse, ReadNegotiationAcceptance returns the response as an error. If the response is StopResponse, ErrStopResponse is returned, allowing for direct error comparison.
Note that since errors returned by ReadNegotiationAcceptance are newly allocated, they cannot be compared to other errors in the traditional fashion.
func ReadRPCMessage ¶ added in v1.4.0
ReadRPCMessage reads an encrypted RPC message.
func ReadRPCRequest ¶ added in v1.4.0
ReadRPCRequest reads an RPC request using the new loop protocol.
func ReadRPCResponse ¶ added in v1.4.0
ReadRPCResponse reads an RPC response using the new loop protocol.
func RenewBaseCosts ¶ added in v1.5.1
func RenewBaseCosts(lastRev types.FileContractRevision, pt *RPCPriceTable, endHeight types.BlockHeight) (basePrice, baseCollateral types.Currency)
RenewBaseCosts is a helper to calculate the base costs for a renewed contract. The base costs consist of the initial storage cost and collateral associated with renewing a contract that already contains data. NOTE: The baseCollateral is computed using the maximum acceptable collateral to the host. Because of siafund fees, a renter may decide to use less than the amount of collateral advertised by the host. If the renter would rather have lower collateral and pay fewer siafund fees, they have the full freedom within the protocol to do that. It is strictly advantageous for the host.
func RenterPayoutsPreTax ¶ added in v1.3.5
func RenterPayoutsPreTax(host HostDBEntry, funding, txnFee, basePrice, baseCollateral types.Currency, period types.BlockHeight, expectedStorage uint64) (renterPayout, hostPayout, hostCollateral types.Currency, err error)
RenterPayoutsPreTax calculates the renterPayout before tax and the hostPayout given a host, the available renter funding, the expected txnFee for the transaction and an optional basePrice in case this helper is used for a renewal. It also returns the hostCollateral.
func RestoreSkylink ¶ added in v1.5.4
RestoreSkylink restores a skylink by returning the Skylink and the baseSector from the reader.
func RoundRegistrySize ¶ added in v1.5.1
RoundRegistrySize is a helper to correctly round up the size of a registry to the closest valid one.
func SeedToString ¶ added in v1.0.0
func SeedToString(seed Seed, did mnemonics.DictionaryID) (string, error)
SeedToString converts a wallet seed to a human friendly string.
func SiaPKToMuxPK ¶ added in v1.4.5
func SiaPKToMuxPK(spk types.SiaPublicKey) (mk mux.ED25519PublicKey)
SiaPKToMuxPK turns a SiaPublicKey into a mux.ED25519PublicKey
func SkyfileMetadataBytes ¶ added in v1.5.4
func SkyfileMetadataBytes(sm SkyfileMetadata) ([]byte, error)
SkyfileMetadataBytes will return the marshalled/encoded bytes for the skyfile metadata.
func SkylinkFromSysPath ¶ added in v1.5.4
SkylinkFromSysPath returns a skylink string from a system path
func SkylinkToSysPath ¶ added in v1.5.4
SkylinkToSysPath takes the string of a skylink and turns it into a filepath that has defaultDirDepth number of directories that have names which have defaultDirLength characters
func V154MDMReadRegistryCost ¶ added in v1.5.5
func V154MDMReadRegistryCost(pt *RPCPriceTable) (_ types.Currency)
V154MDMReadRegistryCost is the cost of executing a 'ReadRegistry' instruction on pre 155 hosts.
func V154MDMUpdateRegistryCost ¶ added in v1.5.5
func V154MDMUpdateRegistryCost(pt *RPCPriceTable) (_, _ types.Currency)
V154MDMUpdateRegistryCost is the cost of executing a 'UpdateRegistry' instruction in host versions 1.5.4 and below.
func ValidatePathString ¶ added in v1.5.0
ValidatePathString validates a path given a string.
func ValidateSkyfileMetadata ¶ added in v1.5.4
func ValidateSkyfileMetadata(metadata SkyfileMetadata) error
ValidateSkyfileMetadata validates the given SkyfileMetadata
func VerifyFileContractRevisionTransactionSignatures ¶ added in v1.0.0
func VerifyFileContractRevisionTransactionSignatures(fcr types.FileContractRevision, tsigs []types.TransactionSignature, height types.BlockHeight) error
VerifyFileContractRevisionTransactionSignatures checks that the signatures on a file contract revision are valid and cover the right fields.
func VerifyRenewalTransactionSignatures ¶ added in v1.5.4
func VerifyRenewalTransactionSignatures(fcr types.FileContractRevision, fc types.FileContract, tsigs []types.TransactionSignature, height types.BlockHeight) error
VerifyRenewalTransactionSignatures checks that the signatures on a file contract and revision are valid and cover the right fields.
func WriteNegotiationAcceptance ¶ added in v1.0.0
WriteNegotiationAcceptance writes the 'accept' response to w (usually a net.Conn).
func WriteNegotiationRejection ¶ added in v1.0.0
WriteNegotiationRejection will write a rejection response to w (usually a net.Conn) and return the input error. If the write fails, the write error is joined with the input error.
func WriteNegotiationStop ¶ added in v1.0.0
WriteNegotiationStop writes the 'stop' response to w (usually a net.Conn).
func WriteRPCMessage ¶ added in v1.4.0
WriteRPCMessage writes an encrypted RPC message.
func WriteRPCRequest ¶ added in v1.4.0
WriteRPCRequest writes an encrypted RPC request using the new loop protocol.
func WriteRPCResponse ¶ added in v1.4.0
WriteRPCResponse writes an RPC response or error using the new loop protocol. Either resp or err must be nil. If err is an *RPCError, it is sent directly; otherwise, a generic RPCError is created from err's Error string.
Types ¶
type AccountBalanceRequest ¶ added in v1.4.9
type AccountBalanceRequest struct {
Account AccountID
}
AccountBalanceRequest specifies the account for which to retrieve the balance.
type AccountBalanceResponse ¶ added in v1.4.9
AccountBalanceResponse contains the balance of the previously specified account.
type AccountID ¶ added in v1.4.7
type AccountID struct {
// contains filtered or unexported fields
}
AccountID is the unique identifier of an ephemeral account on the host. It should always be a valid representation of types.SiaPublicKey or an empty string.
func NewAccountID ¶ added in v1.4.8
NewAccountID is a helper function that creates a new account ID from a randomly generate key pair
func (*AccountID) FromSPK ¶ added in v1.4.8
func (aid *AccountID) FromSPK(spk types.SiaPublicKey)
FromSPK creates an AccountID from a SiaPublicKey. This assumes that the provided key is valid and won't perform additional checks.
func (AccountID) IsZeroAccount ¶ added in v1.4.8
IsZeroAccount returns whether or not the account id matches the empty string.
func (*AccountID) LoadString ¶ added in v1.4.8
LoadString loads an account id from a string.
func (AccountID) MarshalSia ¶ added in v1.4.8
MarshalSia implements the SiaMarshaler interface.
func (AccountID) SPK ¶ added in v1.4.8
func (aid AccountID) SPK() (spk types.SiaPublicKey)
SPK returns the account id as a types.SiaPublicKey.
type Alert ¶ added in v1.4.2
type Alert struct { // Cause is the cause for the Alert. // e.g. "Wallet is locked" Cause string `json:"cause"` // Msg is the message the Alert is meant to convey to the user. // e.g. "Contractor can't form new contrats" Msg string `json:"msg"` // Module contains information about what module the alert originated from. Module string `json:"module"` // Severity categorizes the Alerts to allow for an easy way to filter them. Severity AlertSeverity `json:"severity"` }
Alert is a type that contains essential information about an alert.
type AlertID ¶ added in v1.4.2
type AlertID string
AlertID is a helper type for an Alert's ID.
func AlertIDSiafileLowRedundancy ¶ added in v1.4.2
AlertIDSiafileLowRedundancy uses a Siafile's UID to create a unique AlertID for a low redundancy alert.
type AlertSeverity ¶ added in v1.4.2
type AlertSeverity uint64
AlertSeverity describes the severity of an alert.
func (AlertSeverity) MarshalJSON ¶ added in v1.4.2
func (a AlertSeverity) MarshalJSON() ([]byte, error)
MarshalJSON defines a JSON encoding for the AlertSeverity.
func (AlertSeverity) String ¶ added in v1.4.2
func (a AlertSeverity) String() string
String converts an alertSeverity to a string
func (*AlertSeverity) UnmarshalJSON ¶ added in v1.4.2
func (a *AlertSeverity) UnmarshalJSON(b []byte) error
UnmarshalJSON attempts to decode an AlertSeverity.
type Alerter ¶ added in v1.4.2
type Alerter interface {
Alerts() (crit, err, warn []Alert)
}
Alerter is the interface implemented by all top-level modules. It's an interface that allows for asking a module about potential issues.
type Allowance ¶ added in v1.0.0
type Allowance struct { Funds types.Currency `json:"funds"` Hosts uint64 `json:"hosts"` Period types.BlockHeight `json:"period"` RenewWindow types.BlockHeight `json:"renewwindow"` // PaymentContractInitialFunding establishes the amount of money that the a // Skynet portal will put into a brand new payment contract. If this value // is set to zero, this node will not act as a Skynet portal. When this // value is non-zero, this node will act as a Skynet portal, and form // contracts with every reasonably priced host. PaymentContractInitialFunding types.Currency `json:"paymentcontractinitialfunding"` // ExpectedStorage is the amount of data that we expect to have in a contract. ExpectedStorage uint64 `json:"expectedstorage"` // ExpectedUpload is the expected amount of data uploaded through the API, // before redundancy, per block. ExpectedUpload uint64 `json:"expectedupload"` // ExpectedDownload is the expected amount of data downloaded through the // API per block. ExpectedDownload uint64 `json:"expecteddownload"` // ExpectedRedundancy is the average redundancy of files being uploaded. ExpectedRedundancy float64 `json:"expectedredundancy"` // MaxPeriodChurn is maximum amount of contract churn allowed in a single // period. MaxPeriodChurn uint64 `json:"maxperiodchurn"` // The following fields provide price gouging protection for the user. By // setting a particular maximum price for each mechanism that a host can use // to charge users, the workers know to avoid hosts that go outside of the // safety range. // // The intention is that if the fields are not set, a reasonable value will // be derived from the other allowance settings. The intention is that the // hostdb will pay attention to these limits when forming contracts, // understanding that a certain feature (such as storage) will not be used // if the host price is above the limit. If the hostdb believes that a host // is valuable for its other, more reasonably priced features, the hostdb // may choose to form a contract with the host anyway. // // NOTE: If the allowance max price fields are ever extended, all of the // price gouging checks throughout the worker code and contract formation // code also need to be extended. MaxRPCPrice types.Currency `json:"maxrpcprice"` MaxContractPrice types.Currency `json:"maxcontractprice"` MaxDownloadBandwidthPrice types.Currency `json:"maxdownloadbandwidthprice"` MaxSectorAccessPrice types.Currency `json:"maxsectoraccessprice"` MaxStoragePrice types.Currency `json:"maxstorageprice"` MaxUploadBandwidthPrice types.Currency `json:"maxuploadbandwidthprice"` }
An Allowance dictates how much the Renter is allowed to spend in a given period. Note that funds are spent on both storage and bandwidth.
NOTE: When changing the allowance struct, any new or adjusted fields are going to be loaded as blank when the contractor first starts up. The startup code either needs to set sane defaults, or the code which depends on the values needs to appropriately handle the values being empty.
func (Allowance) Active ¶ added in v1.4.2
Active returns true if and only if this allowance has been set in the contractor.
func (Allowance) PortalMode ¶ added in v1.5.1
PortalMode returns true if the renter is supposed to act as a portal.
type AppFee ¶ added in v1.4.8
type AppFee struct { // Address of the developer wallet Address types.UnlockHash `json:"address"` // Amount of SC that the Fee is for Amount types.Currency `json:"amount"` // AppUID is a unique Application ID that the fee is for AppUID AppUID `json:"appuid"` // FeeUID is a unique identifier for the Fee FeeUID FeeUID `json:"feeuid"` // PaymentCompleted indicates whether the payment for this fee has // appeared on-chain. PaymentCompleted bool `json:"paymentcompleted"` // PayoutHeight is the height at which the fee will be paid out. PayoutHeight types.BlockHeight `json:"payoutheight"` // Recurring indicates whether or not this fee is a recurring fee and // will be charged in the next period as well // // NOTE: the application is responsible for submitting the fee again, // the FeeManager is not responsible for processing this fee on a // recurring basis Recurring bool `json:"recurring"` // Timestamp is the moment that the fee was requested. Timestamp int64 `json:"timestamp"` // TransactionCreated indicates whether the transaction for this fee has // been created and sent to the Sia network for processing. TransactionCreated bool `json:"transactioncreated"` }
AppFee is the struct that contains information about a fee submitted by an application to the FeeManager
type AppFeeByTimestamp ¶ added in v1.4.8
type AppFeeByTimestamp []AppFee
AppFeeByTimestamp is a helper struct for the ByTimestamp sort.
func (AppFeeByTimestamp) Len ¶ added in v1.4.8
func (afbt AppFeeByTimestamp) Len() int
func (AppFeeByTimestamp) Less ¶ added in v1.4.8
func (afbt AppFeeByTimestamp) Less(i, j int) bool
func (AppFeeByTimestamp) Swap ¶ added in v1.4.8
func (afbt AppFeeByTimestamp) Swap(i, j int)
type AppUID ¶ added in v1.4.8
type AppUID string
AppUID is a unique identifier for an application that had submitted a fee to the FeeManager
type BlockFacts ¶ added in v1.0.0
type BlockFacts struct { BlockID types.BlockID `json:"blockid"` Difficulty types.Currency `json:"difficulty"` EstimatedHashrate types.Currency `json:"estimatedhashrate"` Height types.BlockHeight `json:"height"` MaturityTimestamp types.Timestamp `json:"maturitytimestamp"` Target types.Target `json:"target"` TotalCoins types.Currency `json:"totalcoins"` // Transaction type counts. MinerPayoutCount uint64 `json:"minerpayoutcount"` TransactionCount uint64 `json:"transactioncount"` SiacoinInputCount uint64 `json:"siacoininputcount"` SiacoinOutputCount uint64 `json:"siacoinoutputcount"` FileContractCount uint64 `json:"filecontractcount"` FileContractRevisionCount uint64 `json:"filecontractrevisioncount"` StorageProofCount uint64 `json:"storageproofcount"` SiafundInputCount uint64 `json:"siafundinputcount"` SiafundOutputCount uint64 `json:"siafundoutputcount"` MinerFeeCount uint64 `json:"minerfeecount"` ArbitraryDataCount uint64 `json:"arbitrarydatacount"` TransactionSignatureCount uint64 `json:"transactionsignaturecount"` // Factoids about file contracts. ActiveContractCost types.Currency `json:"activecontractcost"` ActiveContractCount uint64 `json:"activecontractcount"` ActiveContractSize types.Currency `json:"activecontractsize"` TotalContractCost types.Currency `json:"totalcontractcost"` TotalContractSize types.Currency `json:"totalcontractsize"` TotalRevisionVolume types.Currency `json:"totalrevisionvolume"` }
BlockFacts returns a bunch of statistics about the consensus set as they were at a specific block.
type BlockManager ¶ added in v1.0.0
type BlockManager interface { // HeaderForWork returns a block header that can be grinded on and // resubmitted to the miner. HeaderForWork() will remember the block that // corresponds to the header for 50 calls. HeaderForWork() (types.BlockHeader, types.Target, error) // SubmitBlock accepts a solved block. SubmitBlock(types.Block) error // SubmitHeader takes a block header that has been worked on and has a // valid target. SubmitHeader(types.BlockHeader) error // BlocksMined returns the number of blocks and stale blocks that have been // mined using this miner. BlocksMined() (goodBlocks, staleBlocks int) }
BlockManager contains functions that can interface with external miners, providing and receiving blocks that have experienced nonce grinding.
type BudgetLimit ¶ added in v1.4.8
type BudgetLimit struct {
// contains filtered or unexported fields
}
BudgetLimit is an implementation of the BandwidthLimit interface which uses an RPCBudget to determine whether to allow for more bandwidth consumption or not.
func NewBudgetLimit ¶ added in v1.4.8
func NewBudgetLimit(budget *RPCBudget, readCost, writeCost types.Currency) *BudgetLimit
NewBudgetLimit creates a new limit from a budget and priceTable.
func (*BudgetLimit) Downloaded ¶ added in v1.4.8
func (bl *BudgetLimit) Downloaded() uint64
Downloaded implements the mux.BandwidthLimit interface.
func (*BudgetLimit) RecordDownload ¶ added in v1.4.8
func (bl *BudgetLimit) RecordDownload(bytes uint64) error
RecordDownload implements the mux.BandwidthLimit interface.
func (*BudgetLimit) RecordUpload ¶ added in v1.4.8
func (bl *BudgetLimit) RecordUpload(bytes uint64) error
RecordUpload implements the mux.BandwidthLimit interface.
func (*BudgetLimit) UpdateCosts ¶ added in v1.5.5
func (bl *BudgetLimit) UpdateCosts(readCost, writeCost types.Currency)
UpdateCosts updates the limit's underlying readCost and writeCost.
func (*BudgetLimit) Uploaded ¶ added in v1.4.8
func (bl *BudgetLimit) Uploaded() uint64
Uploaded implements the mux.BandwidthLimit interface.
type CPUMiner ¶ added in v1.0.0
type CPUMiner interface { // CPUHashrate returns the hashrate of the cpu miner in hashes per second. CPUHashrate() int // Mining returns true if the cpu miner is enabled, and false otherwise. CPUMining() bool // StartMining turns on the miner, which will endlessly work for new // blocks. StartCPUMining() // StopMining turns off the miner, but keeps the same number of threads. StopCPUMining() }
CPUMiner provides access to a single-threaded cpu miner.
type CombinedChunkID ¶ added in v1.4.2
type CombinedChunkID string
CombinedChunkID is a unique identifier for a combined chunk which makes up part of its filename on disk.
type ConsensusChange ¶ added in v0.3.3
type ConsensusChange struct { // ID is a unique id for the consensus change derived from the reverted // and applied blocks. ID ConsensusChangeID // RevertedBlocks is the list of blocks that were reverted by the change. // The reverted blocks were always all reverted before the applied blocks // were applied. The revered blocks are presented in the order that they // were reverted. RevertedBlocks []types.Block // AppliedBlocks is the list of blocks that were applied by the change. The // applied blocks are always all applied after all the reverted blocks were // reverted. The applied blocks are presented in the order that they were // applied. AppliedBlocks []types.Block // RevertedDiffs is the set of diffs caused by reverted blocks. Each // element corresponds to a block in RevertedBlocks. RevertedDiffs []ConsensusChangeDiffs // AppliedDiffs is the set of diffs caused by applied blocks. Each // element corresponds to a block in AppliedBlocks. AppliedDiffs []ConsensusChangeDiffs // ConsensusChangeDiffs is the concatenation of all RevertedDiffs and // AppliedDiffs. ConsensusChangeDiffs // ChildTarget defines the target of any block that would be the child // of the block most recently appended to the consensus set. ChildTarget types.Target // MinimumValidChildTimestamp defines the minimum allowed timestamp for // any block that is the child of the block most recently appended to // the consensus set. MinimumValidChildTimestamp types.Timestamp // Synced indicates whether or not the ConsensusSet is synced with its // peers. Synced bool // TryTransactionSet is an unlocked version of // ConsensusSet.TryTransactionSet. This allows the TryTransactionSet // function to be called by a subscriber during // ProcessConsensusChange. TryTransactionSet func([]types.Transaction) (ConsensusChange, error) }
A ConsensusChange enumerates a set of changes that occurred to the consensus set.
func (*ConsensusChange) AppendDiffs ¶ added in v1.5.1
func (cc *ConsensusChange) AppendDiffs(diffs ConsensusChangeDiffs)
AppendDiffs appends a set of diffs to cc.
func (ConsensusChange) MarshalSia ¶ added in v1.4.9
func (cc ConsensusChange) MarshalSia(w io.Writer) error
MarshalSia implements encoding.SiaMarshaler.
func (*ConsensusChange) UnmarshalSia ¶ added in v1.4.9
func (cc *ConsensusChange) UnmarshalSia(r io.Reader) error
UnmarshalSia implements encoding.SiaUnmarshaler.
type ConsensusChangeDiffs ¶ added in v1.5.1
type ConsensusChangeDiffs struct { SiacoinOutputDiffs []SiacoinOutputDiff FileContractDiffs []FileContractDiff SiafundOutputDiffs []SiafundOutputDiff DelayedSiacoinOutputDiffs []DelayedSiacoinOutputDiff SiafundPoolDiffs []SiafundPoolDiff }
ConsensusChangeDiffs is a collection of diffs caused by a single block. If the block was reverted, the individual diff directions are inverted. For example, a block that spends an output and creates a miner payout would have one SiacoinOutputDiff with direction DiffRevert and one DelayedSiacoinOutputDiff with direction DiffApply. If the same block were reverted, the SCOD would have direction DiffApply and the DSCOD would have direction DiffRevert.
type ConsensusChangeID ¶ added in v1.0.0
ConsensusChangeID is the id of a consensus change.
func (ConsensusChangeID) String ¶ added in v1.4.2
func (ccID ConsensusChangeID) String() string
String returns the ConsensusChangeID as a string.
type ConsensusConflict ¶ added in v1.0.0
type ConsensusConflict string
ConsensusConflict implements the error interface, and indicates that a transaction was rejected due to being incompatible with the current consensus set, meaning either a double spend or a consensus rule violation - it is unlikely that the transaction will ever be valid.
func NewConsensusConflict ¶ added in v1.0.0
func NewConsensusConflict(s string) ConsensusConflict
NewConsensusConflict returns a consensus conflict, which implements the error interface.
func (ConsensusConflict) Error ¶ added in v1.0.0
func (cc ConsensusConflict) Error() string
Error implements the error interface, turning the consensus conflict into an acceptable error type.
type ConsensusSet ¶ added in v0.3.2
type ConsensusSet interface { Alerter // AcceptBlock adds a block to consensus. An error will be returned if the // block is invalid, has been seen before, is an orphan, or doesn't // contribute to the heaviest fork known to the consensus set. If the block // does not become the head of the heaviest known fork but is otherwise // valid, it will be remembered by the consensus set but an error will // still be returned. AcceptBlock(types.Block) error // BlockAtHeight returns the block found at the input height, with a // bool to indicate whether that block exists. BlockAtHeight(types.BlockHeight) (types.Block, bool) // BlocksByID returns a block found for a given ID and its height, with // a bool to indicate whether that block exists. BlockByID(types.BlockID) (types.Block, types.BlockHeight, bool) // ChildTarget returns the target required to extend the current heaviest // fork. This function is typically used by miners looking to extend the // heaviest fork. ChildTarget(types.BlockID) (types.Target, bool) // Close will shut down the consensus set, giving the module enough time to // run any required closing routines. Close() error // ConsensusSetSubscribe adds a subscriber to the list of subscribers // and gives them every consensus change that has occurred since the // change with the provided id. There are a few special cases, // described by the ConsensusChangeX variables in this package. // A channel can be provided to abort the subscription process. ConsensusSetSubscribe(ConsensusSetSubscriber, ConsensusChangeID, <-chan struct{}) error // CurrentBlock returns the latest block in the heaviest known // blockchain. CurrentBlock() types.Block // Height returns the current height of consensus. Height() types.BlockHeight // Synced returns true if the consensus set is synced with the network. Synced() bool // InCurrentPath returns true if the block id presented is found in the // current path, false otherwise. InCurrentPath(types.BlockID) bool // MinimumValidChildTimestamp returns the earliest timestamp that is // valid on the current longest fork according to the consensus set. This is // a required piece of information for the miner, who could otherwise be at // risk of mining invalid blocks. MinimumValidChildTimestamp(types.BlockID) (types.Timestamp, bool) // StorageProofSegment returns the segment to be used in the storage proof for // a given file contract. StorageProofSegment(types.FileContractID) (uint64, error) // FoundationUnlockHashes returns the current primary and failsafe // Foundation UnlockHashes. FoundationUnlockHashes() (primary, failsafe types.UnlockHash) // TryTransactionSet checks whether the transaction set would be valid if // it were added in the next block. A consensus change is returned // detailing the diffs that would result from the application of the // transaction. TryTransactionSet([]types.Transaction) (ConsensusChange, error) // Unsubscribe removes a subscriber from the list of subscribers, // allowing for garbage collection and rescanning. If the subscriber is // not found in the subscriber database, no action is taken. Unsubscribe(ConsensusSetSubscriber) }
A ConsensusSet accepts blocks and builds an understanding of network consensus.
type ConsensusSetSubscriber ¶ added in v0.3.2
type ConsensusSetSubscriber interface { // ProcessConsensusChange sends a consensus update to a module through // a function call. Updates will always be sent in the correct order. // There may not be any reverted blocks, but there will always be // applied blocks. ProcessConsensusChange(ConsensusChange) }
A ConsensusSetSubscriber is an object that receives updates to the consensus set every time there is a change in consensus.
type ContractParams ¶ added in v1.5.5
type ContractParams struct { Allowance Allowance Host HostDBEntry Funding types.Currency StartHeight types.BlockHeight EndHeight types.BlockHeight RefundAddress types.UnlockHash RenterSeed EphemeralRenterSeed }
ContractParams are supplied as an argument to FormContract.
type ContractSignedIdentifier ¶ added in v1.5.5
type ContractSignedIdentifier [FCSignedIdentiferSize]byte
ContractSignedIdentifier is an identifier with a prefix and appended signature, ready to be stored in the arbitrary data section of a transaction.
func PrefixedSignedIdentifier ¶ added in v1.5.5
func PrefixedSignedIdentifier(renterSeed EphemeralRenterSeed, txn types.Transaction, hostKey types.SiaPublicKey) (ContractSignedIdentifier, crypto.Ciphertext)
PrefixedSignedIdentifier is a helper function that creates a prefixed and signed identifier using a renter key and the first siacoin input of a transaction. NOTE: Always use PrefixedSignedIdentifier when creating identifiers for filecontracts. It wipes all the secrets required for creating the identifier from memory safely.
func (ContractSignedIdentifier) IsValid ¶ added in v1.5.5
func (csi ContractSignedIdentifier) IsValid(renterSeed EphemeralRenterSeed, txn types.Transaction, hostKey crypto.Ciphertext) (types.SiaPublicKey, bool, error)
IsValid checks the signature against a seed and contract to determine if it was created using the specified seed.
type ContractUtility ¶ added in v1.3.1
type ContractUtility struct { GoodForUpload bool `json:"goodforupload"` GoodForRenew bool `json:"goodforrenew"` // BadContract will be set to true if there's good reason to believe that // the contract is unusable and will continue to be unusable. For example, // if the host is claiming that the contract does not exist, the contract // should be marked as bad. BadContract bool `json:"badcontract"` LastOOSErr types.BlockHeight `json:"lastooserr"` // OOS means Out Of Storage // If a contract is locked, the utility should not be updated. 'Locked' is a // value that gets persisted. Locked bool `json:"locked"` }
ContractUtility contains metrics internal to the contractor that reflect the utility of a given contract.
type ContractWatchStatus ¶ added in v1.4.2
type ContractWatchStatus struct { Archived bool `json:"archived"` FormationSweepHeight types.BlockHeight `json:"formationsweepheight"` ContractFound bool `json:"contractfound"` LatestRevisionFound uint64 `json:"latestrevisionfound"` StorageProofFoundAtHeight types.BlockHeight `json:"storageprooffoundatheight"` DoubleSpendHeight types.BlockHeight `json:"doublespendheight"` WindowStart types.BlockHeight `json:"windowstart"` WindowEnd types.BlockHeight `json:"windowend"` }
ContractWatchStatus provides information about the status of a contract in the renter's watchdog.
type ContractorChurnStatus ¶ added in v1.4.2
type ContractorChurnStatus struct { // AggregateCurrentPeriodChurn is the total size of files from churned contracts in this // period. AggregateCurrentPeriodChurn uint64 `json:"aggregatecurrentperiodchurn"` // MaxPeriodChurn is the (adjustable) maximum churn allowed per period. MaxPeriodChurn uint64 `json:"maxperiodchurn"` }
ContractorChurnStatus contains the current churn budgets for the Contractor's churnLimiter and the aggregate churn for the current period.
type ContractorSpending ¶ added in v1.3.1
type ContractorSpending struct { // ContractFees are the sum of all fees in the contract. This means it // includes the ContractFee, TxnFee and SiafundFee ContractFees types.Currency `json:"contractfees"` // DownloadSpending is the money currently spent on downloads. DownloadSpending types.Currency `json:"downloadspending"` // StorageSpending is the money currently spent on storage. StorageSpending types.Currency `json:"storagespending"` // ContractSpending is the total amount of money that the renter has put // into contracts, whether it's locked and the renter gets that money // back or whether it's spent and the renter won't get the money back. TotalAllocated types.Currency `json:"totalallocated"` // UploadSpending is the money currently spent on uploads. UploadSpending types.Currency `json:"uploadspending"` // Unspent is locked-away, unspent money. Unspent types.Currency `json:"unspent"` // ContractSpendingDeprecated was renamed to TotalAllocated and always has the // same value as TotalAllocated. ContractSpendingDeprecated types.Currency `json:"contractspending,siamismatch"` // WithheldFunds are the funds from the previous period that are tied up // in contracts and have not been released yet WithheldFunds types.Currency `json:"withheldfunds"` // ReleaseBlock is the block at which the WithheldFunds should be // released to the renter, based on worst case. // Contract End Height + Host Window Size + Maturity Delay ReleaseBlock types.BlockHeight `json:"releaseblock"` // PreviousSpending is the total spend funds from old contracts // that are not included in the current period spending PreviousSpending types.Currency `json:"previousspending"` }
ContractorSpending contains the metrics about how much the Contractor has spent during the current billing period.
type DataSourceID ¶ added in v1.5.1
DataSourceID is an identifier to uniquely identify a data source, such as for loading a file. Adding data sources that have the same ID should return the exact same data when queried. This is typically used inside of the renter to build stream buffers.
type DelayedSiacoinOutputDiff ¶ added in v0.3.3
type DelayedSiacoinOutputDiff struct { Direction DiffDirection ID types.SiacoinOutputID SiacoinOutput types.SiacoinOutput MaturityHeight types.BlockHeight }
A DelayedSiacoinOutputDiff indicates the introduction of a siacoin output that cannot be spent until after maturing for 144 blocks. When the output has matured, a SiacoinOutputDiff will be provided.
type Dependencies ¶ added in v1.3.2
type Dependencies interface { // NebulousAddress will return an address that can be used to send // SiaCoin to a Nebulous managed Wallet. NebulousAddress() types.UnlockHash // AtLeastOne will return a value that is at least one. In production, // the value should always be one. This function is used to test the // idempotence of actions, so during testing sometimes the value // returned will be higher, causing an idempotent action to be // committed multiple times. If the action is truly idempotent, // committing it multiple times should not cause any problems or // changes. AtLeastOne() uint64 // CreateFile gives the host the ability to create files on the // operating system. CreateFile(string) (File, error) // Destruct will clean up the dependencies, panicking if there are // unclosed resources. Destruct() // DialTimeout tries to create a tcp connection to the specified // address with a certain timeout. DialTimeout(NetAddress, time.Duration) (net.Conn, error) // Disrupt can be inserted in the code as a way to inject problems, // such as a network call that take 10 minutes or a disk write that // never completes. disrupt will return true if the disruption is // forcibly triggered. In production, disrupt will always return false. Disrupt(string) bool // Listen gives the host the ability to receive incoming connections. Listen(string, string) (net.Listener, error) // LoadFile allows the host to load a persistence structure form disk. LoadFile(persist.Metadata, interface{}, string) error // LookupIP resolves a hostname to a number of IP addresses. If an IP // address is provided as an argument it will just return that IP. LookupIP(string) ([]net.IP, error) // MkdirAll gives the host the ability to create chains of folders // within the filesystem. MkdirAll(string, os.FileMode) error // NewLogger creates a logger that the host can use to log messages and // write critical statements. NewLogger(string) (*persist.Logger, error) // OpenDatabase creates a database that the host can use to interact // with large volumes of persistent data. OpenDatabase(persist.Metadata, string) (*persist.BoltDatabase, error) // Open opens a file readonly. Open(string) (File, error) // OpenFile opens a file with the specified mode. OpenFile(string, int, os.FileMode) (File, error) // Resolver returns a Resolver which can resolve hostnames to IPs. Resolver() Resolver // RandRead fills the input bytes with random data. RandRead([]byte) (int, error) // ReadFile reads a file in full from the filesystem. ReadFile(string) ([]byte, error) // RemoveFile removes a file from file filesystem. RemoveFile(string) error // RenameFile renames a file on disk to another name. RenameFile(string, string) error // SaveFileSync writes JSON encoded data to disk and syncs the file // afterwards. SaveFileSync(persist.Metadata, interface{}, string) error // Sleep blocks the calling thread for at least the specified duration. Sleep(time.Duration) // Symlink creates a sym link between a source and a destination. Symlink(s1, s2 string) error // WriteFile writes data to the filesystem using the provided filename. WriteFile(string, []byte, os.FileMode) error }
Dependencies defines dependencies used by all of Sia's modules. Custom dependencies can be created to inject certain behavior during testing.
type DiffDirection ¶ added in v0.3.1
type DiffDirection bool
A DiffDirection indicates the "direction" of a diff, either applied or reverted. A bool is used to restrict the value to these two possibilities.
const ( // ConsensusDir is the name of the directory used for all of the consensus // persistence files. ConsensusDir = "consensus" // DiffApply indicates that a diff is being applied to the consensus set. DiffApply DiffDirection = true // DiffRevert indicates that a diff is being reverted from the consensus // set. DiffRevert DiffDirection = false )
type DirListFunc ¶ added in v1.5.4
type DirListFunc func(DirectoryInfo)
DirListFunc is a type that's passed in to functions related to iterating over the filesystem.
type DirectoryInfo ¶ added in v1.4.0
type DirectoryInfo struct { // The following fields are aggregate values of the siadir. These values are // the totals of the siadir and any sub siadirs, or are calculated based on // all the values in the subtree AggregateHealth float64 `json:"aggregatehealth"` AggregateLastHealthCheckTime time.Time `json:"aggregatelasthealthchecktime"` AggregateMaxHealth float64 `json:"aggregatemaxhealth"` AggregateMaxHealthPercentage float64 `json:"aggregatemaxhealthpercentage"` AggregateMinRedundancy float64 `json:"aggregateminredundancy"` AggregateMostRecentModTime time.Time `json:"aggregatemostrecentmodtime"` AggregateNumFiles uint64 `json:"aggregatenumfiles"` AggregateNumStuckChunks uint64 `json:"aggregatenumstuckchunks"` AggregateNumSubDirs uint64 `json:"aggregatenumsubdirs"` AggregateRepairSize uint64 `json:"aggregaterepairsize"` AggregateSize uint64 `json:"aggregatesize"` AggregateStuckHealth float64 `json:"aggregatestuckhealth"` // Skynet Fields AggregateSkynetFiles uint64 `json:"aggregateskynetfiles"` AggregateSkynetSize uint64 `json:"aggregateskynetsize"` // The following fields are information specific to the siadir that is not // an aggregate of the entire sub directory tree Health float64 `json:"health"` LastHealthCheckTime time.Time `json:"lasthealthchecktime"` MaxHealthPercentage float64 `json:"maxhealthpercentage"` MaxHealth float64 `json:"maxhealth"` MinRedundancy float64 `json:"minredundancy"` DirMode os.FileMode `json:"mode,siamismatch"` // Field is called DirMode for fuse compatibility MostRecentModTime time.Time `json:"mostrecentmodtime"` NumFiles uint64 `json:"numfiles"` NumStuckChunks uint64 `json:"numstuckchunks"` NumSubDirs uint64 `json:"numsubdirs"` RepairSize uint64 `json:"repairsize"` SiaPath SiaPath `json:"siapath"` DirSize uint64 `json:"size,siamismatch"` // Stays as 'size' in json for compatibility StuckHealth float64 `json:"stuckhealth"` UID uint64 `json:"uid"` // Skynet Fields SkynetFiles uint64 `json:"skynetfiles"` SkynetSize uint64 `json:"skynetsize"` }
DirectoryInfo provides information about a siadir
func (DirectoryInfo) IsDir ¶ added in v1.4.2
func (d DirectoryInfo) IsDir() bool
IsDir implements os.FileInfo.
func (DirectoryInfo) ModTime ¶ added in v1.4.2
func (d DirectoryInfo) ModTime() time.Time
ModTime implements os.FileInfo.
func (DirectoryInfo) Mode ¶ added in v1.4.2
func (d DirectoryInfo) Mode() os.FileMode
Mode implements os.FileInfo.
func (DirectoryInfo) Name ¶ added in v1.4.2
func (d DirectoryInfo) Name() string
Name implements os.FileInfo.
func (DirectoryInfo) Size ¶ added in v1.4.1
func (d DirectoryInfo) Size() int64
Size implements os.FileInfo.
func (DirectoryInfo) Sys ¶ added in v1.4.2
func (d DirectoryInfo) Sys() interface{}
Sys implements os.FileInfo.
type DownloadAction ¶ added in v1.0.0
A DownloadAction is a description of a download that the renter would like to make. The MerkleRoot indicates the root of the sector, the offset indicates what portion of the sector is being downloaded, and the length indicates how many bytes should be grabbed starting from the offset.
type DownloadID ¶ added in v1.4.2
type DownloadID string
DownloadID is a unique identifier used to identify downloads within the download history.
type DownloadInfo ¶
type DownloadInfo struct { Destination string `json:"destination"` // The destination of the download. DestinationType string `json:"destinationtype"` // Can be "file", "memory buffer", or "http stream". Length uint64 `json:"length"` // The length requested for the download. Offset uint64 `json:"offset"` // The offset within the siafile requested for the download. SiaPath SiaPath `json:"siapath"` // The siapath of the file used for the download. Completed bool `json:"completed"` // Whether or not the download has completed. EndTime time.Time `json:"endtime"` // The time when the download fully completed. Error string `json:"error"` // Will be the empty string unless there was an error. Received uint64 `json:"received"` // Amount of data confirmed and decoded. StartTime time.Time `json:"starttime"` // The time when the download was started. StartTimeUnix int64 `json:"starttimeunix"` // The time when the download was started in unix format. TotalDataTransferred uint64 `json:"totaldatatransferred"` // Total amount of data transferred, including negotiation, etc. }
DownloadInfo provides information about a file that has been requested for download.
type EncryptionManager ¶ added in v1.0.0
type EncryptionManager interface { // Encrypt will encrypt the wallet using the input key. Upon // encryption, a primary seed will be created for the wallet (no seed // exists prior to this point). If the key is blank, then the hash of // the seed that is generated will be used as the key. // // Encrypt can only be called once throughout the life of the wallet // and will return an error on subsequent calls (even after restarting // the wallet). To reset the wallet, the wallet files must be moved to // a different directory or deleted. Encrypt(masterKey crypto.CipherKey) (Seed, error) // Reset will reset the wallet, clearing the database and returning it to // the unencrypted state. Reset can only be called on a wallet that has // already been encrypted. Reset() error // Encrypted returns whether or not the wallet has been encrypted yet. // After being encrypted for the first time, the wallet can only be // unlocked using the encryption password. Encrypted() (bool, error) // InitFromSeed functions like Encrypt, but using a specified seed. // Unlike Encrypt, the blockchain will be scanned to determine the // seed's progress. For this reason, InitFromSeed should not be called // until the blockchain is fully synced. InitFromSeed(masterKey crypto.CipherKey, seed Seed) error // Lock deletes all keys in memory and prevents the wallet from being // used to spend coins or extract keys until 'Unlock' is called. Lock() error // Unlock must be called before the wallet is usable. All wallets and // wallet seeds are encrypted by default, and the wallet will not know // which addresses to watch for on the blockchain until unlock has been // called. // // All items in the wallet are encrypted using different keys which are // derived from the master key. Unlock(masterKey crypto.CipherKey) error // UnlockAsync must be called before the wallet is usable. All wallets and // wallet seeds are encrypted by default, and the wallet will not know // which addresses to watch for on the blockchain until unlock has been // called. // UnlockAsync will return a channel as soon as the wallet is unlocked but // before the wallet is caught up to consensus. // // All items in the wallet are encrypted using different keys which are // derived from the master key. UnlockAsync(masterKey crypto.CipherKey) <-chan error // ChangeKey changes the wallet's materKey from masterKey to newKey, // re-encrypting the wallet with the provided key. ChangeKey(masterKey crypto.CipherKey, newKey crypto.CipherKey) error // IsMasterKey verifies that the masterKey is the key used to encrypt // the wallet. IsMasterKey(masterKey crypto.CipherKey) (bool, error) // ChangeKeyWithSeed is the same as ChangeKey but uses the primary seed // instead of the current masterKey. ChangeKeyWithSeed(seed Seed, newKey crypto.CipherKey) error // Unlocked returns true if the wallet is currently unlocked, false // otherwise. Unlocked() (bool, error) }
EncryptionManager can encrypt, lock, unlock, and indicate the current status of the EncryptionManager.
type EphemeralRenterSeed ¶ added in v1.5.5
type EphemeralRenterSeed RenterSeed
EphemeralRenterSeed is a renter seed derived from the master renter seed. The master seed should never be used directly.
type ErasureCoder ¶ added in v1.0.0
type ErasureCoder interface { // NumPieces is the number of pieces returned by Encode. NumPieces() int // MinPieces is the minimum number of pieces that must be present to // recover the original data. MinPieces() int // Encode splits data into equal-length pieces, with some pieces // containing parity data. Encode(data []byte) ([][]byte, error) // Identifier returns the ErasureCoderIdentifier of the ErasureCoder. Identifier() ErasureCoderIdentifier // EncodeShards encodes the input data like Encode but accepts an already // sharded input. EncodeShards(data [][]byte) ([][]byte, error) // Reconstruct recovers the full set of encoded shards from the provided // pieces, of which at least MinPieces must be non-nil. Reconstruct(pieces [][]byte) error // Recover recovers the original data from pieces and writes it to w. // pieces should be identical to the slice returned by Encode (length // and order must be preserved), but with missing elements set to nil. n // is the number of bytes to be written to w; this is necessary because // pieces may have been padded with zeros during encoding. Recover(pieces [][]byte, n uint64, w io.Writer) error // SupportsPartialEncoding returns true if partial encoding is // supported. The piece segment size will be returned. Otherwise the // numerical return value is set to zero. SupportsPartialEncoding() (uint64, bool) // Type returns the type identifier of the ErasureCoder. Type() ErasureCoderType }
An ErasureCoder is an error-correcting encoder and decoder.
func NewPassthroughErasureCoder ¶ added in v1.5.1
func NewPassthroughErasureCoder() ErasureCoder
NewPassthroughErasureCoder will return an erasure coder that does not encode the data. It uses 1-of-1 redundancy and always returns itself or some subset of itself.
func NewRSCode ¶ added in v1.5.1
func NewRSCode(nData, nParity int) (ErasureCoder, error)
NewRSCode creates a new Reed-Solomon encoder/decoder using the supplied parameters.
func NewRSCodeDefault ¶ added in v1.5.1
func NewRSCodeDefault() ErasureCoder
NewRSCodeDefault creates a new Reed-Solomon encoder/decoder using the default parameters.
func NewRSSubCode ¶ added in v1.5.1
func NewRSSubCode(nData, nParity int, segmentSize uint64) (ErasureCoder, error)
NewRSSubCode creates a new Reed-Solomon encoder/decoder using the supplied parameters.
func NewRSSubCodeDefault ¶ added in v1.5.1
func NewRSSubCodeDefault() ErasureCoder
NewRSSubCodeDefault creates a new Reed-Solomon encoder/decoder using the default parameters and the default segment size.
type ErasureCoderIdentifier ¶ added in v1.4.2
type ErasureCoderIdentifier string
ErasureCoderIdentifier is an identifier that only matches another ErasureCoder's identifier if they both are of the same type and settings.
type ErasureCoderType ¶ added in v1.4.0
type ErasureCoderType [4]byte
ErasureCoderType is an identifier for the individual types of erasure coders.
type Explorer ¶ added in v1.0.0
type Explorer interface { Alerter // Block returns the block that matches the input block id. The bool // indicates whether the block appears in the blockchain. Block(types.BlockID) (types.Block, types.BlockHeight, bool) // BlockFacts returns a set of statistics about the blockchain as they // appeared at a given block. BlockFacts(types.BlockHeight) (BlockFacts, bool) // LatestBlockFacts returns the block facts of the last block // in the explorer's database. LatestBlockFacts() BlockFacts // Transaction returns the block that contains the input transaction // id. The transaction itself is either the block (indicating the miner // payouts are somehow involved), or it is a transaction inside of the // block. The bool indicates whether the transaction is found in the // consensus set. Transaction(types.TransactionID) (types.Block, types.BlockHeight, bool) // UnlockHash returns all of the transaction ids associated with the // provided unlock hash. UnlockHash(types.UnlockHash) []types.TransactionID // SiacoinOutput will return the siacoin output associated with the // input id. SiacoinOutput(types.SiacoinOutputID) (types.SiacoinOutput, bool) // SiacoinOutputID returns all of the transaction ids associated with // the provided siacoin output id. SiacoinOutputID(types.SiacoinOutputID) []types.TransactionID // FileContractHistory returns the history associated with a file // contract, which includes the file contract itself and all of the // revisions that have been submitted to the blockchain. The first bool // indicates whether the file contract exists, and the second bool // indicates whether a storage proof was successfully submitted for the // file contract. FileContractHistory(types.FileContractID) (fc types.FileContract, fcrs []types.FileContractRevision, fcExists bool, storageProofExists bool) // FileContractID returns all of the transaction ids associated with // the provided file contract id. FileContractID(types.FileContractID) []types.TransactionID // SiafundOutput will return the siafund output associated with the // input id. SiafundOutput(types.SiafundOutputID) (types.SiafundOutput, bool) // SiafundOutputID returns all of the transaction ids associated with // the provided siafund output id. SiafundOutputID(types.SiafundOutputID) []types.TransactionID Close() error }
Explorer tracks the blockchain and provides tools for gathering statistics and finding objects or patterns within the blockchain.
type FeeManager ¶ added in v1.4.5
type FeeManager interface { // AddFee adds a fee for the FeeManager to manage, returning the UID of // the fee. AddFee(address types.UnlockHash, amount types.Currency, appUID AppUID, recurring bool) (FeeUID, error) // CancelFee cancels the fee associated with the FeeUID CancelFee(feeUID FeeUID) error // Close closes the FeeManager Close() error // PaidFees returns all the paid fees that are being tracked by the // FeeManager PaidFees() ([]AppFee, error) // PayoutHeight returns the nextPayoutHeight of the FeeManager PayoutHeight() (types.BlockHeight, error) // PendingFees returns all the pending fees that are being tracked by the // FeeManager PendingFees() ([]AppFee, error) }
FeeManager manages fees for applications
type FeeUID ¶ added in v1.4.8
type FeeUID string
FeeUID is a unique identifier for a fee that is being managed by the FeeManager
type File ¶ added in v1.3.2
type File interface { io.ReadWriteCloser Name() string ReadAt([]byte, int64) (int, error) Seek(int64, int) (int64, error) Stat() (os.FileInfo, error) Sync() error Truncate(int64) error WriteAt([]byte, int64) (int, error) }
File implements all of the methods that can be called on an os.File.
type FileContractDiff ¶ added in v0.3.1
type FileContractDiff struct { Direction DiffDirection ID types.FileContractID FileContract types.FileContract }
A FileContractDiff indicates the addition or removal of a FileContract in the consensus set.
type FileInfo ¶
type FileInfo struct { AccessTime time.Time `json:"accesstime"` Available bool `json:"available"` ChangeTime time.Time `json:"changetime"` CipherType string `json:"ciphertype"` CreateTime time.Time `json:"createtime"` Expiration types.BlockHeight `json:"expiration"` Filesize uint64 `json:"filesize"` Health float64 `json:"health"` LocalPath string `json:"localpath"` MaxHealth float64 `json:"maxhealth"` MaxHealthPercent float64 `json:"maxhealthpercent"` ModificationTime time.Time `json:"modtime,siamismatch"` // Stays as 'modtime' in json for compatibility FileMode os.FileMode `json:"mode,siamismatch"` // Field is called FileMode for fuse compatibility NumStuckChunks uint64 `json:"numstuckchunks"` OnDisk bool `json:"ondisk"` Recoverable bool `json:"recoverable"` Redundancy float64 `json:"redundancy"` Renewing bool `json:"renewing"` Skylinks []string `json:"skylinks"` SiaPath SiaPath `json:"siapath"` Stuck bool `json:"stuck"` StuckHealth float64 `json:"stuckhealth"` UID uint64 `json:"uid"` UploadedBytes uint64 `json:"uploadedbytes"` UploadProgress float64 `json:"uploadprogress"` }
FileInfo provides information about a file.
type FileListFunc ¶ added in v1.5.4
type FileListFunc func(FileInfo)
FileListFunc is a type that's passed in to functions related to iterating over the filesystem.
type FilePlacement ¶ added in v1.4.4
FilePlacement contains the sector of a file and its offset in the sector.
func PackFiles ¶ added in v1.4.4
func PackFiles(files map[string]uint64) ([]FilePlacement, uint64, error)
PackFiles packs files, given as a map (id => size), into sectors in an efficient manner. Returns a FilePlacement slice and the number of sectors.
1. Sort the files by size in descending order.
2. Going from larger to smaller files, try to fit each file into an available bucket in a sector.
a. The first of the largest available buckets should be chosen. b. The first byte of the file must be aligned to a certain multiple of KiB, based on its size. i. For a file size up to 32*2^n KiB, the file must align to 4*2^n KiB, for 0 <= n <= 7. ii. Alignment is based on the start of the sector, not the bucket. iii. Alignment may cause a file not to fit into an otherwise large-enough bucket. c. If there are no suitable buckets, create a new sector and a new bucket in that sector that fills the whole sector.
3. Pack the file into the bucket at the correct alignment.
a. Delete the bucket and make up to 2 new buckets. The new buckets, if any, should stay ordered with regards to their positions in the sectors: i. If the file could not align to the start of the bucket, make a new bucket from the start of the old bucket to the start of the file. ii. If the file does not go to the end of the bucket, make a new bucket that goes from the end of the file to the end of the old bucket.
4. Return the slice of file placements in the order that they were packed chronologically. Note that they may be out of order positionally, as smaller files may be packed in lower offsets than larger files despite appearing later in the slice.
type FileUploadParams ¶ added in v0.3.1
type FileUploadParams struct { Source string SiaPath SiaPath ErasureCode ErasureCoder Force bool DisablePartialChunk bool Repair bool // CipherType was added later. If it is left blank, the renter will use the // default encryption method (as of writing, Threefish) CipherType crypto.CipherType // CipherKey was added in v1.5.0. If it is left blank, the renter will use it // to create a CipherKey with the given CipherType. This value override // CipherType if it is set. CipherKey crypto.CipherKey }
FileUploadParams contains the information used by the Renter to upload a file.
type FilterMode ¶ added in v1.4.0
type FilterMode int
FilterMode is the helper type for the enum constants for the HostDB filter mode
const ( HostDBFilterError FilterMode = iota HostDBDisableFilter HostDBActivateBlacklist HostDBActiveWhitelist )
HostDBFilterError HostDBDisableFilter HostDBActivateBlacklist and HostDBActiveWhitelist are the constants used to enable and disable the filter mode of the renter's hostdb
func (*FilterMode) FromString ¶ added in v1.4.0
func (fm *FilterMode) FromString(s string) error
FromString assigned the FilterMode from the provide string
func (FilterMode) String ¶ added in v1.4.0
func (fm FilterMode) String() string
String returns the string value for the FilterMode
type FundAccountRequest ¶ added in v1.4.8
type FundAccountRequest struct {
Account AccountID
}
FundAccountRequest specifies the ephemeral account id that gets funded.
type FundAccountResponse ¶ added in v1.4.8
type FundAccountResponse struct { Balance types.Currency Receipt Receipt Signature crypto.Signature }
FundAccountResponse contains the signature. This signature is a signed receipt, and can be used as proof of funding.
type Gateway ¶
type Gateway interface { Alerter // BandwidthCounters returns the Gateway's upload and download bandwidth BandwidthCounters() (uint64, uint64, time.Time, error) // Connect establishes a persistent connection to a peer. Connect(NetAddress) error // ConnectManual is a Connect wrapper for a user-initiated Connect ConnectManual(NetAddress) error // Disconnect terminates a connection to a peer. Disconnect(NetAddress) error // DiscoverAddress discovers and returns the current public IP address // of the gateway. Contrary to Address, DiscoverAddress is blocking and // might take multiple minutes to return. A channel to cancel the // discovery can be supplied optionally. DiscoverAddress(cancel <-chan struct{}) (net.IP, error) // ForwardPort adds a port mapping to the router. It will block until // the mapping is established or until it is interrupted by a shutdown. ForwardPort(port string) error // DisconnectManual is a Disconnect wrapper for a user-initiated // disconnect DisconnectManual(NetAddress) error // AddToBlocklist adds addresses to the blocklist of the gateway AddToBlocklist(addresses []string) error // Blocklist returns the current blocklist of the Gateway Blocklist() ([]string, error) // RemoveFromBlocklist removes addresses from the blocklist of the // gateway RemoveFromBlocklist(addresses []string) error // SetBlocklist sets the blocklist of the gateway SetBlocklist(addresses []string) error // Address returns the Gateway's address. Address() NetAddress // Peers returns the addresses that the Gateway is currently connected // to. Peers() []Peer // RegisterRPC registers a function to handle incoming connections that // supply the given RPC ID. RegisterRPC(string, RPCFunc) // RateLimits returns the currently set bandwidth limits of the gateway. RateLimits() (int64, int64) // SetRateLimits changes the rate limits for the peer-connections of the // gateway. SetRateLimits(downloadSpeed, uploadSpeed int64) error // UnregisterRPC unregisters an RPC and removes all references to the // RPCFunc supplied in the corresponding RegisterRPC call. References to // RPCFuncs registered with RegisterConnectCall are not removed and // should be removed with UnregisterConnectCall. If the RPC does not // exist no action is taken. UnregisterRPC(string) // RegisterConnectCall registers an RPC name and function to be called // upon connecting to a peer. RegisterConnectCall(string, RPCFunc) // UnregisterConnectCall unregisters an RPC and removes all references to the // RPCFunc supplied in the corresponding RegisterConnectCall call. References // to RPCFuncs registered with RegisterRPC are not removed and should be // removed with UnregisterRPC. If the RPC does not exist no action is taken. UnregisterConnectCall(string) // RPC calls an RPC on the given address. RPC cannot be called on an // address that the Gateway is not connected to. RPC(NetAddress, string, RPCFunc) error // Broadcast transmits obj, prefaced by the RPC name, to all of the // given peers in parallel. Broadcast(name string, obj interface{}, peers []Peer) // Online returns true if the gateway is connected to remote hosts Online() bool // Close safely stops the Gateway's listener process. Close() error }
A Gateway facilitates the interactions between the local node and remote nodes (peers). It relays incoming blocks and transactions to local modules, and broadcasts outgoing blocks and transactions to peers. In a broad sense, it is responsible for ensuring that the local consensus set is consistent with the "network" consensus set.
type GenericAlerter ¶ added in v1.4.2
type GenericAlerter struct {
// contains filtered or unexported fields
}
GenericAlerter implements the Alerter interface. It can be used as a helper type to implement the Alerter interface for modules and submodules.
func NewAlerter ¶ added in v1.4.2
func NewAlerter(module string) *GenericAlerter
NewAlerter creates a new alerter for the renter.
func (*GenericAlerter) Alerts ¶ added in v1.4.2
func (a *GenericAlerter) Alerts() (crit, err, warn []Alert)
Alerts returns the current alerts tracked by the alerter.
func (*GenericAlerter) RegisterAlert ¶ added in v1.4.2
func (a *GenericAlerter) RegisterAlert(id AlertID, msg, cause string, severity AlertSeverity)
RegisterAlert adds an alert to the alerter.
func (*GenericAlerter) UnregisterAlert ¶ added in v1.4.2
func (a *GenericAlerter) UnregisterAlert(id AlertID)
UnregisterAlert removes an alert from the alerter by id.
type HalfLifeDistribution ¶ added in v1.5.5
type HalfLifeDistribution struct { LastUpdate time.Time `json:"lastupdate"` OneMinute RequestTimeDistribution `json:"oneminute"` // Requests with a half life of one minute. FiveMinutes RequestTimeDistribution `json:"fiveminutes"` FifteenMinutes RequestTimeDistribution `json:"fifteenminutes"` TwentyFourHours RequestTimeDistribution `json:"twentyfourhours"` Lifetime RequestTimeDistribution `json:"lifetime"` // No decay applied. }
HalfLifeDistribution contains a set of RequestTimeDistributions with different half lives, allowing for a more complete picture of how responsive the requests are over time.
func NewHalfLifeDistribution ¶ added in v1.5.5
func NewHalfLifeDistribution() HalfLifeDistribution
NewHalfLifeDistribution initializes and returns a half life distribution ready to collect stats.
func (*HalfLifeDistribution) AddRequest ¶ added in v1.5.5
func (hld *HalfLifeDistribution) AddRequest(speed time.Duration, size uint64)
AddRequest will add a request to the half life distribution. Each call to add a request will update the bucket.
func (*HalfLifeDistribution) Update ¶ added in v1.5.5
func (hld *HalfLifeDistribution) Update()
Update will update the 'LastUpdate' for each bucket, applying the appropriate exponential decay to each counter. This should be called before collecting stats.
type Host ¶
type Host interface { Alerter // AddSector will add a sector on the host. If the sector already // exists, a virtual sector will be added, meaning that the 'sectorData' // will be ignored and no new disk space will be consumed. The expiry // height is used to track what height the sector can be safely deleted // at, though typically the host will manually delete the sector before // the expiry height. The same sector can be added multiple times at // different expiry heights, and the host is expected to only store the // data once. AddSector(sectorRoot crypto.Hash, sectorData []byte) error // HasSector indicates whether the host stores a sector with a given // root or not. HasSector(crypto.Hash) bool // AddSectorBatch is a performance optimization over AddSector when // adding a bunch of virtual sectors. It is necessary because otherwise // potentially thousands or even tens-of-thousands of fsync calls would // need to be made in serial, which would prevent renters from ever // successfully renewing. AddSectorBatch(sectorRoots []crypto.Hash) error // AddStorageFolder adds a storage folder to the host. The host may not // check that there is enough space available on-disk to support as much // storage as requested, though the manager should gracefully handle // running out of storage unexpectedly. AddStorageFolder(path string, size uint64) error // Announce submits a host announcement to the blockchain. Announce() error // AnnounceAddress submits an announcement using the given address. AnnounceAddress(NetAddress) error // The host needs to be able to shut down. Close() error // ConnectabilityStatus returns the connectability status of the host, // that is, if it can connect to itself on the configured NetAddress. ConnectabilityStatus() HostConnectabilityStatus // DeleteSector deletes a sector, meaning that the host will be // unable to upload that sector and be unable to provide a storage // proof on that sector. DeleteSector is for removing the data // entirely, and will remove instances of the sector appearing at all // heights. The primary purpose of DeleteSector is to comply with legal // requests to remove data. DeleteSector(sectorRoot crypto.Hash) error // ExternalSettings returns the settings of the host as seen by an // untrusted node querying the host for settings. ExternalSettings() HostExternalSettings // BandwidthCounters returns the Hosts's upload and download bandwidth BandwidthCounters() (uint64, uint64, time.Time, error) // FinancialMetrics returns the financial statistics of the host. FinancialMetrics() HostFinancialMetrics // InternalSettings returns the host's internal settings, including // potentially private or sensitive information. InternalSettings() HostInternalSettings // NetworkMetrics returns information on the types of RPC calls that // have been made to the host. NetworkMetrics() HostNetworkMetrics PaymentProcessor // PriceTable returns the host's current price table. PriceTable() RPCPriceTable // PruneStaleStorageObligations will delete storage obligations from the // host that, for whatever reason, did not make it on the block chain. // As these stale storage obligations have an impact on the host // financial metrics, this method updates the host financial metrics to // show the correct values. PruneStaleStorageObligations() error // PublicKey returns the public key of the host. PublicKey() types.SiaPublicKey // ReadSector will read a sector from the host, returning the bytes that // match the input sector root. ReadSector(sectorRoot crypto.Hash) ([]byte, error) // ReadPartialSector will read a sector from the storage manager, returning the // 'length' bytes at offset 'offset' that match the input sector root. ReadPartialSector(sectorRoot crypto.Hash, offset, length uint64) ([]byte, error) // RemoveSector will remove a sector from the host. The height at which // the sector expires should be provided, so that the auto-expiry // information for that sector can be properly updated. RemoveSector(sectorRoot crypto.Hash) error // RemoveSectorBatch is a non-ACID performance optimization to remove a // ton of sectors from the host all at once. This is necessary when // clearing out an entire contract from the host. RemoveSectorBatch(sectorRoots []crypto.Hash) error // RemoveStorageFolder will remove a storage folder from the host. All // storage on the folder will be moved to other storage folders, meaning // that no data will be lost. If the host is unable to save data, an // error will be returned and the operation will be stopped. If the // force flag is set to true, errors will be ignored and the remove // operation will be completed, meaning that data will be lost. RemoveStorageFolder(index uint16, force bool) error // ResetStorageFolderHealth will reset the health statistics on a // storage folder. ResetStorageFolderHealth(index uint16) error // ResizeStorageFolder will grow or shrink a storage folder on the host. // The host may not check that there is enough space on-disk to support // growing the storage folder, but should gracefully handle running out // of space unexpectedly. When shrinking a storage folder, any data in // the folder that needs to be moved will be placed into other storage // folders, meaning that no data will be lost. If the manager is unable // to migrate the data, an error will be returned and the operation will // be stopped. If the force flag is set to true, errors will be ignored // and the resize operation completed, meaning that data will be lost. ResizeStorageFolder(index uint16, newSize uint64, force bool) error // SetInternalSettings sets the hosting parameters of the host. SetInternalSettings(HostInternalSettings) error // StorageObligations returns the set of storage obligations held by // the host. StorageObligations() []StorageObligation // StorageFolders will return a list of storage folders tracked by the // host. StorageFolders() []StorageFolderMetadata // WorkingStatus returns the working state of the host, determined by if // settings calls are increasing. WorkingStatus() HostWorkingStatus }
A Host can take storage from disk and offer it to the network, managing things such as announcements, settings, and implementing all of the RPCs of the host protocol.
type HostAnnouncement ¶
type HostAnnouncement struct { Specifier types.Specifier NetAddress NetAddress PublicKey types.SiaPublicKey }
HostAnnouncement is an announcement by the host that appears in the blockchain. 'Specifier' is always 'PrefixHostAnnouncement'. The announcement is always followed by a signature from the public key of the whole announcement.
type HostConnectabilityStatus ¶ added in v1.2.0
type HostConnectabilityStatus string
HostConnectabilityStatus reports the connectability state of a host. Can be one of "checking", "connectable", or "not connectable"
type HostDB ¶
type HostDB interface { Alerter // ActiveHosts returns the list of hosts that are actively being selected // from. ActiveHosts() ([]HostDBEntry, error) // AllHosts returns the full list of hosts known to the hostdb, sorted in // order of preference. AllHosts() ([]HostDBEntry, error) // CheckForIPViolations accepts a number of host public keys and returns the // ones that violate the rules of the addressFilter. CheckForIPViolations([]types.SiaPublicKey) ([]types.SiaPublicKey, error) // Close closes the hostdb. Close() error // EstimateHostScore returns the estimated score breakdown of a host with the // provided settings. EstimateHostScore(HostDBEntry, Allowance) (HostScoreBreakdown, error) // Filter returns the hostdb's filterMode and filteredHosts Filter() (FilterMode, map[string]types.SiaPublicKey, error) // SetFilterMode sets the renter's hostdb filter mode SetFilterMode(lm FilterMode, hosts []types.SiaPublicKey) error // Host returns the HostDBEntry for a given host. Host(pk types.SiaPublicKey) (HostDBEntry, bool, error) // IncrementSuccessfulInteractions increments the number of successful // interactions with a host for a given key IncrementSuccessfulInteractions(types.SiaPublicKey) error // IncrementFailedInteractions increments the number of failed interactions with // a host for a given key IncrementFailedInteractions(types.SiaPublicKey) error // initialScanComplete returns a boolean indicating if the initial scan of the // hostdb is completed. InitialScanComplete() (bool, error) // IPViolationsCheck returns a boolean indicating if the IP violation check is // enabled or not. IPViolationsCheck() (bool, error) // RandomHosts returns a set of random hosts, weighted by their estimated // usefulness / attractiveness to the renter. RandomHosts will not return // any offline or inactive hosts. RandomHosts(int, []types.SiaPublicKey, []types.SiaPublicKey) ([]HostDBEntry, error) // RandomHostsWithAllowance is the same as RandomHosts but accepts an // allowance as an argument to be used instead of the allowance set in the // renter. RandomHostsWithAllowance(int, []types.SiaPublicKey, []types.SiaPublicKey, Allowance) ([]HostDBEntry, error) // ScoreBreakdown returns a detailed explanation of the various properties // of the host. ScoreBreakdown(HostDBEntry) (HostScoreBreakdown, error) // SetAllowance updates the allowance used by the hostdb for weighing hosts by // updating the host weight function. It will completely rebuild the hosttree so // it should be used with care. SetAllowance(Allowance) error // SetIPViolationCheck enables/disables the IP violation check within the // hostdb. SetIPViolationCheck(enabled bool) error // UpdateContracts rebuilds the knownContracts of the HostBD using the provided // contracts. UpdateContracts([]RenterContract) error }
A HostDB is a database of hosts that the renter can use for figuring out who to upload to, and download from.
type HostDBEntry ¶ added in v1.0.0
type HostDBEntry struct { HostExternalSettings // FirstSeen is the last block height at which this host was announced. FirstSeen types.BlockHeight `json:"firstseen"` // Measurements that have been taken on the host. The most recent // measurements are kept in full detail, historic ones are compressed into // the historic values. HistoricDowntime time.Duration `json:"historicdowntime"` HistoricUptime time.Duration `json:"historicuptime"` ScanHistory HostDBScans `json:"scanhistory"` // Measurements that are taken whenever we interact with a host. HistoricFailedInteractions float64 `json:"historicfailedinteractions"` HistoricSuccessfulInteractions float64 `json:"historicsuccessfulinteractions"` RecentFailedInteractions float64 `json:"recentfailedinteractions"` RecentSuccessfulInteractions float64 `json:"recentsuccessfulinteractions"` LastHistoricUpdate types.BlockHeight `json:"lasthistoricupdate"` // Measurements related to the IP subnet mask. IPNets []string `json:"ipnets"` LastIPNetChange time.Time `json:"lastipnetchange"` // The public key of the host, stored separately to minimize risk of certain // MitM based vulnerabilities. PublicKey types.SiaPublicKey `json:"publickey"` // Filtered says whether or not a HostDBEntry is being filtered out of the // filtered hosttree due to the filter mode of the hosttree Filtered bool `json:"filtered"` }
A HostDBEntry represents one host entry in the Renter's host DB. It aggregates the host's external settings and metrics with its public key.
type HostDBScan ¶ added in v1.1.0
HostDBScan represents a single scan event.
type HostDBScans ¶ added in v1.1.0
type HostDBScans []HostDBScan
HostDBScans represents a sortable slice of scans.
func (HostDBScans) Len ¶ added in v1.1.0
func (s HostDBScans) Len() int
func (HostDBScans) Less ¶ added in v1.1.0
func (s HostDBScans) Less(i, j int) bool
func (HostDBScans) Swap ¶ added in v1.1.0
func (s HostDBScans) Swap(i, j int)
type HostExternalSettings ¶ added in v1.0.0
type HostExternalSettings struct { // MaxBatchSize indicates the maximum size in bytes that a batch is // allowed to be. A batch is an array of revision actions; each // revision action can have a different number of bytes, depending on // the action, so the number of revision actions allowed depends on the // sizes of each. AcceptingContracts bool `json:"acceptingcontracts"` MaxDownloadBatchSize uint64 `json:"maxdownloadbatchsize"` MaxDuration types.BlockHeight `json:"maxduration"` MaxReviseBatchSize uint64 `json:"maxrevisebatchsize"` NetAddress NetAddress `json:"netaddress"` RemainingStorage uint64 `json:"remainingstorage"` SectorSize uint64 `json:"sectorsize"` TotalStorage uint64 `json:"totalstorage"` UnlockHash types.UnlockHash `json:"unlockhash"` WindowSize types.BlockHeight `json:"windowsize"` // Collateral is the amount of collateral that the host will put up for // storage in 'bytes per block', as an assurance to the renter that the // host really is committed to keeping the file. But, because the file // contract is created with no data available, this does leave the host // exposed to an attack by a wealthy renter whereby the renter causes // the host to lockup in-advance a bunch of funds that the renter then // never uses, meaning the host will not have collateral for other // clients. // // MaxCollateral indicates the maximum number of coins that a host is // willing to put into a file contract. Collateral types.Currency `json:"collateral"` MaxCollateral types.Currency `json:"maxcollateral"` // ContractPrice is the number of coins that the renter needs to pay to // the host just to open a file contract with them. Generally, the price // is only to cover the siacoin fees that the host will suffer when // submitting the file contract revision and storage proof to the // blockchain. // // BaseRPC price is a flat per-RPC fee charged by the host for any // non-free RPC. // // 'Download' bandwidth price is the cost per byte of downloading data // from the host. This includes metadata such as Merkle proofs. // // SectorAccessPrice is the cost per sector of data accessed when // downloading data. // // StoragePrice is the cost per-byte-per-block in hastings of storing // data on the host. // // 'Upload' bandwidth price is the cost per byte of uploading data to // the host. BaseRPCPrice types.Currency `json:"baserpcprice"` ContractPrice types.Currency `json:"contractprice"` DownloadBandwidthPrice types.Currency `json:"downloadbandwidthprice"` SectorAccessPrice types.Currency `json:"sectoraccessprice"` StoragePrice types.Currency `json:"storageprice"` UploadBandwidthPrice types.Currency `json:"uploadbandwidthprice"` // EphemeralAccountExpiry is the amount of time an account can be // inactive before the host considers it expired. // // MaxEphemeralAccountBalance is the maximum amount of money the host // allows to be deposited into a single ephemeral account. EphemeralAccountExpiry time.Duration `json:"ephemeralaccountexpiry"` MaxEphemeralAccountBalance types.Currency `json:"maxephemeralaccountbalance"` // Because the host has a public key, and settings are signed, and // because settings may be MITM'd, settings need a revision number so // that a renter can compare multiple sets of settings and determine // which is the most recent. RevisionNumber uint64 `json:"revisionnumber"` Version string `json:"version"` SiaMuxPort string `json:"siamuxport"` }
HostExternalSettings are the parameters advertised by the host. These are the values that the renter will request from the host in order to build its database.
NOTE: Anytime the pricing is extended for the HostExternalSettings, the Allowance also needs to be extended to support manually setting a maximum reasonable price.
func DefaultHostExternalSettings ¶ added in v1.4.8
func DefaultHostExternalSettings() HostExternalSettings
DefaultHostExternalSettings returns HostExternalSettings with certain default fields set. NetAddress, RemainingStorage, TotalStorage, UnlockHash, RevisionNumber and SiaMuxPort are not set.
func (HostExternalSettings) MaxBaseRPCPrice ¶ added in v1.4.8
func (hes HostExternalSettings) MaxBaseRPCPrice() types.Currency
MaxBaseRPCPrice returns the maximum value for the BaseRPCPrice based on the DownloadBandwidthPrice
func (HostExternalSettings) MaxSectorAccessPrice ¶ added in v1.4.8
func (hes HostExternalSettings) MaxSectorAccessPrice() types.Currency
MaxSectorAccessPrice returns the maximum value for the SectorAccessPrice based on the DownloadBandwidthPrice
func (HostExternalSettings) SiaMuxAddress ¶ added in v1.4.9
func (hes HostExternalSettings) SiaMuxAddress() string
SiaMuxAddress returns the address of the host's siamux.
type HostFinancialMetrics ¶ added in v1.0.0
type HostFinancialMetrics struct { // Metrics related to ephemeral accounts. Account funding represents all // funds used to fund ephemeral acccounts with for storage obligations // that were successful. Potential account funding represents the same // but for storage obligations that have not been confirmed yet. AccountFunding types.Currency `json:"accountfunding"` PotentialAccountFunding types.Currency `json:"potentialaccountfunding"` // Every time a renter forms a contract with a host, a contract fee is // paid by the renter. These stats track the total contract fees. ContractCount uint64 `json:"contractcount"` ContractCompensation types.Currency `json:"contractcompensation"` PotentialContractCompensation types.Currency `json:"potentialcontractcompensation"` // Metrics related to storage proofs, collateral, and submitting // transactions to the blockchain. LockedStorageCollateral types.Currency `json:"lockedstoragecollateral"` LostRevenue types.Currency `json:"lostrevenue"` LostStorageCollateral types.Currency `json:"loststoragecollateral"` PotentialStorageRevenue types.Currency `json:"potentialstoragerevenue"` RiskedStorageCollateral types.Currency `json:"riskedstoragecollateral"` StorageRevenue types.Currency `json:"storagerevenue"` TransactionFeeExpenses types.Currency `json:"transactionfeeexpenses"` // Bandwidth financial metrics. DownloadBandwidthRevenue types.Currency `json:"downloadbandwidthrevenue"` PotentialDownloadBandwidthRevenue types.Currency `json:"potentialdownloadbandwidthrevenue"` PotentialUploadBandwidthRevenue types.Currency `json:"potentialuploadbandwidthrevenue"` UploadBandwidthRevenue types.Currency `json:"uploadbandwidthrevenue"` }
HostFinancialMetrics provides financial statistics for the host, including money that is locked in contracts. Though verbose, these statistics should provide a clear picture of where the host's money is currently being used. The front end can consolidate stats where desired. Potential revenue refers to revenue that is available in a file contract for which the file contract window has not yet closed.
type HostInternalSettings ¶ added in v1.0.0
type HostInternalSettings struct { AcceptingContracts bool `json:"acceptingcontracts"` MaxDownloadBatchSize uint64 `json:"maxdownloadbatchsize"` MaxDuration types.BlockHeight `json:"maxduration"` MaxReviseBatchSize uint64 `json:"maxrevisebatchsize"` NetAddress NetAddress `json:"netaddress"` WindowSize types.BlockHeight `json:"windowsize"` Collateral types.Currency `json:"collateral"` CollateralBudget types.Currency `json:"collateralbudget"` MaxCollateral types.Currency `json:"maxcollateral"` MinBaseRPCPrice types.Currency `json:"minbaserpcprice"` MinContractPrice types.Currency `json:"mincontractprice"` MinDownloadBandwidthPrice types.Currency `json:"mindownloadbandwidthprice"` MinSectorAccessPrice types.Currency `json:"minsectoraccessprice"` MinStoragePrice types.Currency `json:"minstorageprice"` MinUploadBandwidthPrice types.Currency `json:"minuploadbandwidthprice"` EphemeralAccountExpiry time.Duration `json:"ephemeralaccountexpiry"` MaxEphemeralAccountBalance types.Currency `json:"maxephemeralaccountbalance"` MaxEphemeralAccountRisk types.Currency `json:"maxephemeralaccountrisk"` CustomRegistryPath string `json:"customregistrypath"` RegistrySize uint64 `json:"registrysize"` }
HostInternalSettings contains a list of settings that can be changed.
func (HostInternalSettings) MaxBaseRPCPrice ¶ added in v1.4.7
func (his HostInternalSettings) MaxBaseRPCPrice() types.Currency
MaxBaseRPCPrice returns the maximum value for the MinBaseRPCPrice based on the MinDownloadBandwidthPrice
func (HostInternalSettings) MaxSectorAccessPrice ¶ added in v1.4.7
func (his HostInternalSettings) MaxSectorAccessPrice() types.Currency
MaxSectorAccessPrice returns the maximum value for the MinSectorAccessPrice based on the MinDownloadBandwidthPrice
type HostNetworkMetrics ¶ added in v1.0.0
type HostNetworkMetrics struct { DownloadCalls uint64 `json:"downloadcalls"` ErrorCalls uint64 `json:"errorcalls"` FormContractCalls uint64 `json:"formcontractcalls"` RenewCalls uint64 `json:"renewcalls"` ReviseCalls uint64 `json:"revisecalls"` SettingsCalls uint64 `json:"settingscalls"` UnrecognizedCalls uint64 `json:"unrecognizedcalls"` }
HostNetworkMetrics reports the quantity of each type of RPC call that has been made to the host.
type HostOldExternalSettings ¶ added in v1.4.0
type HostOldExternalSettings struct { AcceptingContracts bool `json:"acceptingcontracts"` MaxDownloadBatchSize uint64 `json:"maxdownloadbatchsize"` MaxDuration types.BlockHeight `json:"maxduration"` MaxReviseBatchSize uint64 `json:"maxrevisebatchsize"` NetAddress NetAddress `json:"netaddress"` RemainingStorage uint64 `json:"remainingstorage"` SectorSize uint64 `json:"sectorsize"` TotalStorage uint64 `json:"totalstorage"` UnlockHash types.UnlockHash `json:"unlockhash"` WindowSize types.BlockHeight `json:"windowsize"` Collateral types.Currency `json:"collateral"` MaxCollateral types.Currency `json:"maxcollateral"` ContractPrice types.Currency `json:"contractprice"` DownloadBandwidthPrice types.Currency `json:"downloadbandwidthprice"` StoragePrice types.Currency `json:"storageprice"` UploadBandwidthPrice types.Currency `json:"uploadbandwidthprice"` RevisionNumber uint64 `json:"revisionnumber"` Version string `json:"version"` }
HostOldExternalSettings are the pre-v1.4.0 host settings.
type HostScoreBreakdown ¶ added in v1.1.1
type HostScoreBreakdown struct { Score types.Currency `json:"score"` ConversionRate float64 `json:"conversionrate"` AcceptContractAdjustment float64 `json:"acceptcontractadjustment"` AgeAdjustment float64 `json:"ageadjustment"` BasePriceAdjustment float64 `json:"basepriceadjustment"` BurnAdjustment float64 `json:"burnadjustment"` CollateralAdjustment float64 `json:"collateraladjustment"` DurationAdjustment float64 `json:"durationadjustment"` InteractionAdjustment float64 `json:"interactionadjustment"` PriceAdjustment float64 `json:"pricesmultiplier,siamismatch"` StorageRemainingAdjustment float64 `json:"storageremainingadjustment"` UptimeAdjustment float64 `json:"uptimeadjustment"` VersionAdjustment float64 `json:"versionadjustment"` }
HostScoreBreakdown provides a piece-by-piece explanation of why a host has the score that they do.
NOTE: Renters are free to use whatever scoring they feel appropriate for hosts. Some renters will outright blacklist or whitelist sets of hosts. The results provided by this struct can only be used as a guide, and may vary significantly from machine to machine.
type HostWorkingStatus ¶ added in v1.2.0
type HostWorkingStatus string
HostWorkingStatus reports the working state of a host. Can be one of "checking", "working", or "not working".
type Instruction ¶ added in v1.4.2
type Instruction struct { Specifier InstructionSpecifier Args []byte }
Instruction specifies a generic instruction used as an input to `mdm.ExecuteProgram`.
func NewAppendInstruction ¶ added in v1.4.9
func NewAppendInstruction(dataOffset uint64, merkleProof bool) Instruction
NewAppendInstruction creates an Instruction from arguments.
func NewDropSectorsInstruction ¶ added in v1.4.9
func NewDropSectorsInstruction(numSectorsOffset uint64, merkleProof bool) Instruction
NewDropSectorsInstruction creates an Instruction from arguments.
func NewHasSectorInstruction ¶ added in v1.4.8
func NewHasSectorInstruction(merkleRootOffset uint64) Instruction
NewHasSectorInstruction creates a modules.Instruction from arguments.
func NewReadOffsetInstruction ¶ added in v1.4.9
func NewReadOffsetInstruction(lengthOffset, offsetOffset uint64, merkleProof bool) Instruction
NewReadOffsetInstruction creates a modules.Instruction from arguments.
func NewReadRegistryInstruction ¶ added in v1.5.1
func NewReadRegistryInstruction(pubKeyOff, pubKeyLen, tweakOff uint64) Instruction
NewReadRegistryInstruction creates an Instruction from arguments.
func NewReadSectorInstruction ¶ added in v1.4.8
func NewReadSectorInstruction(lengthOffset, offsetOffset, merkleRootOffset uint64, merkleProof bool) Instruction
NewReadSectorInstruction creates a modules.Instruction from arguments.
func NewRevisionInstruction ¶ added in v1.5.0
func NewRevisionInstruction(merkleRootOffset uint64) Instruction
NewRevisionInstruction creates a modules.Instruction from arguments.
func NewSwapSectorInstruction ¶ added in v1.5.0
func NewSwapSectorInstruction(sector1Offset, sector2Offset uint64, merkleProof bool) Instruction
NewSwapSectorInstruction creates a modules.Instruction from arguments.
func NewUpdateRegistryInstruction ¶ added in v1.5.1
func NewUpdateRegistryInstruction(tweakOff, revisionOff, signatureOff, pubKeyOff, pubKeyLen, dataOff, dataLen uint64) Instruction
NewUpdateRegistryInstruction creates an Instruction from arguments.
func RPCHasSectorInstruction ¶ added in v1.4.8
func RPCHasSectorInstruction(merkleRootOffset uint64) Instruction
RPCHasSectorInstruction creates an Instruction from arguments.
func RPCIReadSector ¶ added in v1.4.2
func RPCIReadSector(rootOff, offsetOff, lengthOff uint64, merkleProof bool) Instruction
RPCIReadSector is a convenience method to create an Instruction of type 'ReadSector'.
type InstructionSpecifier ¶ added in v1.4.2
InstructionSpecifier specifies the type of the instruction.
type KeyManager ¶ added in v1.0.0
type KeyManager interface { // AllAddresses returns all addresses that the wallet is able to spend // from, including unseeded addresses. Addresses are returned sorted in // byte-order. AllAddresses() ([]types.UnlockHash, error) // AllSeeds returns all of the seeds that are being tracked by the // wallet, including the primary seed. Only the primary seed is used to // generate new addresses, but the wallet can spend funds sent to // public keys generated by any of the seeds returned. AllSeeds() ([]Seed, error) // CreateBackup will create a backup of the wallet at the provided // filepath. The backup will have all seeds and keys. CreateBackup(string) error // LastAddresses returns the last n addresses starting at the last seedProgress // for which an address was generated. LastAddresses(n uint64) ([]types.UnlockHash, error) // Load033xWallet will load a version 0.3.3.x wallet from disk and add all of // the keys in the wallet as unseeded keys. Load033xWallet(crypto.CipherKey, string) error // LoadSeed will recreate a wallet file using the recovery phrase. // LoadSeed only needs to be called if the original seed file or // encryption password was lost. The master key is used to encrypt the // recovery seed before saving it to disk. LoadSeed(crypto.CipherKey, Seed) error // LoadSiagKeys will take a set of filepaths that point to a siag key // and will have the siag keys loaded into the wallet so that they will // become spendable. LoadSiagKeys(crypto.CipherKey, []string) error // NextAddress returns a new coin addresses generated from the // primary seed. NextAddress() (types.UnlockConditions, error) // NextAddresses returns n new coin addresses generated from the primary // seed. NextAddresses(uint64) ([]types.UnlockConditions, error) // PrimarySeed returns the unencrypted primary seed of the wallet, // along with a uint64 indicating how many addresses may be safely // generated from the seed. PrimarySeed() (Seed, uint64, error) // SignTransaction signs txn using secret keys known to the wallet. // The transaction should be complete with the exception of the // Signature fields of each TransactionSignature referenced by toSign. SignTransaction(txn *types.Transaction, toSign []crypto.Hash) error // SweepSeed scans the blockchain for outputs generated from seed and // creates a transaction that transfers them to the wallet. Note that // this incurs a transaction fee. It returns the total value of the // outputs, minus the fee. If only siafunds were found, the fee is // deducted from the wallet. SweepSeed(seed Seed) (coins, funds types.Currency, err error) }
KeyManager manages wallet keys, including the use of seeds, creating and loading backups, and providing a layer of compatibility for older wallet files.
type LoopChallengeRequest ¶ added in v1.4.0
type LoopChallengeRequest struct { // Entropy signed by the renter to prove that it controls the secret key // used to sign contract revisions. The actual data signed should be: // // blake2b(RPCChallengePrefix | Challenge) Challenge [16]byte }
LoopChallengeRequest contains a challenge for the renter to prove their identity. It is the host's first encrypted message, and immediately follows KeyExchangeResponse.
type LoopContractAdditions ¶ added in v1.4.0
type LoopContractAdditions struct { Parents []types.Transaction Inputs []types.SiacoinInput Outputs []types.SiacoinOutput }
LoopContractAdditions contains the parent transaction, inputs, and outputs added by the host when negotiating a file contract.
type LoopContractSignatures ¶ added in v1.4.0
type LoopContractSignatures struct { ContractSignatures []types.TransactionSignature RevisionSignature types.TransactionSignature }
LoopContractSignatures contains the signatures for a contract transaction and initial revision. These signatures are sent by both the renter and host during contract formation and renewal.
type LoopFormContractRequest ¶ added in v1.4.0
type LoopFormContractRequest struct { Transactions []types.Transaction RenterKey types.SiaPublicKey }
LoopFormContractRequest contains the request parameters for RPCLoopFormContract.
type LoopKeyExchangeRequest ¶ added in v1.4.0
type LoopKeyExchangeRequest struct { // The renter's ephemeral X25519 public key. PublicKey crypto.X25519PublicKey // Encryption ciphers that the renter supports. Ciphers []types.Specifier }
LoopKeyExchangeRequest is the first object sent when initializing the renter-host protocol.
type LoopKeyExchangeResponse ¶ added in v1.4.0
type LoopKeyExchangeResponse struct { // The host's ephemeral X25519 public key. PublicKey crypto.X25519PublicKey // Signature of (Host's Public Key | Renter's Public Key). Note that this // also serves to authenticate the host. Signature []byte // Cipher selected by the host. Must be one of the ciphers offered in // the key exchange request. Cipher types.Specifier }
LoopKeyExchangeResponse contains the host's response to the KeyExchangeRequest.
type LoopLockRequest ¶ added in v1.4.0
type LoopLockRequest struct { // The contract to lock; implicitly referenced by subsequent RPCs. ContractID types.FileContractID // The host's challenge, signed by the renter's contract key. Signature []byte // Lock timeout, in milliseconds. Timeout uint64 }
LoopLockRequest contains the request parameters for RPCLoopLock.
type LoopLockResponse ¶ added in v1.4.0
type LoopLockResponse struct { Acquired bool NewChallenge [16]byte Revision types.FileContractRevision Signatures []types.TransactionSignature }
LoopLockResponse contains the response data for RPCLoopLock.
type LoopReadRequest ¶ added in v1.4.0
type LoopReadRequest struct { Sections []LoopReadRequestSection MerkleProof bool NewRevisionNumber uint64 NewValidProofValues []types.Currency NewMissedProofValues []types.Currency Signature []byte }
LoopReadRequest contains the request parameters for RPCLoopRead.
type LoopReadRequestSection ¶ added in v1.4.0
LoopReadRequestSection is a section requested in LoopReadRequest.
type LoopReadResponse ¶ added in v1.4.0
LoopReadResponse contains the response data for RPCLoopRead.
type LoopRenewAndClearContractRequest ¶ added in v1.4.4
type LoopRenewAndClearContractRequest struct { Transactions []types.Transaction RenterKey types.SiaPublicKey FinalValidProofValues []types.Currency FinalMissedProofValues []types.Currency }
LoopRenewAndClearContractRequest contains the request parameters for RPCLoopRenewClearContract.
type LoopRenewAndClearContractSignatures ¶ added in v1.4.4
type LoopRenewAndClearContractSignatures struct { ContractSignatures []types.TransactionSignature RevisionSignature types.TransactionSignature FinalRevisionSignature []byte }
LoopRenewAndClearContractSignatures contains the signatures for a contract transaction, initial revision and final revision of the old contract. These signatures are sent by the renter during contract renewal.
type LoopRenewContractRequest ¶ added in v1.4.0
type LoopRenewContractRequest struct { Transactions []types.Transaction RenterKey types.SiaPublicKey }
LoopRenewContractRequest contains the request parameters for RPCLoopRenewContract.
type LoopSectorRootsRequest ¶ added in v1.4.0
type LoopSectorRootsRequest struct { RootOffset uint64 NumRoots uint64 NewRevisionNumber uint64 NewValidProofValues []types.Currency NewMissedProofValues []types.Currency Signature []byte }
LoopSectorRootsRequest contains the request parameters for RPCLoopSectorRoots.
type LoopSectorRootsResponse ¶ added in v1.4.0
type LoopSectorRootsResponse struct { Signature []byte SectorRoots []crypto.Hash MerkleProof []crypto.Hash }
LoopSectorRootsResponse contains the response data for RPCLoopSectorRoots.
type LoopSettingsResponse ¶ added in v1.4.0
type LoopSettingsResponse struct {
Settings []byte // actually a JSON-encoded HostExternalSettings
}
LoopSettingsResponse contains the response data for RPCLoopSettingsResponse.
type LoopWriteAction ¶ added in v1.4.0
LoopWriteAction is a generic Write action. The meaning of each field depends on the Type of the action.
type LoopWriteMerkleProof ¶ added in v1.4.0
type LoopWriteMerkleProof struct { OldSubtreeHashes []crypto.Hash OldLeafHashes []crypto.Hash NewMerkleRoot crypto.Hash }
LoopWriteMerkleProof contains the optional Merkle proof for response data for RPCLoopWrite.
type LoopWriteRequest ¶ added in v1.4.0
type LoopWriteRequest struct { Actions []LoopWriteAction MerkleProof bool NewRevisionNumber uint64 NewValidProofValues []types.Currency NewMissedProofValues []types.Currency }
LoopWriteRequest contains the request parameters for RPCLoopWrite.
type LoopWriteResponse ¶ added in v1.4.0
type LoopWriteResponse struct {
Signature []byte
}
LoopWriteResponse contains the response data for RPCLoopWrite.
type MDMCancellationToken ¶ added in v1.4.10
type MDMCancellationToken [MDMCancellationTokenLen]byte
MDMCancellationToken is a token that can be used to request cancellation of a program
type MDMInstructionRevisionResponse ¶ added in v1.5.0
type MDMInstructionRevisionResponse struct {
RevisionTxn types.Transaction
}
MDMInstructionRevisionResponse is the format of the MDM's revision instruction's output.
type MemoryManagerStatus ¶ added in v1.5.5
type MemoryManagerStatus struct { Available uint64 `json:"available"` Base uint64 `json:"base"` Requested uint64 `json:"requested"` PriorityAvailable uint64 `json:"priorityavailable"` PriorityBase uint64 `json:"prioritybase"` PriorityRequested uint64 `json:"priorityrequested"` PriorityReserve uint64 `json:"priorityreserve"` }
MemoryManagerStatus contains the memory status of a single memory manager.
func (MemoryManagerStatus) Add ¶ added in v1.5.5
func (ms MemoryManagerStatus) Add(ms2 MemoryManagerStatus) MemoryManagerStatus
Add combines two MemoryManagerStatus objects into one.
type MemoryStatus ¶ added in v1.5.0
type MemoryStatus struct { MemoryManagerStatus Registry MemoryManagerStatus `json:"registry"` UserUpload MemoryManagerStatus `json:"userupload"` UserDownload MemoryManagerStatus `json:"userdownload"` System MemoryManagerStatus `json:"system"` }
MemoryStatus contains information about the status of the memory managers in the renter.
type MerkleRootSet ¶ added in v1.1.1
MerkleRootSet is a set of Merkle roots, and gets encoded more efficiently.
func (MerkleRootSet) MarshalJSON ¶ added in v1.1.1
func (mrs MerkleRootSet) MarshalJSON() ([]byte, error)
MarshalJSON defines a JSON encoding for a MerkleRootSet.
func (*MerkleRootSet) UnmarshalJSON ¶ added in v1.1.1
func (mrs *MerkleRootSet) UnmarshalJSON(b []byte) error
UnmarshalJSON attempts to decode a MerkleRootSet, falling back on the legacy decoding of a []crypto.Hash if that fails.
type Miner ¶ added in v0.3.1
type Miner interface { BlockManager CPUMiner io.Closer }
The Miner interface provides access to mining features.
type MountInfo ¶ added in v1.4.2
type MountInfo struct { MountPoint string `json:"mountpoint"` SiaPath SiaPath `json:"siapath"` MountOptions MountOptions `json:"mountoptions"` }
MountInfo contains information about a mounted FUSE filesystem.
type MountOptions ¶ added in v1.4.2
MountOptions specify various settings of a FUSE filesystem mount.
type NetAddress ¶
type NetAddress string
A NetAddress contains the information needed to contact a peer.
func DecodeAnnouncement ¶ added in v1.0.0
func DecodeAnnouncement(fullAnnouncement []byte) (na NetAddress, spk types.SiaPublicKey, err error)
DecodeAnnouncement decodes announcement bytes into a host announcement, verifying the prefix and the signature.
func (NetAddress) Host ¶
func (na NetAddress) Host() string
Host removes the port from a NetAddress, returning just the host. If the address is not of the form "host:port" the empty string is returned. The port will still be returned for invalid NetAddresses (e.g. "unqualified:0" will return "unqualified"), but in general you should only call Host on valid addresses.
func (NetAddress) IsLocal ¶ added in v1.0.3
func (na NetAddress) IsLocal() bool
IsLocal returns true if the input IP address belongs to a local address range such as 192.168.x.x or 127.x.x.x
func (NetAddress) IsLoopback ¶ added in v1.0.0
func (na NetAddress) IsLoopback() bool
IsLoopback returns true for IP addresses that are on the same machine.
func (NetAddress) IsStdValid ¶ added in v1.0.3
func (na NetAddress) IsStdValid() error
IsStdValid returns an error if the NetAddress is invalid. A valid NetAddress is of the form "host:port", such that "host" is either a valid IPv4/IPv6 address or a valid hostname, and "port" is an integer in the range [1,65535]. Valid IPv4 addresses, IPv6 addresses, and hostnames are detailed in RFCs 791, 2460, and 952, respectively. Loopback addresses are allowed.
func (NetAddress) IsValid ¶ added in v1.0.0
func (na NetAddress) IsValid() error
IsValid is an extension to IsStdValid that also forbids the loopback address.
NOTE: IsValid is being phased out in favor of allowing the loopback address but verifying through other means that the connection is not to yourself (which is the original reason that the loopback address was banned).
func (NetAddress) Port ¶
func (na NetAddress) Port() string
Port returns the NetAddress object's port number. If the address is not of the form "host:port" the empty string is returned. The port will still be returned for invalid NetAddresses (e.g. "localhost:0" will return "0"), but in general you should only call Port on valid addresses.
type PartialChunk ¶ added in v1.4.2
type PartialChunk struct { ChunkID CombinedChunkID // The ChunkID of the combined chunk the partial is in. InPartialsFile bool // 'true' if the combined chunk is already in the partials siafile. Length uint64 // length of the partial chunk within the combined chunk. Offset uint64 // offset of the partial chunk within the combined chunk. }
PartialChunk holds some information about a combined chunk
type PassthroughErasureCoder ¶ added in v1.5.1
type PassthroughErasureCoder struct{}
PassthroughErasureCoder is a blank type that signifies no erasure coding.
func (*PassthroughErasureCoder) Encode ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) Encode(data []byte) ([][]byte, error)
Encode splits data into equal-length pieces, with some pieces containing parity data. For the passthrough this is a no-op.
func (*PassthroughErasureCoder) EncodeShards ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) EncodeShards(pieces [][]byte) ([][]byte, error)
EncodeShards encodes the input data like Encode but accepts an already sharded input. For the passthrough this is a no-op.
func (*PassthroughErasureCoder) Identifier ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) Identifier() ErasureCoderIdentifier
Identifier returns the ErasureCoderIdentifier of the ErasureCoder.
func (*PassthroughErasureCoder) MinPieces ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) MinPieces() int
MinPieces is the minimum number of pieces that must be present to recover the original data. For the passthrough this is hardcoded to 1.
func (*PassthroughErasureCoder) NumPieces ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) NumPieces() int
NumPieces is the number of pieces returned by Encode. For the passthrough this is hardcoded to 1.
func (*PassthroughErasureCoder) Reconstruct ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) Reconstruct(pieces [][]byte) error
Reconstruct recovers the full set of encoded shards from the provided pieces, of which at least MinPieces must be non-nil. For the passthrough this is a no-op.
func (*PassthroughErasureCoder) Recover ¶ added in v1.5.1
Recover recovers the original data from pieces and writes it to w. pieces should be identical to the slice returned by Encode (length and order must be preserved), but with missing elements set to nil. n is the number of bytes to be written to w; this is necessary because pieces may have been padded with zeros during encoding.
func (*PassthroughErasureCoder) SupportsPartialEncoding ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) SupportsPartialEncoding() (uint64, bool)
SupportsPartialEncoding returns true if partial encoding is supported. The piece segment size will be returned. Otherwise the numerical return value is set to zero.
func (*PassthroughErasureCoder) Type ¶ added in v1.5.1
func (pec *PassthroughErasureCoder) Type() ErasureCoderType
Type returns the type identifier of the ErasureCoder.
type PayByContractRequest ¶ added in v1.4.7
type PayByContractRequest struct { ContractID types.FileContractID NewRevisionNumber uint64 NewValidProofValues []types.Currency NewMissedProofValues []types.Currency RefundAccount AccountID Signature []byte }
PayByContractRequest holds all payment details to pay from a file contract.
type PayByContractResponse ¶ added in v1.4.7
PayByContractResponse is the object sent in response to the PayByContractRequest
type PayByEphemeralAccountRequest ¶ added in v1.4.7
type PayByEphemeralAccountRequest struct { Message WithdrawalMessage Signature crypto.Signature Priority int64 }
PayByEphemeralAccountRequest holds all payment details to pay from an ephemeral account.
type PaymentDetails ¶ added in v1.4.7
PaymentDetails is an interface that defines method that give more information about the details of a processed payment.
type PaymentProcessor ¶ added in v1.4.7
type PaymentProcessor interface { // ProcessPayment takes a stream and handles the payment request objects // sent by the caller. Returns an object that implements the PaymentDetails // interface, or an error in case of failure. ProcessPayment(stream siamux.Stream) (PaymentDetails, error) }
PaymentProcessor is the interface implemented to handle RPC payments.
type PaymentProvider ¶ added in v1.4.8
type PaymentProvider interface { // ProvidePayment takes a stream and various payment details and handles the // payment by sending and processing payment request and response objects. // Returns an error in case of failure. ProvidePayment(stream io.ReadWriter, host types.SiaPublicKey, rpc types.Specifier, amount types.Currency, refundAccount AccountID, blockHeight types.BlockHeight) error }
PaymentProvider is the interface implemented to provide payment for an RPC.
type PaymentRequest ¶ added in v1.4.7
PaymentRequest identifies the payment method. This can be either PayByContract or PayByEphemeralAccount
type Peer ¶ added in v1.0.0
type Peer struct { Inbound bool `json:"inbound"` Local bool `json:"local"` NetAddress NetAddress `json:"netaddress"` Version string `json:"version"` }
Peer contains all the info necessary to Broadcast to a peer.
type PeerConn ¶ added in v0.3.1
type PeerConn interface { net.Conn RPCAddr() NetAddress }
A PeerConn is the connection type used when communicating with peers during an RPC. It is identical to a net.Conn with the additional RPCAddr method. This method acts as an identifier for peers and is the address that the peer can be dialed on. It is also the address that should be used when calling an RPC on the peer.
type ProcessedInput ¶ added in v1.0.0
type ProcessedInput struct { ParentID types.OutputID `json:"parentid"` FundType types.Specifier `json:"fundtype"` WalletAddress bool `json:"walletaddress"` RelatedAddress types.UnlockHash `json:"relatedaddress"` Value types.Currency `json:"value"` }
A ProcessedInput represents funding to a transaction. The input is coming from an address and going to the outputs. The fund types are 'SiacoinInput', 'SiafundInput'.
type ProcessedOutput ¶ added in v1.0.0
type ProcessedOutput struct { ID types.OutputID `json:"id"` FundType types.Specifier `json:"fundtype"` MaturityHeight types.BlockHeight `json:"maturityheight"` WalletAddress bool `json:"walletaddress"` RelatedAddress types.UnlockHash `json:"relatedaddress"` Value types.Currency `json:"value"` }
A ProcessedOutput is a siacoin output that appears in a transaction. Some outputs mature immediately, some are delayed, and some may never mature at all (in the event of storage proofs).
Fund type can either be 'SiacoinOutput', 'SiafundOutput', 'ClaimOutput', 'MinerPayout', or 'MinerFee'. All outputs except the miner fee create outputs accessible to an address. Miner fees are not spendable, and instead contribute to the block subsidy.
MaturityHeight indicates at what block height the output becomes available. SiacoinInputs and SiafundInputs become available immediately. ClaimInputs and MinerPayouts become available after 144 confirmations.
type ProcessedTransaction ¶ added in v1.0.0
type ProcessedTransaction struct { Transaction types.Transaction `json:"transaction"` TransactionID types.TransactionID `json:"transactionid"` ConfirmationHeight types.BlockHeight `json:"confirmationheight"` ConfirmationTimestamp types.Timestamp `json:"confirmationtimestamp"` Inputs []ProcessedInput `json:"inputs"` Outputs []ProcessedOutput `json:"outputs"` }
A ProcessedTransaction is a transaction that has been processed into explicit inputs and outputs and tagged with some header data such as confirmation height + timestamp.
Because of the block subsidy, a block is considered as a transaction. Since there is technically no transaction id for the block subsidy, the block id is used instead.
type ProductionDependencies ¶ added in v1.3.2
type ProductionDependencies struct {
// contains filtered or unexported fields
}
ProductionDependencies are the dependencies used in a Release or Debug production build.
func (*ProductionDependencies) AtLeastOne ¶ added in v1.3.2
func (*ProductionDependencies) AtLeastOne() uint64
AtLeastOne will return a value that is equal to 1 if debugging is disabled. If debugging is enabled, a higher value may be returned.
func (*ProductionDependencies) CreateFile ¶ added in v1.3.2
func (pd *ProductionDependencies) CreateFile(s string) (File, error)
CreateFile gives the host the ability to create files on the operating system.
func (*ProductionDependencies) Destruct ¶ added in v1.3.2
func (pd *ProductionDependencies) Destruct()
Destruct checks that all resources have been cleaned up correctly.
func (*ProductionDependencies) DialTimeout ¶ added in v1.3.2
func (*ProductionDependencies) DialTimeout(addr NetAddress, timeout time.Duration) (net.Conn, error)
DialTimeout creates a tcp connection to a certain address with the specified timeout.
func (*ProductionDependencies) Disrupt ¶ added in v1.3.2
func (*ProductionDependencies) Disrupt(string) bool
Disrupt can be used to inject specific behavior into a module by overwriting it using a custom dependency.
func (*ProductionDependencies) Listen ¶ added in v1.3.2
func (*ProductionDependencies) Listen(s1, s2 string) (net.Listener, error)
Listen gives the host the ability to receive incoming connections.
func (*ProductionDependencies) LoadFile ¶ added in v1.3.2
func (*ProductionDependencies) LoadFile(meta persist.Metadata, data interface{}, filename string) error
LoadFile loads JSON encoded data from a file.
func (*ProductionDependencies) LookupIP ¶ added in v1.3.4
func (*ProductionDependencies) LookupIP(host string) ([]net.IP, error)
LookupIP resolves a hostname to a number of IP addresses. If an IP address is provided as an argument it will just return that IP.
func (*ProductionDependencies) MkdirAll ¶ added in v1.3.2
func (*ProductionDependencies) MkdirAll(s string, fm os.FileMode) error
MkdirAll gives the host the ability to create chains of folders within the filesystem.
func (*ProductionDependencies) NebulousAddress ¶ added in v1.4.9
func (*ProductionDependencies) NebulousAddress() types.UnlockHash
NebulousAddress will return an address that can be used to send SiaCoin to a Nebulous managed Wallet.
func (*ProductionDependencies) NewLogger ¶ added in v1.3.2
func (*ProductionDependencies) NewLogger(s string) (*persist.Logger, error)
NewLogger creates a logger that the host can use to log messages and write critical statements.
func (*ProductionDependencies) Open ¶ added in v1.4.0
func (pd *ProductionDependencies) Open(s string) (File, error)
Open opens a file readonly.
func (*ProductionDependencies) OpenDatabase ¶ added in v1.3.2
func (*ProductionDependencies) OpenDatabase(m persist.Metadata, s string) (*persist.BoltDatabase, error)
OpenDatabase creates a database that the host can use to interact with large volumes of persistent data.
func (*ProductionDependencies) OpenFile ¶ added in v1.3.2
OpenFile opens a file with the specified mode and permissions.
func (*ProductionDependencies) RandRead ¶ added in v1.3.2
func (*ProductionDependencies) RandRead(b []byte) (int, error)
RandRead fills the input bytes with random data.
func (*ProductionDependencies) ReadFile ¶ added in v1.3.2
func (*ProductionDependencies) ReadFile(s string) ([]byte, error)
ReadFile reads a file from the filesystem.
func (*ProductionDependencies) RemoveFile ¶ added in v1.3.2
func (pd *ProductionDependencies) RemoveFile(s string) error
RemoveFile will remove a file from disk.
func (*ProductionDependencies) RenameFile ¶ added in v1.3.2
func (pd *ProductionDependencies) RenameFile(s1 string, s2 string) error
RenameFile renames a file on disk.
func (*ProductionDependencies) Resolver ¶ added in v1.3.5
func (*ProductionDependencies) Resolver() Resolver
Resolver returns the ProductionResolver.
func (*ProductionDependencies) SaveFileSync ¶ added in v1.3.2
func (*ProductionDependencies) SaveFileSync(meta persist.Metadata, data interface{}, filename string) error
SaveFileSync writes JSON encoded data to a file and syncs the file to disk afterwards.
func (*ProductionDependencies) Sleep ¶ added in v1.3.2
func (*ProductionDependencies) Sleep(d time.Duration)
Sleep blocks the calling thread for a certain duration.
func (*ProductionDependencies) Symlink ¶ added in v1.3.2
func (*ProductionDependencies) Symlink(s1, s2 string) error
Symlink creates a symlink between a source and a destination file.
type ProductionFile ¶ added in v1.3.2
ProductionFile is the implementation of the File interface that is used in a Release or Debug production build.
func (*ProductionFile) Close ¶ added in v1.3.2
func (pf *ProductionFile) Close() error
Close will close a file, checking whether the file handle is open somewhere else before closing completely. This check is performed on Windows but not Linux, therefore a mock is used to ensure that linux testing picks up potential problems that would be seen on Windows.
type ProductionResolver ¶ added in v1.3.5
type ProductionResolver struct{}
ProductionResolver is the hostname resolver used in production builds.
type Program ¶ added in v1.4.8
type Program []Instruction
Program specifies a generic program used as input to `mdm.ExecuteProram`.
func (Program) ReadOnly ¶ added in v1.4.8
ReadOnly returns true if the program consists of no write instructions.
func (Program) RequiresSnapshot ¶ added in v1.4.8
RequiresSnapshot returns true if an instruction requires access to the sector roots of a filecontract and therefore requires the host to load a snapshot from disk to provide that information.
type ProgramBuilder ¶ added in v1.4.8
type ProgramBuilder struct {
// contains filtered or unexported fields
}
ProgramBuilder is a helper type to easily create programs and compute their cost.
func NewProgramBuilder ¶ added in v1.4.8
func NewProgramBuilder(pt *RPCPriceTable, duration types.BlockHeight) *ProgramBuilder
NewProgramBuilder creates an empty program builder.
func (*ProgramBuilder) AddAppendInstruction ¶ added in v1.4.9
func (pb *ProgramBuilder) AddAppendInstruction(data []byte, merkleProof bool) error
AddAppendInstruction adds an Append instruction to the program.
func (*ProgramBuilder) AddDropSectorsInstruction ¶ added in v1.4.9
func (pb *ProgramBuilder) AddDropSectorsInstruction(numSectors uint64, merkleProof bool)
AddDropSectorsInstruction adds a DropSectors instruction to the program.
func (*ProgramBuilder) AddHasSectorInstruction ¶ added in v1.4.8
func (pb *ProgramBuilder) AddHasSectorInstruction(merkleRoot crypto.Hash)
AddHasSectorInstruction adds a HasSector instruction to the program.
func (*ProgramBuilder) AddReadOffsetInstruction ¶ added in v1.4.9
func (pb *ProgramBuilder) AddReadOffsetInstruction(length, offset uint64, merkleProof bool)
AddReadOffsetInstruction adds a ReadOffset instruction to the program.
func (*ProgramBuilder) AddReadRegistryInstruction ¶ added in v1.5.1
func (pb *ProgramBuilder) AddReadRegistryInstruction(spk types.SiaPublicKey, tweak crypto.Hash) (types.Currency, error)
AddReadRegistryInstruction adds an ReadRegistry instruction to the program.
func (*ProgramBuilder) AddReadSectorInstruction ¶ added in v1.4.8
func (pb *ProgramBuilder) AddReadSectorInstruction(length, offset uint64, merkleRoot crypto.Hash, merkleProof bool)
AddReadSectorInstruction adds a ReadSector instruction to the program.
func (*ProgramBuilder) AddRevisionInstruction ¶ added in v1.5.0
func (pb *ProgramBuilder) AddRevisionInstruction()
AddRevisionInstruction adds a Revision instruction to the program.
func (*ProgramBuilder) AddSwapSectorInstruction ¶ added in v1.5.0
func (pb *ProgramBuilder) AddSwapSectorInstruction(sector1Idx, sector2Idx uint64, merkleProof bool)
AddSwapSectorInstruction adds a SwapSector instruction to the program.
func (*ProgramBuilder) AddUpdateRegistryInstruction ¶ added in v1.5.1
func (pb *ProgramBuilder) AddUpdateRegistryInstruction(spk types.SiaPublicKey, rv SignedRegistryValue) error
AddUpdateRegistryInstruction adds an UpdateRegistry instruction to the program.
func (*ProgramBuilder) Cost ¶ added in v1.4.8
func (pb *ProgramBuilder) Cost(finalized bool) (cost, storage, collateral types.Currency)
Cost returns the current cost of the program being built by the builder. If 'finalized' is 'true', the memory cost of finalizing the program is included.
func (*ProgramBuilder) Program ¶ added in v1.4.8
func (pb *ProgramBuilder) Program() (Program, ProgramData)
Program returns the built program and programData.
func (*ProgramBuilder) V154AddReadRegistryInstruction ¶ added in v1.5.5
func (pb *ProgramBuilder) V154AddReadRegistryInstruction(spk types.SiaPublicKey, tweak crypto.Hash) (types.Currency, error)
V154AddReadRegistryInstruction adds an ReadRegistry instruction to the program for pre 155 hosts.
func (*ProgramBuilder) V154AddUpdateRegistryInstruction ¶ added in v1.5.5
func (pb *ProgramBuilder) V154AddUpdateRegistryInstruction(spk types.SiaPublicKey, rv SignedRegistryValue) error
V154AddUpdateRegistryInstruction adds an UpdateRegistry instruction to the program as done in host version 1.5.4 and below.
type ProgramData ¶ added in v1.4.9
type ProgramData []byte
ProgramData contains the raw byte data for the program.
type RPCBudget ¶ added in v1.4.8
type RPCBudget struct {
// contains filtered or unexported fields
}
RPCBudget is a helper type for threadsafe budget handling.
type RPCError ¶ added in v1.4.0
type RPCError struct { Type types.Specifier Data []byte // structure depends on Type Description string // human-readable error string }
An RPCError may be sent instead of a Response to any RPC.
type RPCExecuteProgramRequest ¶ added in v1.4.8
type RPCExecuteProgramRequest struct { // FileContractID is the id of the filecontract we would like to modify. FileContractID types.FileContractID // Instructions to be executed as a program. Program Program // ProgramDataLength is the length of the programData following this // request. ProgramDataLength uint64 }
RPCExecuteProgramRequest is the request sent by the renter to execute a program on the host's MDM.
type RPCExecuteProgramResponse ¶ added in v1.4.8
type RPCExecuteProgramResponse struct { AdditionalCollateral types.Currency OutputLength uint64 NewMerkleRoot crypto.Hash NewSize uint64 Proof []crypto.Hash Error error TotalCost types.Currency FailureRefund types.Currency }
RPCExecuteProgramResponse is the response sent by the host for each executed MDMProgram instruction.
func (RPCExecuteProgramResponse) MarshalSia ¶ added in v1.4.8
func (epr RPCExecuteProgramResponse) MarshalSia(w io.Writer) error
MarshalSia implements the SiaMarshaler interface.
func (*RPCExecuteProgramResponse) UnmarshalSia ¶ added in v1.4.8
func (epr *RPCExecuteProgramResponse) UnmarshalSia(r io.Reader) error
UnmarshalSia implements the SiaMarshaler interface.
type RPCExecuteProgramRevisionSigningRequest ¶ added in v1.5.0
type RPCExecuteProgramRevisionSigningRequest struct { Signature []byte NewRevisionNumber uint64 NewValidProofValues []types.Currency NewMissedProofValues []types.Currency }
RPCExecuteProgramRevisionSigningRequest is the request sent by the renter for updating a contract when executing a write MDM program.
type RPCExecuteProgramRevisionSigningResponse ¶ added in v1.5.0
type RPCExecuteProgramRevisionSigningResponse struct {
Signature []byte
}
RPCExecuteProgramRevisionSigningResponse is the response from the host, containing the host signature for the new revision.
type RPCFunc ¶
RPCFunc is the type signature of functions that handle RPCs. It is used for both the caller and the callee. RPCFuncs may perform locking. RPCFuncs may close the connection early, and it is recommended that they do so to avoid keeping the connection open after all necessary I/O has been performed.
type RPCLatestRevisionRequest ¶ added in v1.5.0
type RPCLatestRevisionRequest struct {
FileContractID types.FileContractID
}
RPCLatestRevisionRequest contains the id of the contract for which to retrieve the latest revision.
type RPCLatestRevisionResponse ¶ added in v1.5.0
type RPCLatestRevisionResponse struct {
Revision types.FileContractRevision
}
RPCLatestRevisionResponse contains the latest file contract revision signed by both host and renter. TODO: might need to update this to match MDMInstructionRevisionResponse?
type RPCPriceTable ¶ added in v1.4.3
type RPCPriceTable struct { // UID is a specifier that uniquely identifies this price table UID UniqueID `json:"uid"` // Validity is a duration that specifies how long the host guarantees these // prices for and are thus considered valid. Validity time.Duration `json:"validity"` // HostBlockHeight is the block height of the host. This allows the renter // to create valid withdrawal messages in case it is not synced yet. HostBlockHeight types.BlockHeight `json:"hostblockheight"` // UpdatePriceTableCost refers to the cost of fetching a new price table // from the host. UpdatePriceTableCost types.Currency `json:"updatepricetablecost"` // AccountBalanceCost refers to the cost of fetching the balance of an // ephemeral account. AccountBalanceCost types.Currency `json:"accountbalancecost"` // FundAccountCost refers to the cost of funding an ephemeral account on the // host. FundAccountCost types.Currency `json:"fundaccountcost"` // LatestRevisionCost refers to the cost of asking the host for the latest // revision of a contract. // TODO: should this be free? LatestRevisionCost types.Currency `json:"latestrevisioncost"` // SubscriptionMemoryCost is the cost of storing a byte of data for // SubscriptionPeriod time. SubscriptionMemoryCost types.Currency `json:"subscriptionmemorycost"` // SubscriptionNotificationCost is the cost of a single notification on top // of what is charged for bandwidth. SubscriptionNotificationCost types.Currency `json:"subscriptionnotificationcost"` // MDM related costs // // InitBaseCost is the amount of cost that is incurred when an MDM program // starts to run. This doesn't include the memory used by the program data. // The total cost to initialize a program is calculated as // InitCost = InitBaseCost + MemoryTimeCost * Time InitBaseCost types.Currency `json:"initbasecost"` // MemoryTimeCost is the amount of cost per byte per time that is incurred // by the memory consumption of the program. MemoryTimeCost types.Currency `json:"memorytimecost"` // Cost values specific to the bandwidth consumption. DownloadBandwidthCost types.Currency `json:"downloadbandwidthcost"` UploadBandwidthCost types.Currency `json:"uploadbandwidthcost"` // Cost values specific to the DropSectors instruction. DropSectorsBaseCost types.Currency `json:"dropsectorsbasecost"` DropSectorsUnitCost types.Currency `json:"dropsectorsunitcost"` // Cost values specific to the HasSector command. HasSectorBaseCost types.Currency `json:"hassectorbasecost"` // Cost values specific to the Read instruction. ReadBaseCost types.Currency `json:"readbasecost"` ReadLengthCost types.Currency `json:"readlengthcost"` // Cost values specific to the RenewContract instruction. RenewContractCost types.Currency `json:"renewcontractcost"` // Cost values specific to the Revision command. RevisionBaseCost types.Currency `json:"revisionbasecost"` // SwapSectorCost is the cost of swapping 2 full sectors by root. SwapSectorCost types.Currency `json:"swapsectorcost"` // Cost values specific to the Write instruction. WriteBaseCost types.Currency `json:"writebasecost"` // per write WriteLengthCost types.Currency `json:"writelengthcost"` // per byte written WriteStoreCost types.Currency `json:"writestorecost"` // per byte / block of additional storage // TxnFee estimations. TxnFeeMinRecommended types.Currency `json:"txnfeeminrecommended"` TxnFeeMaxRecommended types.Currency `json:"txnfeemaxrecommended"` // ContractPrice is the additional fee a host charges when forming/renewing // a contract to cover the miner fees when submitting the contract and // revision to the blockchain. ContractPrice types.Currency `json:"contractprice"` // CollateralCost is the amount of money per byte the host is promising to // lock away as collateral when adding new data to a contract. It's paid out // to the host regardless of the outcome of the storage proof. CollateralCost types.Currency `json:"collateralcost"` // MaxCollateral is the maximum amount of collateral the host is willing to // put into a single file contract. MaxCollateral types.Currency `json:"maxcollateral"` // MaxDuration is the max duration for which the host is willing to form a // contract. MaxDuration types.BlockHeight `json:"maxduration"` // WindowSize is the minimum time in blocks the host requests the // renewWindow of a new contract to be. WindowSize types.BlockHeight `json:"windowsize"` // Registry related fields. RegistryEntriesLeft uint64 `json:"registryentriesleft"` RegistryEntriesTotal uint64 `json:"registryentriestotal"` }
RPCPriceTable contains the cost of executing a RPC on a host. Each host can set its own prices for the individual MDM instructions and RPC costs.
type RPCRegistrySubscriptionNotificationEntryUpdate ¶ added in v1.5.5
type RPCRegistrySubscriptionNotificationEntryUpdate struct { Entry SignedRegistryValue PubKey types.SiaPublicKey }
RPCRegistrySubscriptionNotificationEntryUpdate contains an updated entry.
type RPCRegistrySubscriptionNotificationType ¶ added in v1.5.5
type RPCRegistrySubscriptionNotificationType struct {
Type uint8
}
RPCRegistrySubscriptionNotificationType contains the type of the following notification.
type RPCRegistrySubscriptionRequest ¶ added in v1.5.4
type RPCRegistrySubscriptionRequest struct { PubKey types.SiaPublicKey Tweak crypto.Hash // Ratelimit in milliseconds. This is not used yet but carved out to // avoid a breaking protocol change later on. The idea is that for every // subscribed entry, a ratelimit can be specified to avoid spam and // reduce cost. Ratelimit uint32 }
RPCRegistrySubscriptionRequest is a request to either add or remove a subscription.
type RPCRenewContractCollateralResponse ¶ added in v1.5.4
type RPCRenewContractCollateralResponse struct { NewParents []types.Transaction NewInputs []types.SiacoinInput NewOutputs []types.SiacoinOutput FinalRevSig crypto.Signature }
RPCRenewContractCollateralResponse is the response sent by the host after adding the collateral to the transaction. It contains any new parents, inputs and outputs that were added.
type RPCRenewContractHostSignatures ¶ added in v1.5.4
type RPCRenewContractHostSignatures struct { ContractSignatures []types.TransactionSignature NoOpRevisionSignature types.TransactionSignature }
RPCRenewContractHostSignatures contains the host's revisions for the final revision of the old contract, the new contract and the initial revision of the new contract.
type RPCRenewContractRenterSignatures ¶ added in v1.5.4
type RPCRenewContractRenterSignatures struct { RenterTxnSigs []types.TransactionSignature RenterNoOpRevisionSig types.TransactionSignature }
RPCRenewContractRenterSignatures contains the renter's signatures for the final revision of the old contract, the new contract and the initial revision of the new contract.
type RPCRenewContractRequest ¶ added in v1.5.4
type RPCRenewContractRequest struct { TSet []types.Transaction RenterPK types.SiaPublicKey FinalRevSig crypto.Signature }
RPCRenewContractRequest contains the transaction set with both the final revision of a contract to be renewed as well as the new contract and the renter's public key used within the unlock conditions of the new contract.
type RPCTrackedPriceTableResponse ¶ added in v1.4.9
type RPCTrackedPriceTableResponse struct{}
RPCTrackedPriceTableResponse is an empty response sent by the host to signal it has received payment for the price table and has tracked it, thus considering it valid.
type RPCUpdatePriceTableResponse ¶ added in v1.4.3
type RPCUpdatePriceTableResponse struct {
PriceTableJSON []byte
}
RPCUpdatePriceTableResponse contains a JSON encoded RPC price table
type RSCode ¶ added in v1.5.1
type RSCode struct {
// contains filtered or unexported fields
}
RSCode is a Reed-Solomon encoder/decoder. It implements the ErasureCoder interface.
func (*RSCode) Encode ¶ added in v1.5.1
Encode splits data into equal-length pieces, some containing the original data and some containing parity data.
func (*RSCode) EncodeShards ¶ added in v1.5.1
EncodeShards creates the parity shards for an already sharded input.
func (*RSCode) Identifier ¶ added in v1.5.1
func (rs *RSCode) Identifier() ErasureCoderIdentifier
Identifier returns an identifier for an erasure coder which can be used to identify erasure coders of the same type, dataPieces and parityPieces.
func (*RSCode) MinPieces ¶ added in v1.5.1
MinPieces return the minimum number of pieces that must be present to recover the original data.
func (*RSCode) NumPieces ¶ added in v1.5.1
NumPieces returns the number of pieces returned by Encode.
func (*RSCode) Reconstruct ¶ added in v1.5.1
Reconstruct recovers the full set of encoded shards from the provided pieces, of which at least MinPieces must be non-nil.
func (*RSCode) Recover ¶ added in v1.5.1
Recover recovers the original data from pieces and writes it to w. pieces should be identical to the slice returned by Encode (length and order must be preserved), but with missing elements set to nil.
func (*RSCode) SupportsPartialEncoding ¶ added in v1.5.1
SupportsPartialEncoding returns false for the basic reed-solomon encoder and a size of 0.
func (*RSCode) Type ¶ added in v1.5.1
func (rs *RSCode) Type() ErasureCoderType
Type returns the erasure coders type identifier.
type RSSubCode ¶ added in v1.5.1
type RSSubCode struct { RSCode // contains filtered or unexported fields }
RSSubCode is a Reed-Solomon encoder/decoder. It implements the ErasureCoder interface in a way that every crypto.SegmentSize bytes of encoded data can be recovered separately.
func (*RSSubCode) Encode ¶ added in v1.5.1
Encode splits data into equal-length pieces, some containing the original data and some containing parity data.
func (*RSSubCode) EncodeShards ¶ added in v1.5.1
EncodeShards encodes data in a way that every segmentSize bytes of the encoded data can be decoded independently.
func (*RSSubCode) Identifier ¶ added in v1.5.1
func (rs *RSSubCode) Identifier() ErasureCoderIdentifier
Identifier returns an identifier for an erasure coder which can be used to identify erasure coders of the same type, dataPieces and parityPieces.
func (*RSSubCode) Reconstruct ¶ added in v1.5.1
Reconstruct recovers the full set of encoded shards from the provided pieces, of which at least MinPieces must be non-nil.
func (*RSSubCode) Recover ¶ added in v1.5.1
Recover accepts encoded pieces and decodes the segment at segmentIndex. The size of the decoded data is segmentSize * dataPieces.
func (*RSSubCode) SupportsPartialEncoding ¶ added in v1.5.1
SupportsPartialEncoding returns true for the custom reed-solomon encoder and returns the segment size.
func (*RSSubCode) Type ¶ added in v1.5.1
func (rs *RSSubCode) Type() ErasureCoderType
Type returns the erasure coders type identifier.
type Receipt ¶ added in v1.4.7
type Receipt struct { Host types.SiaPublicKey Account AccountID Amount types.Currency Timestamp int64 }
Receipt is returned by the host after a successful deposit into an ephemeral account and can be used as proof of payment.
type RecoverableContract ¶ added in v1.4.0
type RecoverableContract struct { types.FileContract // ID is the FileContract's ID. ID types.FileContractID `json:"id"` // HostPublicKey is the public key of the host we formed this contract // with. HostPublicKey types.SiaPublicKey `json:"hostpublickey"` // InputParentID is the ParentID of the first SiacoinInput of the // transaction that contains this contract. InputParentID types.SiacoinOutputID `json:"inputparentid"` // StartHeight is the estimated startheight of a recoverable contract. StartHeight types.BlockHeight `json:"startheight"` // TxnFee of the transaction which contains the contract. TxnFee types.Currency `json:"txnfee"` }
RecoverableContract is a types.FileContract as it appears on the blockchain with additional fields which contain the information required to recover its latest revision from a host.
type RegistryValue ¶ added in v1.5.1
RegistryValue is a value that can be registered on a host's registry.
func NewRegistryValue ¶ added in v1.5.1
func NewRegistryValue(tweak crypto.Hash, data []byte, rev uint64) RegistryValue
NewRegistryValue is a convenience method for creating a new RegistryValue from arguments.
func (RegistryValue) Sign ¶ added in v1.5.1
func (entry RegistryValue) Sign(sk crypto.SecretKey) SignedRegistryValue
Sign adds a signature to the RegistryValue.
type Renter ¶
type Renter interface { Alerter // ActiveHosts provides the list of hosts that the renter is selecting, // sorted by preference. ActiveHosts() ([]HostDBEntry, error) // AllHosts returns the full list of hosts known to the renter. AllHosts() ([]HostDBEntry, error) // Close closes the Renter. Close() error // CancelContract cancels a specific contract of the renter. CancelContract(id types.FileContractID) error // Contracts returns the staticContracts of the renter's hostContractor. Contracts() []RenterContract // ContractStatus returns the status of the contract with the given ID in the // watchdog, and a bool indicating whether or not the watchdog is aware of it. ContractStatus(fcID types.FileContractID) (ContractWatchStatus, bool) // CreateBackup creates a backup of the renter's siafiles. If a secret is not // nil, the backup will be encrypted using the provided secret. CreateBackup(dst string, secret []byte) error // LoadBackup loads the siafiles of a previously created backup into the // renter. If the backup is encrypted, secret will be used to decrypt it. // Otherwise the argument is ignored. // If a file from the backup would have the same path as an already // existing file, a suffix of the form _[num] is appended to the siapath. // [num] is incremented until a siapath is found that is not already in // use. LoadBackup(src string, secret []byte) error // InitRecoveryScan starts scanning the whole blockchain for recoverable // contracts within a separate thread. InitRecoveryScan() error // OldContracts returns the oldContracts of the renter's hostContractor. OldContracts() []RenterContract // ContractorChurnStatus returns contract churn stats for the current period. ContractorChurnStatus() ContractorChurnStatus // ContractUtility provides the contract utility for a given host key. ContractUtility(pk types.SiaPublicKey) (ContractUtility, bool) // CurrentPeriod returns the height at which the current allowance period // began. CurrentPeriod() types.BlockHeight // MemoryStatus returns the current status of the memory manager MemoryStatus() (MemoryStatus, error) // Mount mounts a FUSE filesystem at mountPoint, making the contents of sp // available via the local filesystem. Mount(mountPoint string, sp SiaPath, opts MountOptions) error // MountInfo returns the list of currently mounted FUSE filesystems. MountInfo() []MountInfo // Unmount unmounts the FUSE filesystem currently mounted at mountPoint. Unmount(mountPoint string) error // PeriodSpending returns the amount spent on contracts in the current // billing period. PeriodSpending() (ContractorSpending, error) // RecoverableContracts returns the contracts that the contractor deems // recoverable. That means they are not expired yet and also not part of the // active contracts. Usually this should return an empty slice unless the host // isn't available for recovery or something went wrong. RecoverableContracts() []RecoverableContract // RecoveryScanStatus returns a bool indicating if a scan for recoverable // contracts is in progress and if it is, the current progress of the scan. RecoveryScanStatus() (bool, types.BlockHeight) // RefreshedContract checks if the contract was previously refreshed RefreshedContract(fcid types.FileContractID) bool // SetFileStuck sets the 'stuck' status of a file. SetFileStuck(siaPath SiaPath, stuck bool) error // UploadBackup uploads a backup to hosts, such that it can be retrieved // using only the seed. UploadBackup(src string, name string) error // DownloadBackup downloads a backup previously uploaded to hosts. DownloadBackup(dst string, name string) error // UploadedBackups returns a list of backups previously uploaded to hosts, // along with a list of which hosts are storing all known backups. UploadedBackups() ([]UploadedBackup, []types.SiaPublicKey, error) // BackupsOnHost returns the backups stored on the specified host. BackupsOnHost(hostKey types.SiaPublicKey) ([]UploadedBackup, error) // DeleteFile deletes a file entry from the renter. DeleteFile(siaPath SiaPath) error // Download creates a download according to the parameters passed, including // downloads of `offset` and `length` type. It returns a method to // start the download. Download(params RenterDownloadParameters) (DownloadID, func() error, error) // DownloadAsync creates a file download using the passed parameters without // blocking until the download is finished. The download needs to be started // using the method returned by DownloadAsync. DownloadAsync also accepts an // optional input function which will be registered to be called when the // download is finished. DownloadAsync(params RenterDownloadParameters, onComplete func(error) error) (uid DownloadID, start func() error, cancel func(), err error) // ClearDownloadHistory clears the download history of the renter // inclusive for before and after times. ClearDownloadHistory(after, before time.Time) error // DownloadByUID returns a download from the download history given its uid. DownloadByUID(uid DownloadID) (DownloadInfo, bool) // DownloadHistory lists all the files that have been scheduled for download. DownloadHistory() []DownloadInfo // File returns information on specific file queried by user File(siaPath SiaPath) (FileInfo, error) // FileList returns information on all of the files stored by the renter at the // specified folder. The 'cached' argument specifies whether cached values // should be returned or not. FileList(siaPath SiaPath, recursive, cached bool, flf FileListFunc) error // Filter returns the renter's hostdb's filterMode and filteredHosts Filter() (FilterMode, map[string]types.SiaPublicKey, error) // SetFilterMode sets the renter's hostdb filter mode SetFilterMode(fm FilterMode, hosts []types.SiaPublicKey) error // Host provides the DB entry and score breakdown for the requested host. Host(pk types.SiaPublicKey) (HostDBEntry, bool, error) // InitialScanComplete returns a boolean indicating if the initial scan of the // hostdb is completed. InitialScanComplete() (bool, error) // PriceEstimation estimates the cost in siacoins of performing various // storage and data operations. PriceEstimation(allowance Allowance) (RenterPriceEstimation, Allowance, error) // RenameFile changes the path of a file. RenameFile(siaPath, newSiaPath SiaPath) error // RenameDir changes the path of a dir. RenameDir(oldPath, newPath SiaPath) error // EstimateHostScore will return the score for a host with the provided // settings, assuming perfect age and uptime adjustments EstimateHostScore(entry HostDBEntry, allowance Allowance) (HostScoreBreakdown, error) // ReadRegistry starts a registry lookup on all available workers. The // jobs have 'timeout' amount of time to finish their jobs and return a // response. Otherwise the response with the highest revision number will be // used. ReadRegistry(spk types.SiaPublicKey, tweak crypto.Hash, timeout time.Duration) (SignedRegistryValue, error) // ScoreBreakdown will return the score for a host db entry using the // hostdb's weighting algorithm. ScoreBreakdown(entry HostDBEntry) (HostScoreBreakdown, error) // Settings returns the Renter's current settings. Settings() (RenterSettings, error) // SetSettings sets the Renter's settings. SetSettings(RenterSettings) error // SetFileTrackingPath sets the on-disk location of an uploaded file to a // new value. Useful if files need to be moved on disk. SetFileTrackingPath(siaPath SiaPath, newPath string) error // UpdateRegistry updates the registries on all workers with the given // registry value. UpdateRegistry(spk types.SiaPublicKey, srv SignedRegistryValue, timeout time.Duration) error // PauseRepairsAndUploads pauses the renter's repairs and uploads for a time // duration PauseRepairsAndUploads(duration time.Duration) error // ResumeRepairsAndUploads resumes the renter's repairs and uploads ResumeRepairsAndUploads() error // Streamer creates a io.ReadSeeker that can be used to stream downloads // from the Sia network and also returns the fileName of the streamed // resource. Streamer(siapath SiaPath, disableLocalFetch bool) (string, Streamer, error) // Upload uploads a file using the input parameters. Upload(FileUploadParams) error // UploadStreamFromReader reads from the provided reader until io.EOF is reached and // upload the data to the Sia network. UploadStreamFromReader(up FileUploadParams, reader io.Reader) error // CreateDir creates a directory for the renter CreateDir(siaPath SiaPath, mode os.FileMode) error // DeleteDir deletes a directory from the renter DeleteDir(siaPath SiaPath) error // DirList lists the directories in a siadir DirList(siaPath SiaPath) ([]DirectoryInfo, error) // AddSkykey adds the skykey to the renter's skykey manager. AddSkykey(skykey.Skykey) error // CreateSkykey creates a new Skykey with the given name and SkykeyType. CreateSkykey(string, skykey.SkykeyType) (skykey.Skykey, error) // DeleteSkykeyByID deletes the Skykey with the given name from the renter's skykey // manager if it exists. DeleteSkykeyByID(skykey.SkykeyID) error // DeleteSkykeyByName deletes the Skykey with the given name from the renter's skykey // manager if it exists. DeleteSkykeyByName(string) error // SkykeyByName gets the Skykey with the given name from the renter's skykey // manager if it exists. SkykeyByName(string) (skykey.Skykey, error) // SkykeyByID gets the Skykey with the given ID from the renter's skykey // manager if it exists. SkykeyByID(skykey.SkykeyID) (skykey.Skykey, error) // SkykeyIDByName gets the SkykeyID of the key with the given name if it // exists. SkykeyIDByName(string) (skykey.SkykeyID, error) // Skykeys returns a slice containing each Skykey being stored by the renter. Skykeys() ([]skykey.Skykey, error) // CreateSkylinkFromSiafile will create a skylink from a siafile. This will // result in some uploading - the base sector skyfile needs to be uploaded // separately, and if there is a fanout expansion that needs to be uploaded // separately as well. CreateSkylinkFromSiafile(SkyfileUploadParameters, SiaPath) (Skylink, error) // DownloadByRoot will fetch data using the merkle root of that data. This // uses all of the async worker primitives to improve speed and throughput. DownloadByRoot(root crypto.Hash, offset, length uint64, timeout time.Duration) ([]byte, error) // DownloadSkylink will fetch a file from the Sia network using the skylink. DownloadSkylink(Skylink, time.Duration) (SkyfileLayout, SkyfileMetadata, Streamer, error) // DownloadSkylinkBaseSector will take a link and turn it into the data of a download // without any decoding of the metadata, fanout, or decryption. DownloadSkylinkBaseSector(Skylink, time.Duration) (Streamer, error) // UploadSkyfile will upload data to the Sia network from a reader and // create a skyfile, returning the skylink that can be used to access the // file. // // NOTE: A skyfile is a file that is tracked and repaired by the renter. A // skyfile contains more than just the file data, it also contains metadata // about the file and other information which is useful in fetching the // file. UploadSkyfile(SkyfileUploadParameters, SkyfileUploadReader) (Skylink, error) // Blocklist returns the merkleroots that are blocked Blocklist() ([]crypto.Hash, error) // UpdateSkynetBlocklist updates the list of hashed merkleroots that are blocked UpdateSkynetBlocklist(additions, removals []crypto.Hash) error // PinSkylink re-uploads the data stored at the file under that skylink with // the given parameters. PinSkylink(Skylink, SkyfileUploadParameters, time.Duration) error // Portals returns the list of known skynet portals. Portals() ([]SkynetPortal, error) // RestoreSkyfile restores a skyfile such that the skylink is preserved. RestoreSkyfile(reader io.Reader) (Skylink, error) // UpdateSkynetPortals updates the list of known skynet portals. UpdateSkynetPortals(additions []SkynetPortal, removals []NetAddress) error // WorkerPoolStatus returns the current status of the Renter's worker pool WorkerPoolStatus() (WorkerPoolStatus, error) }
A Renter uploads, tracks, repairs, and downloads a set of files for the user.
type RenterContract ¶ added in v1.0.0
type RenterContract struct { ID types.FileContractID HostPublicKey types.SiaPublicKey Transaction types.Transaction StartHeight types.BlockHeight EndHeight types.BlockHeight // RenterFunds is the amount remaining in the contract that the renter can // spend. RenterFunds types.Currency // The FileContract does not indicate what funds were spent on, so we have // to track the various costs manually. DownloadSpending types.Currency StorageSpending types.Currency UploadSpending types.Currency // Utility contains utility information about the renter. Utility ContractUtility // TotalCost indicates the amount of money that the renter spent and/or // locked up while forming a contract. This includes fees, and includes // funds which were allocated (but not necessarily committed) to spend on // uploads/downloads/storage. TotalCost types.Currency // ContractFee is the amount of money paid to the host to cover potential // future transaction fees that the host may incur, and to cover any other // overheads the host may have. // // TxnFee is the amount of money spent on the transaction fee when putting // the renter contract on the blockchain. // // SiafundFee is the amount of money spent on siafund fees when creating the // contract. The siafund fee that the renter pays covers both the renter and // the host portions of the contract, and therefore can be unexpectedly high // if the the host collateral is high. ContractFee types.Currency TxnFee types.Currency SiafundFee types.Currency }
A RenterContract contains metadata about a file contract. It is read-only; modifying a RenterContract does not modify the actual file contract.
func (*RenterContract) Size ¶ added in v1.5.1
func (rc *RenterContract) Size() uint64
Size returns the contract size
type RenterDownloadParameters ¶ added in v1.3.0
type RenterDownloadParameters struct { Async bool Httpwriter io.Writer Length uint64 Offset uint64 SiaPath SiaPath Destination string DisableDiskFetch bool }
RenterDownloadParameters defines the parameters passed to the Renter's Download method.
type RenterHostSession ¶ added in v1.4.0
type RenterHostSession struct {
// contains filtered or unexported fields
}
A RenterHostSession is a session of the new renter-host protocol.
func (*RenterHostSession) ReadRPCID ¶ added in v1.4.0
func (s *RenterHostSession) ReadRPCID() (rpcID types.Specifier, err error)
ReadRPCID reads an RPC request ID using the new loop protocol.
func (*RenterHostSession) ReadRequest ¶ added in v1.4.0
func (s *RenterHostSession) ReadRequest(req interface{}, maxLen uint64) error
ReadRequest reads an RPC request using the new loop protocol.
func (*RenterHostSession) ReadResponse ¶ added in v1.4.0
func (s *RenterHostSession) ReadResponse(resp interface{}, maxLen uint64) error
ReadResponse reads an RPC response using the new loop protocol.
func (*RenterHostSession) WriteRequest ¶ added in v1.4.0
func (s *RenterHostSession) WriteRequest(rpcID types.Specifier, req interface{}) error
WriteRequest writes an encrypted RPC request using the new loop protocol.
func (*RenterHostSession) WriteResponse ¶ added in v1.4.0
func (s *RenterHostSession) WriteResponse(resp interface{}, err error) error
WriteResponse writes an RPC response or error using the new loop protocol. Either resp or err must be nil. If err is an *RPCError, it is sent directly; otherwise, a generic RPCError is created from err's Error string.
type RenterPriceEstimation ¶ added in v1.1.1
type RenterPriceEstimation struct { // The cost of downloading 1 TB of data. DownloadTerabyte types.Currency `json:"downloadterabyte"` // The cost of forming a set of contracts using the defaults. FormContracts types.Currency `json:"formcontracts"` // The cost of storing 1 TB for a month, including redundancy. StorageTerabyteMonth types.Currency `json:"storageterabytemonth"` // The cost of consuming 1 TB of upload bandwidth from the host, including // redundancy. UploadTerabyte types.Currency `json:"uploadterabyte"` }
RenterPriceEstimation contains a bunch of files estimating the costs of various operations on the network.
type RenterSeed ¶ added in v1.5.5
type RenterSeed Seed
RenterSeed is the master seed of the renter which is used to derive other seeds.
func DeriveRenterSeed ¶ added in v1.5.5
func DeriveRenterSeed(walletSeed Seed) RenterSeed
DeriveRenterSeed creates a renterSeed for creating file contracts. NOTE: The seed returned by this function should be wiped once it's no longer in use.
func (RenterSeed) EphemeralRenterSeed ¶ added in v1.5.5
func (rs RenterSeed) EphemeralRenterSeed(windowStart types.BlockHeight) EphemeralRenterSeed
EphemeralRenterSeed creates a renterSeed for creating file contracts. NOTE: The seed returned by this function should be wiped once it's no longer in use.
type RenterSettings ¶ added in v1.0.0
type RenterSettings struct { Allowance Allowance `json:"allowance"` IPViolationCheck bool `json:"ipviolationcheck"` MaxUploadSpeed int64 `json:"maxuploadspeed"` MaxDownloadSpeed int64 `json:"maxdownloadspeed"` UploadsStatus UploadsStatus `json:"uploadsstatus"` }
RenterSettings control the behavior of the Renter.
type RenterStats ¶ added in v1.5.5
type RenterStats struct { // A name for this renter. Name string `json:"name"` // Any alerts that are in place for this renter. Alerts []Alert `json:"alerts"` // Performance and throughput information related to the API. SkynetPerformance SkynetPerformanceStats `json:"skynetperformance"` // The total amount of contract data that hosts are maintaining on behalf of // the renter is the sum of these fields. ActiveContractData uint64 `json:"activecontractdata"` PassiveContractData uint64 `json:"passivecontractdata"` WastedContractData uint64 `json:"wastedcontractdata"` TotalSiafiles uint64 `json:"totalsiafiles"` TotalSiadirs uint64 `json:"totalsiadirs"` TotalSize uint64 `json:"totalsize"` TotalContractSpentFunds types.Currency `json:"totalcontractspentfunds"` // Includes fees TotalContractSpentFees types.Currency `json:"totalcontractspentfees"` TotalContractRemainingFunds types.Currency `json:"totalcontractremainingfunds"` AllowanceFunds types.Currency `json:"allowancefunds"` AllowanceUnspentUnallocated types.Currency `json:"allowanceunspentunallocated"` WalletFunds types.Currency `json:"walletfunds"` // Includes unconfirmed // Information about the status of the memory queue. If the memory is all // used up, jobs will start blocking eachother. HasRenterMemory bool `json:"hasrentermemory"` HasPriorityRenterMemory bool `json:"haspriorityrentermemory"` }
RenterStats is a struct which tracks key metrics in a single renter. This struct is intended to give a large overview / large dump of data related to the renter, which can then be aggregated across a fleet of renters by a program which monitors for inconsistencies or other challenges.
type RequestTimeDistribution ¶ added in v1.5.5
type RequestTimeDistribution struct { N60ms float64 `json:"n60ms"` // Requests taking less than 60ms N120ms float64 `json:"n120ms"` N240ms float64 `json:"n240ms"` N500ms float64 `json:"n500ms"` N1000ms float64 `json:"n1000ms"` N2000ms float64 `json:"n2000ms"` N5000ms float64 `json:"n5000ms"` N10s float64 `json:"n10s"` NLong float64 `json:"nlong"` // Requests taking longer than 10 seconds. NErr float64 `json:"nerr"` // Requests that errored out. TotalSize float64 `json:"totalsize"` }
RequestTimeDistribution contains a distribution of requests, bucketed by how long each request took to return. The buckets use an exponential decay to get a good measurement, which means that the number of requests in each bucket may not be a whole number. It also means that the distribution is not reliable until stats collection has been running for a large multiple of the half life of the distribution.
Exponential decay is used to limit the memory footprint and computational overhead of stats collection.
type Resolver ¶ added in v1.3.5
Resolver is an interface that allows resolving a hostname into IP addresses.
type RevisionAction ¶ added in v1.0.0
A RevisionAction is a description of an edit to be performed on a file contract. Three types are allowed, 'ActionDelete', 'ActionInsert', and 'ActionModify'. ActionDelete just takes a sector index, indicating which sector is going to be deleted. ActionInsert takes a sector index, and a full sector of data, indicating that a sector at the index should be inserted with the provided data. 'Modify' revises the sector at the given index, rewriting it with the provided data starting from the 'offset' within the sector.
Modify could be simulated with an insert and a delete, however an insert requires a full sector to be uploaded, and a modify can be just a few kb, which can be significantly faster.
type Seed ¶ added in v1.0.0
type Seed [crypto.EntropySize]byte
Seed is cryptographic entropy that is used to derive spendable wallet addresses.
func StringToSeed ¶ added in v1.0.0
func StringToSeed(str string, did mnemonics.DictionaryID) (Seed, error)
StringToSeed converts a string to a wallet seed.
type SiaPath ¶ added in v1.4.0
type SiaPath struct {
Path string `json:"path"`
}
SiaPath is the struct used to uniquely identify siafiles and siadirs across Sia
func CombinedSiaFilePath ¶ added in v1.4.2
func CombinedSiaFilePath(ec ErasureCoder) SiaPath
CombinedSiaFilePath returns the SiaPath to a hidden siafile which is used to store chunks that contain pieces of multiple siafiles.
func NewGlobalSiaPath ¶ added in v1.4.2
NewGlobalSiaPath can be used to create a global var which is a SiaPath. If there is an error creating the SiaPath, the function will panic, making this function unsuitable for typical use.
func NewSiaPath ¶ added in v1.4.0
NewSiaPath returns a new SiaPath with the path set
func RandomSiaPath ¶ added in v1.4.1
func RandomSiaPath() (sp SiaPath)
RandomSiaPath returns a random SiaPath created from 20 bytes of base32 encoded entropy.
func RootSiaPath ¶ added in v1.4.0
func RootSiaPath() SiaPath
RootSiaPath returns a SiaPath for the root siadir which has a blank path
func (SiaPath) AddSuffix ¶ added in v1.4.1
AddSuffix adds a numeric suffix to the end of the SiaPath.
func (*SiaPath) FromSysPath ¶ added in v1.4.1
FromSysPath creates a SiaPath from a siaFilePath and corresponding root files dir.
func (SiaPath) IsEmpty ¶ added in v1.4.2
IsEmpty returns true if the siapath is equal to the nil value
func (SiaPath) IsRoot ¶ added in v1.4.0
IsRoot indicates whether or not the SiaPath path is a root directory siapath
func (SiaPath) Join ¶ added in v1.4.0
Join joins the string to the end of the SiaPath with a "/" and returns the new SiaPath.
func (*SiaPath) LoadString ¶ added in v1.4.0
LoadString sets the path of the SiaPath to the provided string
func (*SiaPath) LoadSysPath ¶ added in v1.4.1
LoadSysPath loads a SiaPath from a given system path by trimming the dir at the front of the path, the extension at the back and returning the remaining path as a SiaPath.
func (SiaPath) MarshalJSON ¶ added in v1.4.0
MarshalJSON marshals a SiaPath as a string.
func (SiaPath) Rebase ¶ added in v1.4.1
Rebase changes the base of a siapath from oldBase to newBase and returns a new SiaPath. e.g. rebasing 'a/b/myfile' from oldBase 'a/b/' to 'a/' would result in 'a/myfile'
func (SiaPath) SiaDirMetadataSysPath ¶ added in v1.4.0
SiaDirMetadataSysPath returns the system path needed to read the SiaDir metadata file from disk, the input dir is the root siadir directory on disk
func (SiaPath) SiaDirSysPath ¶ added in v1.4.0
SiaDirSysPath returns the system path needed to read a directory on disk, the input dir is the root siadir directory on disk
func (SiaPath) SiaFileSysPath ¶ added in v1.4.0
SiaFileSysPath returns the system path needed to read the SiaFile from disk, the input dir is the root siafile directory on disk
func (SiaPath) SiaPartialsFileSysPath ¶ added in v1.4.2
SiaPartialsFileSysPath returns the system path needed to read the PartialsSiaFile from disk, the input dir is the root siafile directory on disk
func (*SiaPath) UnmarshalJSON ¶ added in v1.4.0
UnmarshalJSON unmarshals a siapath into a SiaPath object.
type SiacoinOutputDiff ¶ added in v0.3.1
type SiacoinOutputDiff struct { Direction DiffDirection ID types.SiacoinOutputID SiacoinOutput types.SiacoinOutput }
A SiacoinOutputDiff indicates the addition or removal of a SiacoinOutput in the consensus set.
type SiadConfig ¶ added in v1.4.1
type SiadConfig struct { // Ratelimit related fields ReadBPS int64 `json:"readbps"` WriteBPSDeprecated int64 `json:"writeps,siamismatch"` WriteBPS int64 `json:"writebps"` PacketSize uint64 `json:"packetsize"` // contains filtered or unexported fields }
SiadConfig is a helper type to manage the global siad config.
func NewConfig ¶ added in v1.4.1
func NewConfig(path string) (*SiadConfig, error)
NewConfig loads a config from disk or creates a new one if no config exists yet.
func (*SiadConfig) SetRatelimit ¶ added in v1.4.1
func (cfg *SiadConfig) SetRatelimit(readBPS, writeBPS int64) error
SetRatelimit sets the ratelimit related fields in the config and persists it to disk.
type SiafundOutputDiff ¶ added in v0.3.1
type SiafundOutputDiff struct { Direction DiffDirection ID types.SiafundOutputID SiafundOutput types.SiafundOutput }
A SiafundOutputDiff indicates the addition or removal of a SiafundOutput in the consensus set.
type SiafundPoolDiff ¶ added in v0.3.1
type SiafundPoolDiff struct { Direction DiffDirection Previous types.Currency Adjusted types.Currency }
A SiafundPoolDiff contains the value of the siafundPool before the block was applied, and after the block was applied. When applying the diff, set siafundPool to 'Adjusted'. When reverting the diff, set siafundPool to 'Previous'.
type SignedRegistryValue ¶ added in v1.5.1
type SignedRegistryValue struct { RegistryValue Signature crypto.Signature }
SignedRegistryValue is a value that can be registered on a host's registry that has been signed.
func NewSignedRegistryValue ¶ added in v1.5.1
func NewSignedRegistryValue(tweak crypto.Hash, data []byte, rev uint64, sig crypto.Signature) SignedRegistryValue
NewSignedRegistryValue is a convenience method for creating a new SignedRegistryValue from arguments.
type SkyfileBackupHeader ¶ added in v1.5.4
type SkyfileBackupHeader struct { // Metadata contains the persist Metadata identifying the type and version of // the backup persist.Metadata // Skylink is the skylink for the backed up skyfile Skylink string }
SkyfileBackupHeader defines the data that goes at the head of the backup
type SkyfileFormat ¶ added in v1.4.4
type SkyfileFormat string
SkyfileFormat is the file format the API uses to return a Skyfile as.
func (SkyfileFormat) Extension ¶ added in v1.5.0
func (sf SkyfileFormat) Extension() string
Extension returns the extension for the format
func (SkyfileFormat) IsArchive ¶ added in v1.5.0
func (sf SkyfileFormat) IsArchive() bool
IsArchive returns true if the format is an archive.
type SkyfileLayout ¶ added in v1.5.4
type SkyfileLayout struct { Version uint8 Filesize uint64 MetadataSize uint64 FanoutSize uint64 FanoutDataPieces uint8 FanoutParityPieces uint8 CipherType crypto.CipherType KeyData [layoutKeyDataSize]byte // keyData is incompatible with ciphers that need keys larger than 64 bytes }
SkyfileLayout explains the layout information that is used for storing data inside of the skyfile. The SkyfileLayout always appears as the first bytes of the leading chunk.
func (*SkyfileLayout) Decode ¶ added in v1.5.4
func (sl *SkyfileLayout) Decode(b []byte)
Decode will take a []byte and load the layout from that []byte.
func (*SkyfileLayout) DecodeFanoutIntoChunks ¶ added in v1.5.5
func (sl *SkyfileLayout) DecodeFanoutIntoChunks(fanoutBytes []byte) ([][]crypto.Hash, error)
DecodeFanoutIntoChunks will take the fanout bytes from a skyfile and decode them in to chunks.
func (*SkyfileLayout) Encode ¶ added in v1.5.4
func (sl *SkyfileLayout) Encode() []byte
Encode will return a []byte that has compactly encoded all of the layout data.
type SkyfileMetadata ¶ added in v1.4.3
type SkyfileMetadata struct { Filename string `json:"filename,omitempty"` Length uint64 `json:"length,omitempty"` Mode os.FileMode `json:"mode,omitempty"` Subfiles SkyfileSubfiles `json:"subfiles,omitempty"` DefaultPath string `json:"defaultpath,omitempty"` DisableDefaultPath bool `json:"disabledefaultpath,omitempty"` }
SkyfileMetadata is all of the metadata that gets placed into the first 4096 bytes of the skyfile, and is used to set the metadata of the file when writing back to disk. The data is json-encoded when it is placed into the leading bytes of the skyfile, meaning that this struct can be extended without breaking compatibility.
func (SkyfileMetadata) ContentType ¶ added in v1.4.4
func (sm SkyfileMetadata) ContentType() string
ContentType returns the Content Type of the data. We only return a content-type if it has exactly one subfile. As that is the only case where we can be sure of it.
func (SkyfileMetadata) ForPath ¶ added in v1.4.4
func (sm SkyfileMetadata) ForPath(path string) (SkyfileMetadata, bool, uint64, uint64)
ForPath returns a subset of the SkyfileMetadata that contains all of the subfiles for the given path. The path can lead to both a directory or a file. Note that this method will return the subfiles with offsets relative to the given path, so if a directory is requested, the subfiles in that directory will start at offset 0, relative to the path.
func (SkyfileMetadata) IsDirectory ¶ added in v1.5.0
func (sm SkyfileMetadata) IsDirectory() bool
IsDirectory returns true if the SkyfileMetadata represents a directory.
type SkyfileMultipartUploadParameters ¶ added in v1.4.4
type SkyfileMultipartUploadParameters struct { SiaPath SiaPath Force bool Root bool BaseChunkRedundancy uint8 Reader io.Reader // Filename indicates the filename of the skyfile. Filename string // DefaultPath indicates the default file to be opened when opening skyfiles // that contain directories. If set to empty string no file will be opened // by default. DefaultPath string // DisableDefaultPath prevents the usage of DefaultPath. As a result no // content will be automatically served for the skyfile. DisableDefaultPath bool // ContentType indicates the media of the data supplied by the reader. ContentType string }
SkyfileMultipartUploadParameters defines the parameters specific to multipart uploads. See SkyfileUploadParameters for a detailed description of the fields.
type SkyfilePinParameters ¶ added in v1.4.4
type SkyfilePinParameters struct { SiaPath SiaPath `json:"siapath"` Force bool `json:"force"` Root bool `json:"root"` BaseChunkRedundancy uint8 `json:"basechunkredundancy"` }
SkyfilePinParameters defines the parameters specific to pinning a skylink. See SkyfileUploadParameters for a detailed description of the fields.
type SkyfileSubfileMetadata ¶ added in v1.4.4
type SkyfileSubfileMetadata struct { FileMode os.FileMode `json:"mode,omitempty,siamismatch"` // different json name for compat reasons Filename string `json:"filename,omitempty"` ContentType string `json:"contenttype,omitempty"` Offset uint64 `json:"offset,omitempty"` Len uint64 `json:"len,omitempty"` }
SkyfileSubfileMetadata is all of the metadata that belongs to a subfile in a skyfile. Most importantly it contains the offset at which the subfile is written and its length. Its filename can potentially include a '/' character as nested files and directories are allowed within a single Skyfile, but it is not allowed to contain ./, ../, be empty, or start with a forward slash.
func AddMultipartFile ¶ added in v1.5.1
func AddMultipartFile(w *multipart.Writer, filedata []byte, filekey, filename string, filemode uint64, offset *uint64) (SkyfileSubfileMetadata, error)
AddMultipartFile is a helper function to add a file to multipart form-data. Note that the given data will be treated as binary data and the multipart ContentType header will be set accordingly.
func (SkyfileSubfileMetadata) IsDir ¶ added in v1.4.4
func (sm SkyfileSubfileMetadata) IsDir() bool
IsDir implements the os.FileInfo interface for SkyfileSubfileMetadata.
func (SkyfileSubfileMetadata) IsHTML ¶ added in v1.5.1
func (sm SkyfileSubfileMetadata) IsHTML() bool
IsHTML returns whether or not this subfile is an HTML file
func (SkyfileSubfileMetadata) ModTime ¶ added in v1.4.4
func (sm SkyfileSubfileMetadata) ModTime() time.Time
ModTime implements the os.FileInfo interface for SkyfileSubfileMetadata.
func (SkyfileSubfileMetadata) Mode ¶ added in v1.4.4
func (sm SkyfileSubfileMetadata) Mode() os.FileMode
Mode implements the os.FileInfo interface for SkyfileSubfileMetadata.
func (SkyfileSubfileMetadata) Name ¶ added in v1.4.4
func (sm SkyfileSubfileMetadata) Name() string
Name implements the os.FileInfo interface for SkyfileSubfileMetadata.
func (SkyfileSubfileMetadata) Size ¶ added in v1.4.4
func (sm SkyfileSubfileMetadata) Size() int64
Size implements the os.FileInfo interface for SkyfileSubfileMetadata.
func (SkyfileSubfileMetadata) Sys ¶ added in v1.4.4
func (sm SkyfileSubfileMetadata) Sys() interface{}
Sys implements the os.FileInfo interface for SkyfileSubfileMetadata.
type SkyfileSubfiles ¶ added in v1.4.4
type SkyfileSubfiles map[string]SkyfileSubfileMetadata
SkyfileSubfiles contains the subfiles of a skyfile, indexed by their filename.
type SkyfileUploadParameters ¶ added in v1.4.3
type SkyfileUploadParameters struct { // SiaPath defines the siapath that the skyfile is going to be uploaded // to. Recommended that the skyfile is placed in /var/skynet SiaPath SiaPath // DryRun allows to retrieve the skylink without actually uploading the // file to the Sia network. DryRun bool // Force determines whether the upload should overwrite an existing // siafile at 'SiaPath'. If set to false, an error will be returned if // there is already a file or folder at 'SiaPath'. If set to true, any // existing file or folder at 'SiaPath' will be deleted and overwritten. Force bool // Root determines whether the upload should treat the filepath as a // path from system root, or if the path should be from /var/skynet. Root bool // The base chunk is always uploaded with a 1-of-N erasure coding // setting, meaning that only the redundancy needs to be configured by // the user. BaseChunkRedundancy uint8 // Filename indicates the filename of the skyfile. Filename string // Mode indicates the file permissions of the skyfile. Mode os.FileMode // DefaultPath indicates what content to serve if the user has not // specified a path and the user is not trying to download the Skylink // as an archive. If left empty, it will be interpreted as "index.html" // on download, if the skyfile contains such a file, or the only file in // the skyfile, if the skyfile contains a single file. DefaultPath string // DisableDefaultPath prevents the usage of DefaultPath. As a result no // content will be automatically served for the skyfile. DisableDefaultPath bool // Reader supplies the file data for the skyfile. Reader io.Reader // SkykeyName is the name of the Skykey that should be used to encrypt // the Skyfile. SkykeyName string // SkykeyID is the ID of Skykey that should be used to encrypt the file. SkykeyID skykey.SkykeyID // If Encrypt is set to true and one of SkykeyName or SkykeyID was set, // a Skykey will be derived from the Master Skykey found under that // name/ID to be used for this specific upload. FileSpecificSkykey skykey.Skykey }
SkyfileUploadParameters establishes the parameters such as the intra-root erasure coding.
type SkyfileUploadReader ¶ added in v1.5.4
type SkyfileUploadReader interface { AddReadBuffer(data []byte) FanoutReader() io.Reader SkyfileMetadata(ctx context.Context) (SkyfileMetadata, error) io.Reader }
SkyfileUploadReader is an interface that wraps a reader, containing the Skyfile data, and adds a method to fetch the SkyfileMetadata.
func NewSkyfileMultipartReader ¶ added in v1.5.4
func NewSkyfileMultipartReader(reader *multipart.Reader, fanoutReader *multipart.Reader, sup SkyfileUploadParameters) SkyfileUploadReader
NewSkyfileMultipartReader wraps the given reader and returns a SkyfileUploadReader. By reading from this reader until an EOF is reached, the SkyfileMetadata will be constructed incrementally every time a new Part is read.
NOTE: The fanout reader should be created from the io.Reader generated by a TeeReader of the underlying io.Reader that was used to create the multipart.Reader.
func NewSkyfileMultipartReaderFromRequest ¶ added in v1.5.4
func NewSkyfileMultipartReaderFromRequest(req *http.Request, sup SkyfileUploadParameters) (SkyfileUploadReader, error)
NewSkyfileMultipartReaderFromRequest generates a multipart reader from the http request and returns a SkyfileUploadReader.
func NewSkyfileReader ¶ added in v1.5.4
func NewSkyfileReader(reader io.Reader, sup SkyfileUploadParameters) SkyfileUploadReader
NewSkyfileReader wraps the given reader and metadata and returns a SkyfileUploadReader
type Skylink ¶ added in v1.4.3
type Skylink struct {
// contains filtered or unexported fields
}
Skylink contains all of the information that can be encoded into a skylink. This information consists of a 32 byte MerkleRoot and a 2 byte bitfield.
The first two bits of the bitfield (values 1 and 2 in decimal) determine the version of the skylink. The skylink version determines how the remaining bits are used. Not all values of the bitfield are legal.
func NewSkylinkV1 ¶ added in v1.4.3
NewSkylinkV1 will return a v1 Skylink object with the version set to 1 and the remaining fields set appropriately. Note that the offset needs to be aligned correctly. Check OffsetAndFetchSize for a full list of rules on legal offsets - the value of a legal offset depends on the provided length.
The input length will automatically be converted to the nearest fetch size.
func (Skylink) DataSourceID ¶ added in v1.5.1
func (sl Skylink) DataSourceID() DataSourceID
DataSourceID returns a resource ID for the Skylink. This ID is typically used inside of the renter to uniquely identify a stream buffer.
func (Skylink) IsSkylinkV1 ¶ added in v1.5.5
IsSkylinkV1 returns a boolean indicating if the Skylink is a V1 skylink
func (*Skylink) LoadString ¶ added in v1.4.3
LoadString converts from a string and loads the result into sl.
func (Skylink) MerkleRoot ¶ added in v1.4.3
MerkleRoot returns the merkle root of the Skylink.
func (Skylink) OffsetAndFetchSize ¶ added in v1.4.3
OffsetAndFetchSize returns the offset and fetch size of a file that sits within a skylink sector. All skylinks point to one sector of data. If the file is large enough that more data is necessary, a "fanout" is used to point to more sectors.
NOTE: To fully understand the bitfield of the v1 Skylink, it is recommended that the following documentation is read alongside the code.
Sectors are 4 MiB large. To enable the support of efficiently storing and downloading smaller files, the skylink allows an offset and a fetch size to be specified for a file, which means many files can be stored within a single sector root, and each file can get a unique 46 byte skylink.
Existing content addressing systems use 46 bytes, to maximize compatibility we have also chosen to adhere to a 46 byte link size. 46 bytes of base64 is 34 bytes of raw data, which means there are only 34 bytes to work with for storing extra information such as the version, offset, and fetch size of a file. The tight data constraints resulted in this compact format.
Skylinks are given 2 bits for a version. These bits are always the first 2 bits of the bitfield, which correspond to the values '1' and '2' when the bitfield is interpreted as a uint16. The version must be set to 1 to retrieve an offset and a fetch size.
That leaves 14 bits to determine the actual offset and fetch size for the file. The first 8 of those 14 bits are conditional bits, operating somewhat like varints. There are 8 total "modes" that can be triggered by these 8 bits. The first mode is triggered if the first of the 8 bits is a "0". That mode indicates that the 13 remaining bits should be used to compute the offset and fetch size using mode 1. If the first of the 8 bits is a "1", it means check the next bit. If that next bit is a "0", the second mode is triggered, meaning that the remaining 12 bits should be used to compute the offset and fetch size using mode 2.
Out of the 8 modes total, each mode has 1 fewer bit than the previous mode for computing the offset and fetch size. The first mode has 13 bits total, and the final mode has 6 bits total. The first three of these bits always indicates the fetch size. More on that later.
The modes themselves are fairly simple. The first mode indicates that the file is stored on an offset that is aligned to 4096 (1 << 12) bytes. With that alignment, there are 1024 possible offsets for the file to start at within a 4 MiB sector. That takes 10 bits to represent with perfect precision, and is conveniently the number of remaining bits to determine the offset after the fetch size has been parsed.
The second mode indicates that the file is stored on an offset that is aligned to 8192 (1 << 13) bytes, which means there are 512 possible offsets. Because a bit was consumed to switch modes, only 9 bits are available to indicate what the offset is. But as there are only 512 possible offsets, only 9 bits are needed.
This continues until the final mode, which indicates that the file is stored on an offset that is aligned to 512 kib (1 << 19). This is where it stops, larger offsets are unnecessary. Having 8 consecutive 1's in a v1 Skylink is invalid, which means means there are 64 total unused states (all states where the first 8 of 14 non-version bits are set to '1').
The fetch size is an upper bound that says 'the file is no more than this many bytes', and tells the client to download that many bytes to get the whole file. The actual length of the file is in the metadata that gets downloaded along with the file.
For every mode, there are 8 possible fetch sizes. For the first mode, the first possible fetch size is 4 kib, and each additional possible fetch size is another 4 kib. That means files in the first mode can be placed on any 4096 byte aligned offset within the Merkle root and can be up to 32 kib large.
For the second mode, the fetch sizes also increase by 4 kib at a time, starting where the first mode left off. The smallest fetch size that a file in the second mode can have is 36 kib, and the largest fetch size that a file in the second mode can have is 64 kib.
Each mode after that, the increment of the fetch size doubles. So the third mode starts at a fetch size of 72 kib, and goes up to a fetch size of 128 kib. And the fourth mode starts at a fetch size of 144 kib, and goes up to a fetch size of 256 kib. The eighth and final mode extends up to a fetch size of 4 MiB, which is the full size of the sector.
A full table of fetch sizes is presented here:
4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56, 60, 64, 72, 80, 88, 96, 104, 112, 120, 128, 144, 160, 176, 192, 208, 224, 240, 256, 288, 320, 352, 384, 416, 448, 480, 512, 576, 640, 704, 768, 832, 896, 960, 1024, 1152, 1280, 1408, 1536, 1664, 1792, 1920, 2048, 2304, 2560, 2816, 3072, 3328, 3584, 3840, 4096,
Certain combinations of offset + fetch size are illegal. Specifically, it is illegal to indicate a fetch size that goes beyond the boundary of the file. The first mode has 28 illegal states, and each mode after that has 60 illegal states. Combined with the 64 illegal states that can be created by incorrectly set mode bits, there are 512 illegal states total for v1 of the Sia link.
It's possible that these states will be repurposed in the future, extending the functionality of the v1 skylink. More likely however, a transition to v2 will be made instead.
NOTE: If there is an error, OffsetAndLen will return a signal to download the entire sector. This means that any code which is ignoring the error will still have mostly sane behavior.
func (Skylink) Version ¶ added in v1.4.3
Version will pull the version out of the bitfield and return it. The version is a 2 bit number, meaning there are 4 possible values. The bitwise values cover the range [0, 3], however we want to return a value in the range [1, 4], so we increment the bitwise result.
type SkynetPerformanceStats ¶ added in v1.5.5
type SkynetPerformanceStats struct { // TimeToFirstByte only refers to downloads. TimeToFirstByte HalfLifeDistribution `json:"timetofirstbyte"` // Buckets based on how large a file is. The bucket size represents the // maximum size of a file in that bucket. A file will be placed in the // smallest bucket that it can fit into. Download64KB HalfLifeDistribution `json:"download64kb"` Download1MB HalfLifeDistribution `json:"download1mb"` Download4MB HalfLifeDistribution `json:"download4mb"` DownloadLarge HalfLifeDistribution `json:"downloadlarge"` // NOTE: errored uploads are not counted. Upload4MB HalfLifeDistribution `json:"upload4mb"` UploadLarge HalfLifeDistribution `json:"uploadlarge"` RegistryRead HalfLifeDistribution `json:"registryread"` RegistryWrite HalfLifeDistribution `json:"registrywrite"` }
SkynetPerformanceStats contains a set of performance metrics, bucketed by request size and time window, to give a good picture of how well requests are performing on Skynet.
func NewSkynetPerformanceStats ¶ added in v1.5.5
func NewSkynetPerformanceStats() *SkynetPerformanceStats
NewSkynetPerformanceStats will return a SkynetPerformanceStats object that is ready for use.
func (*SkynetPerformanceStats) Copy ¶ added in v1.5.5
func (sps *SkynetPerformanceStats) Copy() SkynetPerformanceStats
Copy returns a copy of the Skynet performance stats that is safe to pass to other threads and callers.
func (*SkynetPerformanceStats) Update ¶ added in v1.5.5
func (sps *SkynetPerformanceStats) Update()
Update will update all half life distributions.
type SkynetPortal ¶ added in v1.4.8
type SkynetPortal struct { Address NetAddress `json:"address"` // the IP or domain name of the portal. Must be a valid network address Public bool `json:"public"` // indicates whether the portal can be accessed publicly or not }
SkynetPortal contains information identifying a Skynet portal.
type SkynetStats ¶ added in v1.5.5
SkynetStats contains statistical data about skynet
type StorageFolderMetadata ¶ added in v1.0.0
type StorageFolderMetadata struct { Capacity uint64 `json:"capacity"` // bytes CapacityRemaining uint64 `json:"capacityremaining"` // bytes Index uint16 `json:"index"` Path string `json:"path"` // Below are statistics about the filesystem. FailedReads and // FailedWrites are only incremented if the filesystem is returning // errors when operations are being performed. A large number of // FailedWrites can indicate that more space has been allocated on a // drive than is physically available. A high number of failures can // also indicate disk trouble. FailedReads uint64 `json:"failedreads"` FailedWrites uint64 `json:"failedwrites"` SuccessfulReads uint64 `json:"successfulreads"` SuccessfulWrites uint64 `json:"successfulwrites"` // Certain operations on a storage folder can take a long time (Add, // Remove, and Resize). The fields below indicate the progress of any // long running operations that might be under way in the storage // folder. Progress is always reported in bytes. ProgressNumerator uint64 ProgressDenominator uint64 }
StorageFolderMetadata contains metadata about a storage folder that is tracked by the storage folder manager.
type StorageManager ¶ added in v1.0.0
type StorageManager interface { Alerter // AddSector will add a sector to the storage manager. If the sector // already exists, a virtual sector will be added, meaning that the // 'sectorData' will be ignored and no new disk space will be consumed. // The expiry height is used to track what height the sector can be // safely deleted at, though typically the host will manually delete // the sector before the expiry height. The same sector can be added // multiple times at different expiry heights, and the storage manager // is expected to only store the data once. AddSector(sectorRoot crypto.Hash, sectorData []byte) error // HasSector indicates whether the contract manager stores a sector with // a given root or not. HasSector(crypto.Hash) bool // AddSectorBatch is a performance optimization over AddSector when // adding a bunch of virtual sectors. It is necessary because otherwise // potentially thousands or even tens-of-thousands of fsync calls would // need to be made in serial, which would prevent renters from ever // successfully renewing. AddSectorBatch(sectorRoots []crypto.Hash) error // AddStorageFolder adds a storage folder to the manager. The manager // may not check that there is enough space available on-disk to // support as much storage as requested, though the manager should // gracefully handle running out of storage unexpectedly. AddStorageFolder(path string, size uint64) error // The storage manager needs to be able to shut down. Close() error // DeleteSector deletes a sector, meaning that the manager will be // unable to upload that sector and be unable to provide a storage // proof on that sector. DeleteSector is for removing the data // entirely, and will remove instances of the sector appearing at all // heights. The primary purpose of DeleteSector is to comply with legal // requests to remove data. DeleteSector(sectorRoot crypto.Hash) error // ReadSector will read a sector from the storage manager, returning the // bytes that match the input sector root. ReadSector(sectorRoot crypto.Hash) ([]byte, error) // ReadPartialSector will read a sector from the storage manager, // returning the bytes that match the input sector root. ReadPartialSector(sectorRoot crypto.Hash, offset, length uint64) ([]byte, error) // RemoveSector will remove a sector from the storage manager. The // height at which the sector expires should be provided, so that the // auto-expiry information for that sector can be properly updated. RemoveSector(sectorRoot crypto.Hash) error // RemoveSectorBatch is a non-ACID performance optimization to remove a // ton of sectors from the storage manager all at once. This is // necessary when clearing out an entire contract from the host. RemoveSectorBatch(sectorRoots []crypto.Hash) error // RemoveStorageFolder will remove a storage folder from the manager. // All storage on the folder will be moved to other storage folders, // meaning that no data will be lost. If the manager is unable to save // data, an error will be returned and the operation will be stopped. If // the force flag is set to true, errors will be ignored and the remove // operation will be completed, meaning that data will be lost. RemoveStorageFolder(index uint16, force bool) error // ResetStorageFolderHealth will reset the health statistics on a // storage folder. ResetStorageFolderHealth(index uint16) error // ResizeStorageFolder will grow or shrink a storage folder in the // manager. The manager may not check that there is enough space // on-disk to support growing the storage folder, but should gracefully // handle running out of space unexpectedly. When shrinking a storage // folder, any data in the folder that needs to be moved will be placed // into other storage folders, meaning that no data will be lost. If // the manager is unable to migrate the data, an error will be returned // and the operation will be stopped. If the force flag is set to true, // errors will be ignored and the resize operation completed, meaning // that data will be lost. ResizeStorageFolder(index uint16, newSize uint64, force bool) error // StorageFolders will return a list of storage folders tracked by the // manager. StorageFolders() []StorageFolderMetadata }
A StorageManager is responsible for managing storage folders and sectors. Sectors are the base unit of storage that gets moved between renters and hosts, and primarily is stored on the hosts.
type StorageObligation ¶ added in v1.1.2
type StorageObligation struct { ContractCost types.Currency `json:"contractcost"` RevisionNumber uint64 `json:"revisionnumber"` DataSize uint64 `json:"datasize"` LockedCollateral types.Currency `json:"lockedcollateral"` ObligationId types.FileContractID `json:"obligationid"` PotentialAccountFunding types.Currency `json:"potentialaccountfunding"` PotentialDownloadRevenue types.Currency `json:"potentialdownloadrevenue"` PotentialStorageRevenue types.Currency `json:"potentialstoragerevenue"` PotentialUploadRevenue types.Currency `json:"potentialuploadrevenue"` RiskedCollateral types.Currency `json:"riskedcollateral"` SectorRootsCount uint64 `json:"sectorrootscount"` TransactionFeesAdded types.Currency `json:"transactionfeesadded"` TransactionID types.TransactionID `json:"transactionid"` // The negotiation height specifies the block height at which the file // contract was negotiated. The expiration height and the proof deadline // are equal to the window start and window end. Between the expiration height // and the proof deadline, the host must submit the storage proof. ExpirationHeight types.BlockHeight `json:"expirationheight"` NegotiationHeight types.BlockHeight `json:"negotiationheight"` ProofDeadLine types.BlockHeight `json:"proofdeadline"` // Variables indicating whether the critical transactions in a storage // obligation have been confirmed on the blockchain. ObligationStatus string `json:"obligationstatus"` OriginConfirmed bool `json:"originconfirmed"` ProofConfirmed bool `json:"proofconfirmed"` ProofConstructed bool `json:"proofconstructed"` RevisionConfirmed bool `json:"revisionconfirmed"` RevisionConstructed bool `json:"revisionconstructed"` // The outputs that will be created after the expiration of the contract // or a proof has been confirmed on the blockchain. ValidProofOutputs []types.SiacoinOutput `json:"validproofoutputs"` MissedProofOutputs []types.SiacoinOutput `json:"missedproofoutputs"` }
StorageObligation contains information about a storage obligation that the host has accepted.
type Streamer ¶ added in v1.4.0
type Streamer interface { io.ReadSeeker io.Closer }
Streamer is the interface implemented by the Renter's streamer type which allows for streaming files uploaded to the Sia network.
type TestMiner ¶ added in v1.0.0
type TestMiner interface { // AddBlock is an extension of FindBlock - AddBlock will submit the block // after finding it. AddBlock() (types.Block, error) // BlockForWork returns a block that is ready for nonce grinding. All // blocks returned by BlockForWork have a unique Merkle root, meaning that // each can safely start from nonce 0. BlockForWork() (types.Block, types.Target, error) // FindBlock will have the miner make 1 attempt to find a solved block that // builds on the current consensus set. It will give up after a few // seconds, returning the block and a bool indicating whether the block is // solved. FindBlock() (types.Block, error) // SolveBlock will have the miner make 1 attempt to solve the input block, // which amounts to trying a few thousand different nonces. SolveBlock is // primarily used for testing. SolveBlock(types.Block, types.Target) (types.Block, bool) // Needs to have all other miner functions in addition to shortcuts for // mining blocks. Miner }
TestMiner provides direct access to block fetching, solving, and manipulation. The primary use of this interface is integration testing.
type TransactionBuilder ¶ added in v1.0.0
type TransactionBuilder interface { // FundSiacoins will add a siacoin input of exactly 'amount' to the // transaction. A parent transaction may be needed to achieve an input // with the correct value. The siacoin input will not be signed until // 'Sign' is called on the transaction builder. The expectation is that // the transaction will be completed and broadcast within a few hours. // Longer risks double-spends, as the wallet will assume that the // transaction failed. FundSiacoins(amount types.Currency) error // FundSiafunds will add a siafund input of exactly 'amount' to the // transaction. A parent transaction may be needed to achieve an input // with the correct value. The siafund input will not be signed until // 'Sign' is called on the transaction builder. Any siacoins that are // released by spending the siafund outputs will be sent to another // address owned by the wallet. The expectation is that the transaction // will be completed and broadcast within a few hours. Longer risks // double-spends, because the wallet will assume the transaction // failed. FundSiafunds(amount types.Currency) error // AddParents adds a set of parents to the transaction. AddParents([]types.Transaction) // AddMinerFee adds a miner fee to the transaction, returning the index // of the miner fee within the transaction. AddMinerFee(fee types.Currency) uint64 // AddSiacoinInput adds a siacoin input to the transaction, returning // the index of the siacoin input within the transaction. When 'Sign' // gets called, this input will be left unsigned. AddSiacoinInput(types.SiacoinInput) uint64 // AddSiacoinOutput adds a siacoin output to the transaction, returning // the index of the siacoin output within the transaction. AddSiacoinOutput(types.SiacoinOutput) uint64 // ReplaceSiacoinOutput replaces the siacoin output in the transaction at the // given index. ReplaceSiacoinOutput(index uint64, output types.SiacoinOutput) error // AddFileContract adds a file contract to the transaction, returning // the index of the file contract within the transaction. AddFileContract(types.FileContract) uint64 // AddFileContractRevision adds a file contract revision to the // transaction, returning the index of the file contract revision // within the transaction. When 'Sign' gets called, this revision will // be left unsigned. AddFileContractRevision(types.FileContractRevision) uint64 // AddStorageProof adds a storage proof to the transaction, returning // the index of the storage proof within the transaction. AddStorageProof(types.StorageProof) uint64 // AddSiafundInput adds a siafund input to the transaction, returning // the index of the siafund input within the transaction. When 'Sign' // is called, this input will be left unsigned. AddSiafundInput(types.SiafundInput) uint64 // AddSiafundOutput adds a siafund output to the transaction, returning // the index of the siafund output within the transaction. AddSiafundOutput(types.SiafundOutput) uint64 // AddArbitraryData adds arbitrary data to the transaction, returning // the index of the data within the transaction. AddArbitraryData(arb []byte) uint64 // AddTransactionSignature adds a transaction signature to the // transaction, returning the index of the signature within the // transaction. The signature should already be valid, and shouldn't // sign any of the inputs that were added by calling 'FundSiacoins' or // 'FundSiafunds'. AddTransactionSignature(types.TransactionSignature) uint64 // Copy creates a copy of the current transactionBuilder that can be used to // extend the transaction in an alternate way (i.e. create a double spend // transaction). Copy() TransactionBuilder // MarkWalletInputs updates internal TransactionBuilder state by inferring // which inputs belong to this wallet. This allows those inputs to be // signed. Returns true if and only if any inputs belonging to the wallet // are found. MarkWalletInputs() bool // Sign will sign any inputs added by 'FundSiacoins' or 'FundSiafunds' // and return a transaction set that contains all parents prepended to // the transaction. If more fields need to be added, a new transaction // builder will need to be created. // // If the whole transaction flag is set to true, then the whole // transaction flag will be set in the covered fields object. If the // whole transaction flag is set to false, then the covered fields // object will cover all fields that have already been added to the // transaction, but will also leave room for more fields to be added. // // An error will be returned if there are multiple calls to 'Sign', // sometimes even if the first call to Sign has failed. Sign should // only ever be called once, and if the first signing fails, the // transaction should be dropped. Sign(wholeTransaction bool) ([]types.Transaction, error) // Sweep creates a funded txn that sends the inputs of this transactionBuilder // to the specified output if submitted to the blockchain. Sweep(output types.SiacoinOutput) (txn types.Transaction, parents []types.Transaction) // UnconfirmedParents returns any unconfirmed parents the transaction set that // is being built by the transaction builder could have. UnconfirmedParents() ([]types.Transaction, error) // View returns the incomplete transaction along with all of its // parents. View() (txn types.Transaction, parents []types.Transaction) // ViewAdded returns all of the siacoin inputs, siafund inputs, and // parent transactions that have been automatically added by the // builder. Items are returned by index. ViewAdded() (newParents, siacoinInputs, siafundInputs, transactionSignatures []int) // Drop indicates that a transaction is no longer useful and will not be // broadcast, and that all of the outputs can be reclaimed. 'Drop' // should only be used before signatures are added. Drop() }
TransactionBuilder is used to construct custom transactions. A transaction builder is initialized via 'RegisterTransaction' and then can be modified by adding funds or other fields. The transaction is completed by calling 'Sign', which will sign all inputs added via the 'FundSiacoins' or 'FundSiafunds' call. All modifications are additive.
Parents of the transaction are kept in the transaction builder. A parent is any unconfirmed transaction that is required for the child to be valid.
Transaction builders are not thread safe.
type TransactionPool ¶
type TransactionPool interface { Alerter // AcceptTransactionSet accepts a set of potentially interdependent // transactions. AcceptTransactionSet([]types.Transaction) error // Broadcast broadcasts a transaction set to all of the transaction pool's // peers. Broadcast(ts []types.Transaction) // Close is necessary for clean shutdown (e.g. during testing). Close() error // FeeEstimation returns an estimation for how high the transaction fee // needs to be per byte. The minimum recommended targets getting accepted // in ~3 blocks, and the maximum recommended targets getting accepted // immediately. Taking the average has a moderate chance of being accepted // within one block. The minimum has a strong chance of getting accepted // within 10 blocks. FeeEstimation() (minimumRecommended, maximumRecommended types.Currency) // PurgeTransactionPool is a temporary function available to the miner. In // the event that a miner mines an unacceptable block, the transaction pool // will be purged to clear out the transaction pool and get rid of the // illegal transaction. This should never happen, however there are bugs // that make this condition necessary. PurgeTransactionPool() // Transaction returns the transaction and unconfirmed parents // corresponding to the provided transaction id. Transaction(id types.TransactionID) (txn types.Transaction, unconfirmedParents []types.Transaction, exists bool) // Transactions returns the transactions of the transaction pool Transactions() []types.Transaction // TransactionConfirmed returns true if the transaction has been seen on the // blockchain. Note, however, that the block containing the transaction may // later be invalidated by a reorg. TransactionConfirmed(id types.TransactionID) (bool, error) // TransactionList returns a list of all transactions in the transaction // pool. The transactions are provided in an order that can acceptably be // put into a block. TransactionList() []types.Transaction // TransactionPoolSubscribe adds a subscriber to the transaction pool. // Subscribers will receive all consensus set changes as well as // transaction pool changes, and should not subscribe to both. TransactionPoolSubscribe(TransactionPoolSubscriber) // TransactionSet returns the transaction set the provided object // appears in. TransactionSet(crypto.Hash) []types.Transaction // Unsubscribe removes a subscriber from the transaction pool. // This is necessary for clean shutdown of the miner. Unsubscribe(TransactionPoolSubscriber) }
A TransactionPool manages unconfirmed transactions.
type TransactionPoolDiff ¶ added in v1.3.0
type TransactionPoolDiff struct { AppliedTransactions []*UnconfirmedTransactionSet RevertedTransactions []TransactionSetID }
A TransactionPoolDiff indicates the adding or removal of a transaction set to the transaction pool. The transactions in the pool are not persisted, so at startup modules should assume an empty transaction pool.
type TransactionPoolSubscriber ¶ added in v0.3.1
type TransactionPoolSubscriber interface { // ReceiveTransactionPoolUpdate notifies subscribers of a change to the // consensus set and/or unconfirmed set, and includes the consensus change // that would result if all of the transactions made it into a block. ReceiveUpdatedUnconfirmedTransactions(*TransactionPoolDiff) }
A TransactionPoolSubscriber receives updates about the confirmed and unconfirmed set from the transaction pool. Generally, there is no need to subscribe to both the consensus set and the transaction pool.
type TransactionSetID ¶ added in v1.3.0
TransactionSetID is a type-safe wrapper for a crypto.Hash that represents the ID of an entire transaction set.
type UnconfirmedTransactionSet ¶ added in v1.3.0
type UnconfirmedTransactionSet struct { Change *ConsensusChange ID TransactionSetID IDs []types.TransactionID Sizes []uint64 Transactions []types.Transaction }
UnconfirmedTransactionSet defines a new unconfirmed transaction that has been added to the transaction pool. ID is the ID of the set, IDs contains an ID for each transaction, eliminating the need to recompute it (because that's an expensive operation).
type UniqueID ¶ added in v1.4.8
UniqueID is a unique identifier
func (*UniqueID) LoadString ¶ added in v1.4.8
LoadString loads the unique id from the given string. It is the inverse of the `String` method.
func (UniqueID) MarshalJSON ¶ added in v1.4.8
MarshalJSON marshals an id as a hex string.
func (*UniqueID) UnmarshalJSON ¶ added in v1.4.8
UnmarshalJSON decodes the json hex string of the id.
type UnspentOutput ¶ added in v1.3.5
type UnspentOutput struct { ID types.OutputID `json:"id"` FundType types.Specifier `json:"fundtype"` UnlockHash types.UnlockHash `json:"unlockhash"` Value types.Currency `json:"value"` ConfirmationHeight types.BlockHeight `json:"confirmationheight"` IsWatchOnly bool `json:"iswatchonly"` }
A UnspentOutput is a SiacoinOutput or SiafundOutput that the wallet is tracking.
type UploadedBackup ¶ added in v1.4.1
type UploadedBackup struct { Name string UID [16]byte CreationDate types.Timestamp Size uint64 // size of snapshot .sia file UploadProgress float64 }
UploadedBackup contains metadata about an uploaded backup.
type UploadsStatus ¶ added in v1.4.2
type UploadsStatus struct { Paused bool `json:"paused"` PauseEndTime time.Time `json:"pauseendtime"` }
UploadsStatus contains information about the Renter's Uploads
type ValuedTransaction ¶ added in v1.4.0
type ValuedTransaction struct { ProcessedTransaction ConfirmedIncomingValue types.Currency `json:"confirmedincomingvalue"` ConfirmedOutgoingValue types.Currency `json:"confirmedoutgoingvalue"` }
ValuedTransaction is a transaction that has been given incoming and outgoing siacoin value fields.
type Wallet ¶
type Wallet interface { Alerter EncryptionManager KeyManager // AddUnlockConditions adds a set of UnlockConditions to the wallet database. AddUnlockConditions(uc types.UnlockConditions) error // AddWatchAddresses instructs the wallet to begin tracking a set of // addresses, in addition to the addresses it was previously tracking. // If none of the addresses have appeared in the blockchain, the // unused flag may be set to true. Otherwise, the wallet must rescan // the blockchain to search for transactions containing the addresses. AddWatchAddresses(addrs []types.UnlockHash, unused bool) error // Close permits clean shutdown during testing and serving. Close() error // ConfirmedBalance returns the confirmed balance of the wallet, minus // any outgoing transactions. ConfirmedBalance will include unconfirmed // refund transactions. ConfirmedBalance() (siacoinBalance types.Currency, siafundBalance types.Currency, siacoinClaimBalance types.Currency, err error) // UnconfirmedBalance returns the unconfirmed balance of the wallet. // Outgoing funds and incoming funds are reported separately. Refund // outputs are included, meaning that sending a single coin to // someone could result in 'outgoing: 12, incoming: 11'. Siafunds are // not considered in the unconfirmed balance. UnconfirmedBalance() (outgoingSiacoins types.Currency, incomingSiacoins types.Currency, err error) // Height returns the wallet's internal processed consensus height Height() (types.BlockHeight, error) // AddressTransactions returns all of the transactions that are related // to a given address. AddressTransactions(types.UnlockHash) ([]ProcessedTransaction, error) // AddressUnconfirmedHistory returns all of the unconfirmed // transactions related to a given address. AddressUnconfirmedTransactions(types.UnlockHash) ([]ProcessedTransaction, error) // Transaction returns the transaction with the given id. The bool // indicates whether the transaction is in the wallet database. The // wallet only stores transactions that are related to the wallet. Transaction(types.TransactionID) (ProcessedTransaction, bool, error) // Transactions returns all of the transactions that were confirmed at // heights [startHeight, endHeight]. Unconfirmed transactions are not // included. Transactions(startHeight types.BlockHeight, endHeight types.BlockHeight) ([]ProcessedTransaction, error) // UnconfirmedTransactions returns all unconfirmed transactions // relative to the wallet. UnconfirmedTransactions() ([]ProcessedTransaction, error) // RegisterTransaction takes a transaction and its parents and returns // a TransactionBuilder which can be used to expand the transaction. RegisterTransaction(t types.Transaction, parents []types.Transaction) (TransactionBuilder, error) // RemoveWatchAddresses instructs the wallet to stop tracking a set of // addresses and delete their associated transactions. If none of the // addresses have appeared in the blockchain, the unused flag may be // set to true. Otherwise, the wallet must rescan the blockchain to // rebuild its transaction history. RemoveWatchAddresses(addrs []types.UnlockHash, unused bool) error // Rescanning reports whether the wallet is currently rescanning the // blockchain. Rescanning() (bool, error) // Settings returns the Wallet's current settings. Settings() (WalletSettings, error) // SetSettings sets the Wallet's settings. SetSettings(WalletSettings) error // StartTransaction is a convenience method that calls // RegisterTransaction(types.Transaction{}, nil) StartTransaction() (TransactionBuilder, error) // SendSiacoins is a tool for sending siacoins from the wallet to an // address. Sending money usually results in multiple transactions. The // transactions are automatically given to the transaction pool, and are // also returned to the caller. SendSiacoins(amount types.Currency, dest types.UnlockHash) ([]types.Transaction, error) // SendSiacoinsFeeIncluded sends siacoins with fees included. SendSiacoinsFeeIncluded(amount types.Currency, dest types.UnlockHash) ([]types.Transaction, error) // SendSiacoinsMulti sends coins to multiple addresses. SendSiacoinsMulti(outputs []types.SiacoinOutput) ([]types.Transaction, error) // SendSiafunds is a tool for sending siafunds from the wallet to an // address. Sending money usually results in multiple transactions. The // transactions are automatically given to the transaction pool, and // are also returned to the caller. SendSiafunds(amount types.Currency, dest types.UnlockHash) ([]types.Transaction, error) // DustThreshold returns the quantity per byte below which a Currency is // considered to be Dust. DustThreshold() (types.Currency, error) // UnspentOutputs returns the unspent outputs tracked by the wallet. UnspentOutputs() ([]UnspentOutput, error) // UnlockConditions returns the UnlockConditions for the specified // address, if they are known to the wallet. UnlockConditions(addr types.UnlockHash) (types.UnlockConditions, error) // WatchAddresses returns the set of addresses that the wallet is // currently watching. WatchAddresses() ([]types.UnlockHash, error) }
Wallet stores and manages siacoins and siafunds. The wallet file is encrypted using a user-specified password. Common addresses are all derived from a single address seed.
type WalletSettings ¶ added in v1.3.2
type WalletSettings struct {
NoDefrag bool `json:"nodefrag"`
}
WalletSettings control the behavior of the Wallet.
type WalletTransactionID ¶ added in v1.0.0
WalletTransactionID is a unique identifier for a wallet transaction.
func CalculateWalletTransactionID ¶ added in v1.0.0
func CalculateWalletTransactionID(tid types.TransactionID, oid types.OutputID) WalletTransactionID
CalculateWalletTransactionID is a helper function for determining the id of a wallet transaction.
type WithdrawalMessage ¶ added in v1.4.2
type WithdrawalMessage struct { Account AccountID Expiry types.BlockHeight Amount types.Currency Nonce [WithdrawalNonceSize]byte }
WithdrawalMessage contains all details to spend from an ephemeral account
func (*WithdrawalMessage) Validate ¶ added in v1.4.2
func (wm *WithdrawalMessage) Validate(blockHeight, expiry types.BlockHeight, hash crypto.Hash, sig crypto.Signature) error
Validate checks the WithdrawalMessage's expiry and signature. If the signature is invalid, or if the WithdrawlMessage is already expired, or it expires too far into the future, an error is returned.
func (*WithdrawalMessage) ValidateExpiry ¶ added in v1.4.2
func (wm *WithdrawalMessage) ValidateExpiry(blockHeight, expiry types.BlockHeight) error
ValidateExpiry returns an error if the withdrawal message is either already expired or if it expires too far into the future
func (*WithdrawalMessage) ValidateSignature ¶ added in v1.4.2
ValidateSignature returns an error if the provided signature is invalid
type Worker ¶ added in v1.5.5
type Worker interface {
RenewContract(ctx context.Context, fcid types.FileContractID, params ContractParams, txnBuilder TransactionBuilder) (RenterContract, []types.Transaction, error)
}
Worker is a minimal interface for a single worker. It's used to be able to use workers within the contractor.
type WorkerAccountStatus ¶ added in v1.5.0
type WorkerAccountStatus struct { AvailableBalance types.Currency `json:"availablebalance"` NegativeBalance types.Currency `json:"negativebalance"` RecentErr string `json:"recenterr"` RecentErrTime time.Time `json:"recenterrtime"` RecentSuccessTime time.Time `json:"recentsuccesstime"` }
WorkerAccountStatus contains detailed information about the account
type WorkerGenericJobsStatus ¶ added in v1.5.5
type WorkerGenericJobsStatus struct { ConsecutiveFailures uint64 `json:"consecutivefailures"` JobQueueSize uint64 `json:"jobqueuesize"` OnCooldown bool `json:"oncooldown"` OnCooldownUntil time.Time `json:"oncooldownuntil"` RecentErr string `json:"recenterr"` RecentErrTime time.Time `json:"recenterrtime"` }
WorkerGenericJobsStatus contains the common information for worker jobs.
type WorkerHasSectorJobsStatus ¶ added in v1.5.0
type WorkerHasSectorJobsStatus struct { AvgJobTime uint64 `json:"avgjobtime"` // in ms ConsecutiveFailures uint64 `json:"consecutivefailures"` JobQueueSize uint64 `json:"jobqueuesize"` RecentErr string `json:"recenterr"` RecentErrTime time.Time `json:"recenterrtime"` }
WorkerHasSectorJobsStatus contains detailed information about the has sector jobs
type WorkerPool ¶ added in v1.5.5
type WorkerPool interface {
Worker(types.SiaPublicKey) (Worker, error)
}
WorkerPool is an interface that describes a collection of workers. It's used to be able to pass the renter's workers to the contractor.
type WorkerPoolStatus ¶ added in v1.4.8
type WorkerPoolStatus struct { NumWorkers int `json:"numworkers"` TotalDownloadCoolDown int `json:"totaldownloadcooldown"` TotalMaintenanceCoolDown int `json:"totalmaintenancecooldown"` TotalUploadCoolDown int `json:"totaluploadcooldown"` Workers []WorkerStatus `json:"workers"` }
WorkerPoolStatus contains information about the status of the workerPool and the workers
type WorkerPriceTableStatus ¶ added in v1.5.0
type WorkerPriceTableStatus struct { ExpiryTime time.Time `json:"expirytime"` UpdateTime time.Time `json:"updatetime"` Active bool `json:"active"` RecentErr string `json:"recenterr"` RecentErrTime time.Time `json:"recenterrtime"` }
WorkerPriceTableStatus contains detailed information about the price table
type WorkerReadJobsStatus ¶ added in v1.5.0
type WorkerReadJobsStatus struct { AvgJobTime64k uint64 `json:"avgjobtime64k"` // in ms AvgJobTime1m uint64 `json:"avgjobtime1m"` // in ms AvgJobTime4m uint64 `json:"avgjobtime4m"` // in ms ConsecutiveFailures uint64 `json:"consecutivefailures"` JobQueueSize uint64 `json:"jobqueuesize"` RecentErr string `json:"recenterr"` RecentErrTime time.Time `json:"recenterrtime"` }
WorkerReadJobsStatus contains detailed information about the read jobs
type WorkerReadRegistryJobStatus ¶ added in v1.5.5
type WorkerReadRegistryJobStatus struct {
WorkerGenericJobsStatus
}
WorkerReadRegistryJobStatus contains detailed information about the read registry jobs.
type WorkerStatus ¶ added in v1.4.8
type WorkerStatus struct { // Worker contract information ContractID types.FileContractID `json:"contractid"` ContractUtility ContractUtility `json:"contractutility"` HostPubKey types.SiaPublicKey `json:"hostpubkey"` // Download status information DownloadCoolDownError string `json:"downloadcooldownerror"` DownloadCoolDownTime time.Duration `json:"downloadcooldowntime"` DownloadOnCoolDown bool `json:"downloadoncooldown"` DownloadQueueSize int `json:"downloadqueuesize"` DownloadTerminated bool `json:"downloadterminated"` // Upload status information UploadCoolDownError string `json:"uploadcooldownerror"` UploadCoolDownTime time.Duration `json:"uploadcooldowntime"` UploadOnCoolDown bool `json:"uploadoncooldown"` UploadQueueSize int `json:"uploadqueuesize"` UploadTerminated bool `json:"uploadterminated"` // Maintenance Cooldown information MaintenanceOnCooldown bool `json:"maintenanceoncooldown"` MaintenanceCoolDownError string `json:"maintenancecooldownerror"` MaintenanceCoolDownTime time.Duration `json:"maintenancecooldowntime"` // Ephemeral Account information AccountBalanceTarget types.Currency `json:"accountbalancetarget"` AccountStatus WorkerAccountStatus `json:"accountstatus"` // PriceTable information PriceTableStatus WorkerPriceTableStatus `json:"pricetablestatus"` // Job Queues DownloadSnapshotJobQueueSize int `json:"downloadsnapshotjobqueuesize"` UploadSnapshotJobQueueSize int `json:"uploadsnapshotjobqueuesize"` // Read Jobs Information ReadJobsStatus WorkerReadJobsStatus `json:"readjobsstatus"` // HasSector Job Information HasSectorJobsStatus WorkerHasSectorJobsStatus `json:"hassectorjobsstatus"` // ReadRegistry Job Information ReadRegistryJobsStatus WorkerReadRegistryJobStatus `json:"readregistryjobsstatus"` // UpdateRegistry Job information UpdateRegistryJobsStatus WorkerUpdateRegistryJobStatus `json:"updateregistryjobsstatus"` }
WorkerStatus contains information about the status of a worker
type WorkerUpdateRegistryJobStatus ¶ added in v1.5.5
type WorkerUpdateRegistryJobStatus struct {
WorkerGenericJobsStatus
}
WorkerUpdateRegistryJobStatus contains detailed information about the update registry jobs.
Source Files ¶
- alert.go
- consensus.go
- consts.go
- dependencies.go
- erasure.go
- explorer.go
- feemanager.go
- gateway.go
- host.go
- mdm.go
- mdmprogrambuilder.go
- miner.go
- modules.go
- negotiate.go
- netaddress.go
- packing.go
- payment.go
- registry.go
- renew.go
- renter.go
- rpc.go
- seeds.go
- siadconfig.go
- siamux.go
- siapath.go
- skyfilereader.go
- skylink.go
- skynet.go
- skynetbackup.go
- skynethelpers.go
- skynetperf.go
- storagemanager.go
- transactionpool.go
- wallet.go
Directories ¶
Path | Synopsis |
---|---|
Package explorer provides a glimpse into what the Sia network currently looks like.
|
Package explorer provides a glimpse into what the Sia network currently looks like. |
Package gateway connects a Sia node to the Sia flood network.
|
Package gateway connects a Sia node to the Sia flood network. |
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.
|
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. |
Package miner is responsible for creating and submitting siacoin blocks
|
Package miner is responsible for creating and submitting siacoin blocks |
Package renter is responsible for uploading and downloading files on the sia network.
|
Package renter is responsible for uploading and downloading files on the sia network. |
hostdb
Package hostdb provides a HostDB object that implements the renter.hostDB interface.
|
Package hostdb provides a HostDB object that implements the renter.hostDB interface. |