Documentation ¶
Overview ¶
Package maptracker implements a PinTracker component for IPFS Cluster. It uses a map to keep track of the state of tracked pins.
Index ¶
- Constants
- type Config
- type MapPinTracker
- func (mpt *MapPinTracker) Recover(c *cid.Cid) (api.PinInfo, error)
- func (mpt *MapPinTracker) RecoverAll() ([]api.PinInfo, error)
- func (mpt *MapPinTracker) SetClient(c *rpc.Client)
- func (mpt *MapPinTracker) Shutdown() error
- func (mpt *MapPinTracker) Status(c *cid.Cid) api.PinInfo
- func (mpt *MapPinTracker) StatusAll() []api.PinInfo
- func (mpt *MapPinTracker) Sync(c *cid.Cid) (api.PinInfo, error)
- func (mpt *MapPinTracker) SyncAll() ([]api.PinInfo, error)
- func (mpt *MapPinTracker) Track(c api.Pin) error
- func (mpt *MapPinTracker) Untrack(c *cid.Cid) error
Constants ¶
const ( DefaultPinningTimeout = 60 * time.Minute DefaultUnpinningTimeout = 5 * time.Minute DefaultMaxPinQueueSize = 4096 )
Default values for this Config.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Config ¶ added in v0.3.1
type Config struct { config.Saver // PinningTimeout specifies how long to wait before a pinning state becomes a pin error PinningTimeout time.Duration // UnpinningTimeout specifies how long to wait before an unpinning state becomes a pin error UnpinningTimeout time.Duration // MaxPinQueueSize specifies how many pin or unpin requests we can hold in the queue // If higher, they will automatically marked with an error. MaxPinQueueSize int }
Config allows to initialize a Monitor and customize some parameters.
func (*Config) ConfigKey ¶ added in v0.3.1
ConfigKey provides a human-friendly identifier for this type of Config.
func (*Config) LoadJSON ¶ added in v0.3.1
LoadJSON sets the fields of this Config to the values defined by the JSON representation of it, as generated by ToJSON.
type MapPinTracker ¶
type MapPinTracker struct {
// contains filtered or unexported fields
}
MapPinTracker is a PinTracker implementation which uses a Go map to store the status of the tracked Cids. This component is thread-safe.
func NewMapPinTracker ¶
func NewMapPinTracker(cfg *Config, pid peer.ID) *MapPinTracker
NewMapPinTracker returns a new object which has been correcly initialized with the given configuration.
func (*MapPinTracker) Recover ¶
Recover will re-track or re-untrack a Cid in error state, possibly retriggering an IPFS pinning operation and returning only when it is done. The pinning/unpinning operation happens synchronously, jumping the queues.
func (*MapPinTracker) RecoverAll ¶ added in v0.3.1
func (mpt *MapPinTracker) RecoverAll() ([]api.PinInfo, error)
RecoverAll attempts to recover all items tracked by this peer.
func (*MapPinTracker) SetClient ¶
func (mpt *MapPinTracker) SetClient(c *rpc.Client)
SetClient makes the MapPinTracker ready to perform RPC requests to other components.
func (*MapPinTracker) Shutdown ¶
func (mpt *MapPinTracker) Shutdown() error
Shutdown finishes the services provided by the MapPinTracker and cancels any active context.
func (*MapPinTracker) Status ¶
func (mpt *MapPinTracker) Status(c *cid.Cid) api.PinInfo
Status returns information for a Cid tracked by this MapPinTracker.
func (*MapPinTracker) StatusAll ¶
func (mpt *MapPinTracker) StatusAll() []api.PinInfo
StatusAll returns information for all Cids tracked by this MapPinTracker.
func (*MapPinTracker) Sync ¶
Sync verifies that the status of a Cid matches that of the IPFS daemon. If not, it will be transitioned to PinError or UnpinError.
Sync returns the updated local status for the given Cid. Pins in error states can be recovered with Recover(). An error is returned if we are unable to contact the IPFS daemon.
func (*MapPinTracker) SyncAll ¶
func (mpt *MapPinTracker) SyncAll() ([]api.PinInfo, error)
SyncAll verifies that the statuses of all tracked Cids match the one reported by the IPFS daemon. If not, they will be transitioned to PinError or UnpinError.
SyncAll returns the list of local status for all tracked Cids which were updated or have errors. Cids in error states can be recovered with Recover(). An error is returned if we are unable to contact the IPFS daemon.