pin.go 1.41 KB
Newer Older
1 2 3 4 5
package iface

import (
	"context"

Łukasz Magiera's avatar
Łukasz Magiera committed
6
	options "github.com/ipfs/interface-go-ipfs-core/options"
7 8 9 10 11
)

// Pin holds information about pinned resource
type Pin interface {
	// Path to the pinned object
12
	Path() ResolvedPath
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29

	// Type of the pin
	Type() string
}

// PinStatus holds information about pin health
type PinStatus interface {
	// Ok indicates whether the pin has been verified to be correct
	Ok() bool

	// BadNodes returns any bad (usually missing) nodes from the pin
	BadNodes() []BadPinNode
}

// BadPinNode is a node that has been marked as bad by Pin.Verify
type BadPinNode interface {
	// Path is the path of the node
30
	Path() ResolvedPath
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45

	// Err is the reason why the node has been marked as bad
	Err() error
}

// PinAPI specifies the interface to pining
type PinAPI interface {
	// Add creates new pin, be default recursive - pinning the whole referenced
	// tree
	Add(context.Context, Path, ...options.PinAddOption) error

	// Ls returns list of pinned objects on this node
	Ls(context.Context, ...options.PinLsOption) ([]Pin, error)

	// Rm removes pin for object specified by the path
Overbool's avatar
Overbool committed
46
	Rm(context.Context, Path, ...options.PinRmOption) error
47 48 49 50 51 52 53 54

	// Update changes one pin to another, skipping checks for matching paths in
	// the old tree
	Update(ctx context.Context, from Path, to Path, opts ...options.PinUpdateOption) error

	// Verify verifies the integrity of pinned objects
	Verify(context.Context) (<-chan PinStatus, error)
}