Documentation ¶
Overview ¶
package blockservice implements a BlockService interface that provides a single GetBlock/AddBlock interface that seamlessly retrieves data either locally or from a remote peer through the exchange.
Index ¶
- type BlockGetterdeprecated
- type BlockServicedeprecated
- type Sessiondeprecated
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BlockGetter
deprecated
type BlockGetter interface { // GetBlock gets the requested block. GetBlock(ctx context.Context, c cid.Cid) (blocks.Block, error) // GetBlocks does a batch request for the given cids, returning blocks as // they are found, in no particular order. // // It may not be able to find all requested blocks (or the context may // be canceled). In that case, it will close the channel early. It is up // to the consumer to detect this situation and keep track which blocks // it has received and which it hasn't. GetBlocks(ctx context.Context, ks []cid.Cid) <-chan blocks.Block }
BlockGetter is the common interface shared between blockservice sessions and the blockservice.
Deprecated: use github.com/ipfs/boxo/blockservice.BlockGetter
type BlockService
deprecated
type BlockService interface { io.Closer BlockGetter // Blockstore returns a reference to the underlying blockstore Blockstore() blockstore.Blockstore // Exchange returns a reference to the underlying exchange (usually bitswap) Exchange() exchange.Interface // AddBlock puts a given block to the underlying datastore AddBlock(ctx context.Context, o blocks.Block) error // AddBlocks adds a slice of blocks at the same time using batching // capabilities of the underlying datastore whenever possible. AddBlocks(ctx context.Context, bs []blocks.Block) error // DeleteBlock deletes the given block from the blockservice. DeleteBlock(ctx context.Context, o cid.Cid) error }
BlockService is a hybrid block datastore. It stores data in a local datastore and may retrieve data from a remote Exchange. It uses an internal `datastore.Datastore` instance to store values.
Deprecated: use github.com/ipfs/boxo/blockservice.BlockService
func New
deprecated
func New(bs blockstore.Blockstore, rem exchange.Interface) BlockService
NewBlockService creates a BlockService with given datastore instance.
Deprecated: use github.com/ipfs/boxo/blockservice.New
func NewWriteThrough
deprecated
func NewWriteThrough(bs blockstore.Blockstore, rem exchange.Interface) BlockService
NewWriteThrough creates a BlockService that guarantees writes will go through to the blockstore and are not skipped by cache checks.
Deprecated: use github.com/ipfs/boxo/blockservice.NewWriteThrough
type Session
deprecated
type Session struct {
// contains filtered or unexported fields
}
Session is a helper type to provide higher level access to bitswap sessions
Deprecated: use github.com/ipfs/boxo/blockservice.Session
func NewSession
deprecated
func NewSession(ctx context.Context, bs BlockService) *Session
NewSession creates a new session that allows for controlled exchange of wantlists to decrease the bandwidth overhead. If the current exchange is a SessionExchange, a new exchange session will be created. Otherwise, the current exchange will be used directly.
Deprecated: use github.com/ipfs/boxo/blockservice.NewSession