Documentation ¶
Overview ¶
Package renterutil provides convenience functions for common renter actions.
Index ¶
- Variables
- type HostError
- type HostErrorSet
- type HostSet
- type Migrator
- type PseudoFS
- func (fs *PseudoFS) Chmod(name string, mode os.FileMode) error
- func (fs *PseudoFS) Close() error
- func (fs *PseudoFS) Create(name string, minShards int) (*PseudoFile, error)
- func (fs *PseudoFS) GC() error
- func (fs *PseudoFS) Mkdir(name string, perm os.FileMode) error
- func (fs *PseudoFS) MkdirAll(path string, perm os.FileMode) error
- func (fs *PseudoFS) Open(name string) (*PseudoFile, error)
- func (fs *PseudoFS) OpenFile(name string, flag int, perm os.FileMode, minShards int) (*PseudoFile, error)
- func (fs *PseudoFS) Remove(name string) error
- func (fs *PseudoFS) RemoveAll(path string) error
- func (fs *PseudoFS) Rename(oldname, newname string) error
- func (fs *PseudoFS) Stat(name string) (os.FileInfo, error)
- type PseudoFile
- func (pf PseudoFile) Close() error
- func (pf PseudoFile) Free() error
- func (pf PseudoFile) Name() string
- func (pf PseudoFile) Read(p []byte) (int, error)
- func (pf PseudoFile) ReadAt(p []byte, off int64) (int, error)
- func (pf PseudoFile) ReadAtP(p []byte, off int64) (int, error)
- func (pf PseudoFile) Readdir(n int) ([]os.FileInfo, error)
- func (pf PseudoFile) Readdirnames(n int) ([]string, error)
- func (pf PseudoFile) Seek(offset int64, whence int) (int64, error)
- func (pf PseudoFile) Stat() (os.FileInfo, error)
- func (pf PseudoFile) Sync() error
- func (pf PseudoFile) Truncate(size int64) error
- func (pf PseudoFile) Write(p []byte) (int, error)
- func (pf PseudoFile) WriteAt(p []byte, off int64) (int, error)
- type SiadClient
- func (c *SiadClient) AcceptTransactionSet(txnSet []types.Transaction) error
- func (c *SiadClient) ChainHeight() (types.BlockHeight, error)
- func (c *SiadClient) FeeEstimate() (minFee, maxFee types.Currency, err error)
- func (c *SiadClient) LookupHost(prefix string) (hostdb.HostPublicKey, error)
- func (c *SiadClient) NewWalletAddress() (types.UnlockHash, error)
- func (c *SiadClient) ResolveHostKey(pubkey hostdb.HostPublicKey) (modules.NetAddress, error)
- func (c *SiadClient) SignTransaction(txn *types.Transaction, toSign []crypto.Hash) error
- func (c *SiadClient) Synced() (bool, error)
- func (c *SiadClient) UnconfirmedParents(txn types.Transaction) ([]types.Transaction, error)
- func (c *SiadClient) UnlockConditions(addr types.UnlockHash) (types.UnlockConditions, error)
- func (c *SiadClient) UnspentOutputs(limbo bool) ([]modules.UnspentOutput, error)
Constants ¶
This section is empty.
Variables ¶
var ErrAppendOnly = errors.New("file is append-only")
ErrAppendOnly is returned for seek operations on append-only files.
var ErrDirectory = errors.New("file is a directory")
ErrDirectory is returned for operations that are not valid for directories.
var ErrInvalidFileDescriptor = errors.New("invalid file descriptor")
ErrInvalidFileDescriptor is returned when I/O is attempted on an unknown file descriptor.
var ErrNoHostAnnouncement = errors.New("host announcement not found")
ErrNoHostAnnouncement is returned when a host announcement cannot be found.
var ErrNotDirectory = errors.New("file is not a directory")
ErrNotDirectory is returned for operations that are not valid for files.
var ErrNotReadable = errors.New("file is not readable")
ErrNotReadable is returned for read operations on write-only files.
var ErrNotWriteable = errors.New("file is not writeable")
ErrNotWriteable is returned for write operations on read-only files.
Functions ¶
This section is empty.
Types ¶
type HostError ¶ added in v0.11.0
type HostError struct { HostKey hostdb.HostPublicKey Err error }
A HostError associates an error with a given host.
type HostErrorSet ¶ added in v0.11.0
type HostErrorSet []*HostError
A HostErrorSet is a collection of errors from various hosts.
func (HostErrorSet) Error ¶ added in v0.11.0
func (hes HostErrorSet) Error() string
Error implements error.
type HostSet ¶ added in v0.2.0
type HostSet struct {
// contains filtered or unexported fields
}
A HostSet is a collection of renter-host protocol sessions.
func NewHostSet ¶ added in v0.2.0
func NewHostSet(hkr renter.HostKeyResolver, currentHeight types.BlockHeight) *HostSet
NewHostSet creates an empty HostSet using the provided resolver and current height.
func (*HostSet) HasHost ¶ added in v0.11.0
func (set *HostSet) HasHost(hostKey hostdb.HostPublicKey) bool
HasHost returns true if the specified host is in the set.
func (*HostSet) SetLockTimeout ¶ added in v0.16.2
SetLockTimeout sets the timeout used for all Lock RPCs in Sessions initiated by the HostSet.
func (*HostSet) SetRPCStatsRecorder ¶ added in v0.16.1
func (set *HostSet) SetRPCStatsRecorder(r proto.RPCStatsRecorder)
SetRPCStatsRecorder sets the RPCStatsRecorder for all Sessions initiated by the HostSet.
type Migrator ¶ added in v0.11.0
type Migrator struct {
// contains filtered or unexported fields
}
A Migrator facilitates migrating metafiles from one set of hosts to another.
func NewMigrator ¶ added in v0.11.0
NewMigrator creates a Migrator that migrates files to the specified host set.
func (*Migrator) AddFile ¶ added in v0.11.0
func (m *Migrator) AddFile(f *renter.MetaFile, source io.Reader, onFinish func(*renter.MetaFile) error) error
AddFile uses data read from source to migrate f to the Migrator's new host set. Since the Migrator buffers data internally, the migration may not be complete until the Flush method has been called. onFinish is called on the new metafile when the file has been fully migrated.
type PseudoFS ¶ added in v0.2.0
type PseudoFS struct {
// contains filtered or unexported fields
}
PseudoFS implements a filesystem by uploading and downloading data from Sia hosts.
func NewFileSystem ¶ added in v0.2.0
NewFileSystem returns a new pseudo-filesystem rooted at root, which must be a directory containing only metafiles and other directories.
func (*PseudoFS) Close ¶ added in v0.2.0
Close closes the filesystem by flushing any uncommitted writes, closing any open files, and terminating all active host sessions.
func (*PseudoFS) Create ¶ added in v0.2.0
func (fs *PseudoFS) Create(name string, minShards int) (*PseudoFile, error)
Create creates the named file with the specified redundancy and mode 0666 (before umask), truncating it if it already exists. The returned file has mode O_RDWR.
func (*PseudoFS) GC ¶ added in v0.13.0
GC deletes unused data from the filesystem's host set. Any data not referenced by the files within the filesystem will be deleted. This has important implications for shared files: if you share a metafile and do not retain a local copy of it, then running GC will cause that file's data to be deleted, making it inaccessible.
GC complements the (PseudoFile).Free method. Free cannot safely delete non-full sectors, because those sectors may be referenced by other files, e.g. when multiple files are packed into a single sector. GC is guaranteed to delete all unreferenced sectors, but is much slower than Free because it must examine the full filesystem. Free should be called frequently as a "first line of defense," while GC should be called infrequently to remove any sectors missed by Free.
func (*PseudoFS) Mkdir ¶ added in v0.2.0
Mkdir creates a new directory with the specified name and permission bits (before umask).
func (*PseudoFS) MkdirAll ¶ added in v0.2.0
MkdirAll creates a directory named path, along with any necessary parents, and returns nil, or else returns an error. The permission bits perm (before umask) are used for all directories that MkdirAll creates. If path is already a directory, MkdirAll does nothing and returns nil.
func (*PseudoFS) Open ¶ added in v0.2.0
func (fs *PseudoFS) Open(name string) (*PseudoFile, error)
Open opens the named file for reading. The returned file is read-only.
func (*PseudoFS) OpenFile ¶ added in v0.2.0
func (fs *PseudoFS) OpenFile(name string, flag int, perm os.FileMode, minShards int) (*PseudoFile, error)
OpenFile is the generalized open call; most users will use Open or Create instead. It opens the named file with specified flag (os.O_RDONLY etc.) and perm (before umask), if applicable.
func (*PseudoFS) Remove ¶ added in v0.2.0
Remove removes the named file or (empty) directory. It does NOT delete the file data on the host; use (PseudoFS).GC and (PseudoFile).Free for that.
func (*PseudoFS) RemoveAll ¶ added in v0.2.0
RemoveAll removes path and any children it contains. It removes everything it can but returns the first error it encounters. If the path does not exist, RemoveAll returns nil (no error).
type PseudoFile ¶ added in v0.2.0
type PseudoFile struct {
// contains filtered or unexported fields
}
A PseudoFile presents a file-like interface for a metafile stored on Sia hosts.
func (PseudoFile) Close ¶ added in v0.2.0
func (pf PseudoFile) Close() error
Close implements io.Closer.
func (PseudoFile) Free ¶ added in v0.13.0
func (pf PseudoFile) Free() error
Free truncates the file to 0 bytes and deletes file data from the filesystem's host set. Free only deletes sectors that it can prove are exclusively storing the file's data. If multiple files were packed into the same sector, Free will not delete that sector. Similarly, Free cannot safely delete "trailing" sectors at the end of a file. Use (PseudoFS).GC to delete such sectors after calling Remove on all the relevant files.
Note that Free also discards any uncommitted Writes, so it may be necessary to call Sync prior to Free.
func (PseudoFile) Name ¶ added in v0.2.0
func (pf PseudoFile) Name() string
Name returns the file's name, as passed to OpenFile.
func (PseudoFile) Read ¶ added in v0.2.0
func (pf PseudoFile) Read(p []byte) (int, error)
Read implements io.Reader.
func (PseudoFile) ReadAt ¶ added in v0.2.0
func (pf PseudoFile) ReadAt(p []byte, off int64) (int, error)
ReadAt implements io.ReaderAt.
func (PseudoFile) ReadAtP ¶ added in v0.13.0
func (pf PseudoFile) ReadAtP(p []byte, off int64) (int, error)
ReadAtP is a helper method that makes multiple concurrent ReadAt calls, with each call filling part of p. This may increase throughput depending on the file's redundancy. For example, if the file is stored at 2x redundancy, then in ideal circumstances, ReadAtP will be 2x faster than the equivalent ReadAt call.
ReadAtP returns the first non-nil error returned by a ReadAt call. The contents of p are undefined if an error other than io.EOF is returned.
func (PseudoFile) Readdir ¶ added in v0.2.0
func (pf PseudoFile) Readdir(n int) ([]os.FileInfo, error)
Readdir reads the contents of the directory associated with pf and returns a slice of up to n FileInfo values, as would be returned by Lstat, in directory order. Subsequent calls on the same file will yield further FileInfos.
If n > 0, Readdir returns at most n FileInfo structures. In this case, if Readdir returns an empty slice, it will return a non-nil error explaining why. At the end of a directory, the error is io.EOF.
If n <= 0, Readdir returns all the FileInfo from the directory in a single slice. In this case, if Readdir succeeds (reads all the way to the end of the directory), it returns the slice and a nil error. If it encounters an error before the end of the directory, Readdir returns the FileInfo read until that point and a non-nil error.
func (PseudoFile) Readdirnames ¶ added in v0.2.0
func (pf PseudoFile) Readdirnames(n int) ([]string, error)
Readdirnames reads and returns a slice of names from the directory pf.
If n > 0, Readdirnames returns at most n names. In this case, if Readdirnames returns an empty slice, it will return a non-nil error explaining why. At the end of a directory, the error is io.EOF.
If n <= 0, Readdirnames returns all the names from the directory in a single slice. In this case, if Readdirnames succeeds (reads all the way to the end of the directory), it returns the slice and a nil error. If it encounters an error before the end of the directory, Readdirnames returns the names read until that point and a non-nil error.
func (PseudoFile) Seek ¶ added in v0.2.0
func (pf PseudoFile) Seek(offset int64, whence int) (int64, error)
Seek implements io.Seeker.
func (PseudoFile) Stat ¶ added in v0.2.0
func (pf PseudoFile) Stat() (os.FileInfo, error)
Stat returns the FileInfo structure describing the file. If the file is a metafile, its renter.MetaIndex will be available via the Sys method.
func (PseudoFile) Sync ¶ added in v0.2.0
func (pf PseudoFile) Sync() error
Sync commits the current contents of the file to stable storage. Any new data will be uploaded to hosts, and the metafile will be atomically updated to match the current state of the file. Calling Sync on one file may cause other files to be synced as well. Sync typically results in a full sector of data being uploaded to each host.
func (PseudoFile) Truncate ¶ added in v0.2.0
func (pf PseudoFile) Truncate(size int64) error
Truncate changes the size of the file. It does not change the I/O offset. The new size must not exceed the current size.
type SiadClient ¶ added in v0.2.0
type SiadClient struct {
// contains filtered or unexported fields
}
SiadClient wraps the siad API client. It satisfies the proto.Wallet, proto.TransactionPool, and renter.HostKeyResolver interfaces. The proto.Wallet methods require that the wallet is unlocked.
func NewSiadClient ¶ added in v0.2.0
func NewSiadClient(addr, password string) *SiadClient
NewSiadClient returns a SiadClient that communicates with the siad API server at the specified address.
func (*SiadClient) AcceptTransactionSet ¶ added in v0.2.0
func (c *SiadClient) AcceptTransactionSet(txnSet []types.Transaction) error
AcceptTransactionSet submits a transaction set to the transaction pool, where it will be broadcast to other peers.
func (*SiadClient) ChainHeight ¶ added in v0.2.0
func (c *SiadClient) ChainHeight() (types.BlockHeight, error)
ChainHeight returns the current block height.
func (*SiadClient) FeeEstimate ¶ added in v0.2.0
func (c *SiadClient) FeeEstimate() (minFee, maxFee types.Currency, err error)
FeeEstimate returns the current estimate for transaction fees, in Hastings per byte.
func (*SiadClient) LookupHost ¶ added in v0.2.0
func (c *SiadClient) LookupHost(prefix string) (hostdb.HostPublicKey, error)
LookupHost returns the host public key matching the specified prefix.
func (*SiadClient) NewWalletAddress ¶ added in v0.2.0
func (c *SiadClient) NewWalletAddress() (types.UnlockHash, error)
NewWalletAddress returns a new address generated by the wallet.
func (*SiadClient) ResolveHostKey ¶ added in v0.2.0
func (c *SiadClient) ResolveHostKey(pubkey hostdb.HostPublicKey) (modules.NetAddress, error)
ResolveHostKey resolves a host public key to that host's most recently announced network address.
func (*SiadClient) SignTransaction ¶ added in v0.2.0
func (c *SiadClient) SignTransaction(txn *types.Transaction, toSign []crypto.Hash) error
SignTransaction adds the specified signatures to the transaction using private keys known to the wallet.
func (*SiadClient) Synced ¶ added in v0.2.0
func (c *SiadClient) Synced() (bool, error)
Synced returns whether the siad node believes it is fully synchronized with the rest of the network.
func (*SiadClient) UnconfirmedParents ¶ added in v0.3.0
func (c *SiadClient) UnconfirmedParents(txn types.Transaction) ([]types.Transaction, error)
UnconfirmedParents returns any currently-unconfirmed parents of the specified transaction.
func (*SiadClient) UnlockConditions ¶ added in v0.2.0
func (c *SiadClient) UnlockConditions(addr types.UnlockHash) (types.UnlockConditions, error)
UnlockConditions returns the UnlockConditions that correspond to the specified address.
func (*SiadClient) UnspentOutputs ¶ added in v0.2.0
func (c *SiadClient) UnspentOutputs(limbo bool) ([]modules.UnspentOutput, error)
UnspentOutputs returns the set of outputs tracked by the wallet that are spendable.