Documentation ¶
Index ¶
- type BlockSentListeners
- type CancelledListeners
- type CompletedListeners
- type NetworkErrorListeners
- type RequestCloser
- type RequestHooks
- type RequestQueuedHooks
- type ResponseAssembler
- type ResponseManager
- func (rm *ResponseManager) CancelResponse(ctx context.Context, requestID graphsync.RequestID) error
- func (rm *ResponseManager) CloseWithNetworkError(requestID graphsync.RequestID)
- func (rm *ResponseManager) FinishTask(task *peertask.Task, p peer.ID, err error)
- func (rm *ResponseManager) GetUpdates(requestID graphsync.RequestID, updatesChan chan<- []gsmsg.GraphSyncRequest)
- func (rm *ResponseManager) PauseResponse(ctx context.Context, requestID graphsync.RequestID) error
- func (rm *ResponseManager) PeerState(p peer.ID) peerstate.PeerState
- func (rm *ResponseManager) ProcessRequests(ctx context.Context, p peer.ID, requests []gsmsg.GraphSyncRequest)
- func (rm *ResponseManager) Shutdown()
- func (rm *ResponseManager) StartTask(task *peertask.Task, p peer.ID, ...)
- func (rm *ResponseManager) Startup()
- func (rm *ResponseManager) TerminateRequest(requestID graphsync.RequestID)
- func (rm *ResponseManager) UnpauseResponse(ctx context.Context, requestID graphsync.RequestID, ...) error
- func (rm *ResponseManager) UpdateResponse(ctx context.Context, requestID graphsync.RequestID, ...) error
- type UpdateHooks
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BlockSentListeners ¶ added in v0.3.0
type BlockSentListeners interface {
NotifyBlockSentListeners(p peer.ID, request graphsync.RequestData, block graphsync.BlockData)
}
BlockSentListeners is an interface for notifying listeners that of a block send occuring over the wire
type CancelledListeners ¶ added in v0.1.0
type CancelledListeners interface {
NotifyCancelledListeners(p peer.ID, request graphsync.RequestData)
}
CancelledListeners is an interface for notifying listeners that requestor cancelled
type CompletedListeners ¶ added in v0.1.0
type CompletedListeners interface {
NotifyCompletedListeners(p peer.ID, request graphsync.RequestData, status graphsync.ResponseStatusCode)
}
CompletedListeners is an interface for notifying listeners that responses are complete
type NetworkErrorListeners ¶ added in v0.3.0
type NetworkErrorListeners interface {
NotifyNetworkErrorListeners(p peer.ID, request graphsync.RequestData, err error)
}
NetworkErrorListeners is an interface for notifying listeners that an error occurred sending a data on the wire
type RequestCloser ¶ added in v0.10.2
type RequestCloser interface { TerminateRequest(requestID graphsync.RequestID) CloseWithNetworkError(requestID graphsync.RequestID) }
RequestCloser can cancel request on a network error
type RequestHooks ¶ added in v0.1.0
type RequestHooks interface {
ProcessRequestHooks(p peer.ID, request graphsync.RequestData) hooks.RequestResult
}
RequestHooks is an interface for processing request hooks
type RequestQueuedHooks ¶ added in v0.6.4
type RequestQueuedHooks interface {
ProcessRequestQueuedHooks(p peer.ID, request graphsync.RequestData, reqCtx context.Context) context.Context
}
RequestQueuedHooks is an interface for processing request queued hooks
type ResponseAssembler ¶ added in v0.6.0
type ResponseAssembler interface {
NewStream(ctx context.Context, p peer.ID, requestID graphsync.RequestID, subscriber notifications.Subscriber) responseassembler.ResponseStream
}
ResponseAssembler is an interface that returns sender interfaces for peer responses.
type ResponseManager ¶
type ResponseManager struct {
// contains filtered or unexported fields
}
ResponseManager handles incoming requests from the network, initiates selector traversals, and transmits responses
func New ¶
func New(ctx context.Context, linkSystem ipld.LinkSystem, responseAssembler ResponseAssembler, requestQueuedHooks RequestQueuedHooks, requestHooks RequestHooks, updateHooks UpdateHooks, completedListeners CompletedListeners, cancelledListeners CancelledListeners, blockSentListeners BlockSentListeners, networkErrorListeners NetworkErrorListeners, connManager network.ConnManager, maxLinksPerRequest uint64, responseQueue taskqueue.TaskQueue, ) *ResponseManager
New creates a new response manager for responding to requests
func (*ResponseManager) CancelResponse ¶ added in v0.1.0
func (rm *ResponseManager) CancelResponse(ctx context.Context, requestID graphsync.RequestID) error
CancelResponse cancels an in progress response
func (*ResponseManager) CloseWithNetworkError ¶ added in v0.10.2
func (rm *ResponseManager) CloseWithNetworkError(requestID graphsync.RequestID)
CloseWithNetworkError closes a request due to a network error
func (*ResponseManager) FinishTask ¶ added in v0.10.0
FinishTask marks a task from the task queue as done
func (*ResponseManager) GetUpdates ¶ added in v0.10.0
func (rm *ResponseManager) GetUpdates(requestID graphsync.RequestID, updatesChan chan<- []gsmsg.GraphSyncRequest)
GetUpdates is called to read pending updates for a task and clear them
func (*ResponseManager) PauseResponse ¶ added in v0.1.0
func (rm *ResponseManager) PauseResponse(ctx context.Context, requestID graphsync.RequestID) error
PauseResponse pauses an in progress response (may take 1 or more blocks to process)
func (*ResponseManager) PeerState ¶ added in v0.10.7
func (rm *ResponseManager) PeerState(p peer.ID) peerstate.PeerState
PeerState gets current state of the outgoing responses for a given peer
func (*ResponseManager) ProcessRequests ¶
func (rm *ResponseManager) ProcessRequests(ctx context.Context, p peer.ID, requests []gsmsg.GraphSyncRequest)
ProcessRequests processes incoming requests for the given peer
func (*ResponseManager) Shutdown ¶
func (rm *ResponseManager) Shutdown()
Shutdown ends processing for the want manager.
func (*ResponseManager) StartTask ¶ added in v0.10.0
func (rm *ResponseManager) StartTask(task *peertask.Task, p peer.ID, responseTaskChan chan<- queryexecutor.ResponseTask)
StartTask starts the given task from the peer task queue
func (*ResponseManager) Startup ¶
func (rm *ResponseManager) Startup()
Startup starts processing for the WantManager.
func (*ResponseManager) TerminateRequest ¶ added in v0.10.8
func (rm *ResponseManager) TerminateRequest(requestID graphsync.RequestID)
TerminateRequest indicates a request has finished sending data and should no longer be tracked
func (*ResponseManager) UnpauseResponse ¶ added in v0.1.0
func (rm *ResponseManager) UnpauseResponse(ctx context.Context, requestID graphsync.RequestID, extensions ...graphsync.ExtensionData) error
UnpauseResponse unpauses a response that was previously paused
func (*ResponseManager) UpdateResponse ¶ added in v0.13.0
func (rm *ResponseManager) UpdateResponse(ctx context.Context, requestID graphsync.RequestID, extensions ...graphsync.ExtensionData) error
UpdateRequest updates an in progress response
type UpdateHooks ¶ added in v0.1.0
type UpdateHooks interface {
ProcessUpdateHooks(p peer.ID, request graphsync.RequestData, update graphsync.RequestData) hooks.UpdateResult
}
UpdateHooks is an interface for processing update hooks
Directories ¶
Path | Synopsis |
---|---|
Package responseassembler assembles responses that are queued for sending in outgoing messages The response assembler's Transaction method allows a caller to specify response actions that will go into a single libp2p2 message.
|
Package responseassembler assembles responses that are queued for sending in outgoing messages The response assembler's Transaction method allows a caller to specify response actions that will go into a single libp2p2 message. |