Documentation ¶
Index ¶
- func New(parent context.Context, network gsnet.GraphSyncNetwork, ...) graphsync.GraphExchange
- type GraphSync
- func (gs *GraphSync) Cancel(ctx context.Context, requestID graphsync.RequestID) error
- func (gs *GraphSync) Pause(ctx context.Context, requestID graphsync.RequestID) error
- func (gs *GraphSync) PeerState(p peer.ID) PeerState
- func (gs *GraphSync) RegisterBlockSentListener(listener graphsync.OnBlockSentListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterCompletedResponseListener(listener graphsync.OnResponseCompletedListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterIncomingBlockHook(hook graphsync.OnIncomingBlockHook) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterIncomingRequestHook(hook graphsync.OnIncomingRequestHook) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterIncomingRequestProcessingListener(listener graphsync.OnRequestProcessingListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterIncomingResponseHook(hook graphsync.OnIncomingResponseHook) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterNetworkErrorListener(listener graphsync.OnNetworkErrorListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterOutgoingBlockHook(hook graphsync.OnOutgoingBlockHook) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterOutgoingRequestHook(hook graphsync.OnOutgoingRequestHook) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterOutgoingRequestProcessingListener(listener graphsync.OnRequestProcessingListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterPersistenceOption(name string, lsys ipld.LinkSystem) error
- func (gs *GraphSync) RegisterReceiverNetworkErrorListener(listener graphsync.OnReceiverNetworkErrorListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterRequestUpdatedHook(hook graphsync.OnRequestUpdatedHook) graphsync.UnregisterHookFunc
- func (gs *GraphSync) RegisterRequestorCancelledListener(listener graphsync.OnRequestorCancelledListener) graphsync.UnregisterHookFunc
- func (gs *GraphSync) Request(ctx context.Context, p peer.ID, root ipld.Link, selector ipld.Node, ...) (<-chan graphsync.ResponseProgress, <-chan error)
- func (gs *GraphSync) SendUpdate(ctx context.Context, requestID graphsync.RequestID, ...) error
- func (gs *GraphSync) Stats() graphsync.Stats
- func (gs *GraphSync) Unpause(ctx context.Context, requestID graphsync.RequestID, ...) error
- func (gs *GraphSync) UnregisterPersistenceOption(name string) error
- type Option
- func MaxInProgressIncomingRequests(maxInProgressIncomingRequests uint64) Option
- func MaxInProgressIncomingRequestsPerPeer(maxInProgressIncomingRequestsPerPeer uint64) Option
- func MaxInProgressOutgoingRequests(maxInProgressOutgoingRequests uint64) Option
- func MaxLinksPerIncomingRequests(maxLinksPerIncomingRequest uint64) Option
- func MaxLinksPerOutgoingRequests(maxLinksPerOutgoingRequest uint64) Option
- func MaxMemoryPerPeerResponder(maxMemoryPerPeer uint64) Option
- func MaxMemoryResponder(totalMaxMemory uint64) Option
- func MessageSendRetries(messageSendRetries int) Option
- func PanicCallback(callbackFn panics.CallBackFn) Option
- func RejectAllRequestsByDefault() Option
- func SendMessageTimeout(sendMessageTimeout time.Duration) Option
- type PeerState
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func New ¶
func New(parent context.Context, network gsnet.GraphSyncNetwork, linkSystem ipld.LinkSystem, options ...Option) graphsync.GraphExchange
New creates a new GraphSync Exchange on the given network, and the given link loader+storer.
Types ¶
type GraphSync ¶
type GraphSync struct {
// contains filtered or unexported fields
}
GraphSync is an instance of a GraphSync exchange that implements the graphsync protocol.
func (*GraphSync) PeerState ¶ added in v0.10.7
PeerState produces insight on the current state of a given peer
func (*GraphSync) RegisterBlockSentListener ¶ added in v0.3.0
func (gs *GraphSync) RegisterBlockSentListener(listener graphsync.OnBlockSentListener) graphsync.UnregisterHookFunc
RegisterBlockSentListener adds a listener for when blocks are actually sent over the wire
func (*GraphSync) RegisterCompletedResponseListener ¶ added in v0.1.0
func (gs *GraphSync) RegisterCompletedResponseListener(listener graphsync.OnResponseCompletedListener) graphsync.UnregisterHookFunc
RegisterCompletedResponseListener adds a listener on the responder for completed responses
func (*GraphSync) RegisterIncomingBlockHook ¶ added in v0.1.0
func (gs *GraphSync) RegisterIncomingBlockHook(hook graphsync.OnIncomingBlockHook) graphsync.UnregisterHookFunc
RegisterIncomingBlockHook adds a hook that runs when a block is received and validated (put in block store)
func (*GraphSync) RegisterIncomingRequestHook ¶ added in v0.1.0
func (gs *GraphSync) RegisterIncomingRequestHook(hook graphsync.OnIncomingRequestHook) graphsync.UnregisterHookFunc
RegisterIncomingRequestHook adds a hook that runs when a request is received If overrideDefaultValidation is set to true, then if the hook does not error, it is considered to have "validated" the request -- and that validation supersedes the normal validation of requests Graphsync does (i.e. all selectors can be accepted)
func (*GraphSync) RegisterIncomingRequestProcessingListener ¶ added in v0.14.0
func (gs *GraphSync) RegisterIncomingRequestProcessingListener(listener graphsync.OnRequestProcessingListener) graphsync.UnregisterHookFunc
RegisterIncomingRequestQueuedHook adds a hook that runs when a new incoming request is added to the responder's task queue.
func (*GraphSync) RegisterIncomingResponseHook ¶ added in v0.1.0
func (gs *GraphSync) RegisterIncomingResponseHook(hook graphsync.OnIncomingResponseHook) graphsync.UnregisterHookFunc
RegisterIncomingResponseHook adds a hook that runs when a response is received
func (*GraphSync) RegisterNetworkErrorListener ¶ added in v0.3.0
func (gs *GraphSync) RegisterNetworkErrorListener(listener graphsync.OnNetworkErrorListener) graphsync.UnregisterHookFunc
RegisterNetworkErrorListener adds a listener for when errors occur sending data over the wire
func (*GraphSync) RegisterOutgoingBlockHook ¶ added in v0.1.0
func (gs *GraphSync) RegisterOutgoingBlockHook(hook graphsync.OnOutgoingBlockHook) graphsync.UnregisterHookFunc
RegisterOutgoingBlockHook registers a hook that runs after each block is sent in a response
func (*GraphSync) RegisterOutgoingRequestHook ¶ added in v0.1.0
func (gs *GraphSync) RegisterOutgoingRequestHook(hook graphsync.OnOutgoingRequestHook) graphsync.UnregisterHookFunc
RegisterOutgoingRequestHook adds a hook that runs immediately prior to sending a new request
func (*GraphSync) RegisterOutgoingRequestProcessingListener ¶ added in v0.10.5
func (gs *GraphSync) RegisterOutgoingRequestProcessingListener(listener graphsync.OnRequestProcessingListener) graphsync.UnregisterHookFunc
RegisterOutgoingRequestProcessingListener adds a listener that gets called when a request actually begins processing (reaches the top of the outgoing request queue)
func (*GraphSync) RegisterPersistenceOption ¶ added in v0.1.0
func (gs *GraphSync) RegisterPersistenceOption(name string, lsys ipld.LinkSystem) error
RegisterPersistenceOption registers an alternate loader/storer combo that can be substituted for the default
func (*GraphSync) RegisterReceiverNetworkErrorListener ¶ added in v0.6.0
func (gs *GraphSync) RegisterReceiverNetworkErrorListener(listener graphsync.OnReceiverNetworkErrorListener) graphsync.UnregisterHookFunc
RegisterReceiverNetworkErrorListener adds a listener for when errors occur receiving data over the wire
func (*GraphSync) RegisterRequestUpdatedHook ¶ added in v0.1.0
func (gs *GraphSync) RegisterRequestUpdatedHook(hook graphsync.OnRequestUpdatedHook) graphsync.UnregisterHookFunc
RegisterRequestUpdatedHook registers a hook that runs when an update to a request is received
func (*GraphSync) RegisterRequestorCancelledListener ¶ added in v0.1.0
func (gs *GraphSync) RegisterRequestorCancelledListener(listener graphsync.OnRequestorCancelledListener) graphsync.UnregisterHookFunc
RegisterRequestorCancelledListener adds a listener on the responder for responses cancelled by the requestor
func (*GraphSync) Request ¶
func (gs *GraphSync) Request(ctx context.Context, p peer.ID, root ipld.Link, selector ipld.Node, extensions ...graphsync.ExtensionData) (<-chan graphsync.ResponseProgress, <-chan error)
Request initiates a new GraphSync request to the given peer using the given selector spec.
func (*GraphSync) SendUpdate ¶ added in v0.13.0
func (gs *GraphSync) SendUpdate(ctx context.Context, requestID graphsync.RequestID, extensions ...graphsync.ExtensionData) error
SendUpdate sends an update for an in progress request or response
func (*GraphSync) Stats ¶ added in v0.10.3
func (gs *GraphSync) Stats() graphsync.Stats
Stats produces insight on the current state of a graphsync exchange
func (*GraphSync) Unpause ¶ added in v0.13.0
func (gs *GraphSync) Unpause(ctx context.Context, requestID graphsync.RequestID, extensions ...graphsync.ExtensionData) error
Unpause unpauses a request or response that was paused Can also send extensions with unpause
func (*GraphSync) UnregisterPersistenceOption ¶ added in v0.1.0
UnregisterPersistenceOption unregisters an alternate loader/storer combo
type Option ¶ added in v0.1.0
type Option func(*graphsyncConfigOptions)
Option defines the functional option type that can be used to configure graphsync instances
func MaxInProgressIncomingRequests ¶ added in v0.10.0
MaxInProgressIncomingRequests changes the maximum number of incoming graphsync requests that are processed in parallel (default 6)
func MaxInProgressIncomingRequestsPerPeer ¶ added in v0.10.3
MaxInProgressIncomingRequestsPerPeer changes the maximum number of incoming graphsync requests that are processed in parallel on a per-peer basis. The value is not set by default. Useful in an environment for very high bandwidth graphsync responders serving many peers Note: if for some reason this is set higher than MaxInProgressIncomingRequests it will simply have no effect. Note: setting a value of zero will have no effect
func MaxInProgressOutgoingRequests ¶ added in v0.10.0
MaxInProgressOutgoingRequests changes the maximum number of outgoing graphsync requests that are processed in parallel (default 6)
func MaxLinksPerIncomingRequests ¶ added in v0.10.0
MaxLinksPerIncomingRequests changes the allowed number of links an incoming request can traverse before failing A value of 0 = infinity, or no limit
func MaxLinksPerOutgoingRequests ¶ added in v0.10.0
MaxLinksPerOutgoingRequests changes the allowed number of links an outgoing request can traverse before failing A value of 0 = infinity, or no limit
func MaxMemoryPerPeerResponder ¶ added in v0.4.0
MaxMemoryPerPeerResponder defines the maximum amount of memory a peer may consume queueing up messages for a response
func MaxMemoryResponder ¶ added in v0.4.0
MaxMemoryResponder defines the maximum amount of memory the responder may consume queueing up messages for a response in total
func MessageSendRetries ¶ added in v0.10.3
MessageSendRetries sets the number of times graphsync will send attempt to send a message before giving up. Lower to increase the speed at which an unresponsive peer is detected.
If not set, a default of 10 is used.
func PanicCallback ¶ added in v0.13.2
func PanicCallback(callbackFn panics.CallBackFn) Option
PanicCallback allows calling code to receive information about panics that Graphsync recovers from. Graphsync recovers panics that occur during per-request execution in order to keep the over all system running, although they are still treated as standard errors in normal execution flow.
func RejectAllRequestsByDefault ¶ added in v0.1.0
func RejectAllRequestsByDefault() Option
RejectAllRequestsByDefault means that without hooks registered that perform their own request validation, all requests are rejected
func SendMessageTimeout ¶ added in v0.10.3
SendMessageTimeout sets the amount of time graphsync will wait for a message to go across the wire before giving up and trying again (up to max retries). Lower to increase the speed at which an unresponsive peer is detected.
If not set, a default of 10 minutes is used.