Documentation ¶
Index ¶
- type Allocator
- type AsyncLoader
- func (al *AsyncLoader) AsyncLoad(p peer.ID, requestID graphsync.RequestID, link ipld.Link) <-chan types.AsyncLoadResult
- func (al *AsyncLoader) CleanupRequest(requestID graphsync.RequestID)
- func (al *AsyncLoader) CompleteResponsesFor(requestID graphsync.RequestID)
- func (al *AsyncLoader) ProcessResponse(p peer.ID, responses map[graphsync.RequestID]metadata.Metadata, ...)
- func (al *AsyncLoader) RegisterPersistenceOption(name string, loader ipld.Loader, storer ipld.Storer) error
- func (al *AsyncLoader) Shutdown()
- func (al *AsyncLoader) StartRequest(requestID graphsync.RequestID, persistenceOption string) error
- func (al *AsyncLoader) Startup()
- func (al *AsyncLoader) UnregisterPersistenceOption(name string) error
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Allocator ¶ added in v0.6.9
type Allocator interface { AllocateBlockMemory(p peer.ID, amount uint64) <-chan error ReleaseBlockMemory(p peer.ID, amount uint64) error }
Allocator indicates a mechanism for tracking memory used by a given peer
type AsyncLoader ¶
type AsyncLoader struct {
// contains filtered or unexported fields
}
AsyncLoader manages loading links asynchronously in as new responses come in from the network
func New ¶
func New(ctx context.Context, loader ipld.Loader, storer ipld.Storer, allocator Allocator) *AsyncLoader
New initializes a new link loading manager for asynchronous loads from the given context and local store loading and storing function
func (*AsyncLoader) AsyncLoad ¶
func (al *AsyncLoader) AsyncLoad(p peer.ID, requestID graphsync.RequestID, link ipld.Link) <-chan types.AsyncLoadResult
AsyncLoad asynchronously loads the given link for the given request ID. It returns a channel for data and a channel for errors -- only one message will be sent over either.
func (*AsyncLoader) CleanupRequest ¶
func (al *AsyncLoader) CleanupRequest(requestID graphsync.RequestID)
CleanupRequest indicates the given request is complete on the client side, and no further attempts will be made to load links for this request, so any cached response data is invalid can be cleaned
func (*AsyncLoader) CompleteResponsesFor ¶
func (al *AsyncLoader) CompleteResponsesFor(requestID graphsync.RequestID)
CompleteResponsesFor indicates no further responses will come in for the given requestID, so if no responses are in the cache or local store, a link load should not retry
func (*AsyncLoader) ProcessResponse ¶
func (al *AsyncLoader) ProcessResponse(p peer.ID, responses map[graphsync.RequestID]metadata.Metadata, blks []blocks.Block)
ProcessResponse injests new responses and completes asynchronous loads as neccesary
func (*AsyncLoader) RegisterPersistenceOption ¶ added in v0.1.0
func (al *AsyncLoader) RegisterPersistenceOption(name string, loader ipld.Loader, storer ipld.Storer) error
RegisterPersistenceOption registers a new loader/storer option for processing requests
func (*AsyncLoader) Shutdown ¶
func (al *AsyncLoader) Shutdown()
Shutdown finishes processing of messages
func (*AsyncLoader) StartRequest ¶
func (al *AsyncLoader) StartRequest(requestID graphsync.RequestID, persistenceOption string) error
StartRequest indicates the given request has started and the manager should continually attempt to load links for this request as new responses come in
func (*AsyncLoader) Startup ¶
func (al *AsyncLoader) Startup()
Startup starts processing of messages
func (*AsyncLoader) UnregisterPersistenceOption ¶ added in v0.1.0
func (al *AsyncLoader) UnregisterPersistenceOption(name string) error
UnregisterPersistenceOption unregisters an existing loader/storer option for processing requests