transport

package
v0.3.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 28, 2023 License: MIT Imports: 16 Imported by: 2

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	// RetryOnAnyError retries on any error except for the following:
	// -32700: Parse error.
	// -32600: Invalid request.
	// -32601: Method not found.
	// -32602: Invalid params.
	RetryOnAnyError = func(err error) bool {

		switch errorCode(err) {
		case -32700:
			return false
		case -32600:
			return false
		case -32601:
			return false
		case -32602:
			return false
		}

		return err != nil
	}

	// RetryOnLimitExceeded retries on the following errors:
	// -32005: Limit exceeded.
	// 429: Too many requests.
	RetryOnLimitExceeded = func(err error) bool {
		switch errorCode(err) {
		case -32005:
			return true
		case 429:
			return true
		}
		return false
	}
)
View Source
var (
	// LinearBackoff returns a BackoffFunc that returns a constant delay.
	LinearBackoff = func(delay time.Duration) func(int) time.Duration {
		return func(_ int) time.Duration {
			return delay
		}
	}

	// ExponentialBackoff returns a BackoffFunc that returns an exponential delay.
	// The delay is calculated as BaseDelay * ExponentialFactor ^ retryCount.
	ExponentialBackoff = func(opts ExponentialBackoffOptions) func(int) time.Duration {
		return func(retryCount int) time.Duration {
			d := time.Duration(float64(opts.BaseDelay) * math.Pow(opts.ExponentialFactor, float64(retryCount)))
			if d > opts.MaxDelay {
				return opts.MaxDelay
			}
			return d
		}
	}
)
View Source
var ErrNotSubscriptionTransport = errors.New("transport does not implement SubscriptionTransport")

Functions

This section is empty.

Types

type Combined

type Combined struct {
	// contains filtered or unexported fields
}

Combined is transport that uses separate transports for regular calls and subscriptions.

It is recommended by some RPC providers to use HTTP for regular calls and WebSockets for subscriptions.

func NewCombined

func NewCombined(call Transport, subscriber SubscriptionTransport) *Combined

NewCombined creates a new Combined transport.

func (*Combined) Call

func (c *Combined) Call(ctx context.Context, result any, method string, args ...any) error

Call implements the Transport interface.

func (*Combined) Subscribe

func (c *Combined) Subscribe(ctx context.Context, method string, args ...any) (ch chan json.RawMessage, id string, err error)

Subscribe implements the SubscriptionTransport interface.

func (*Combined) Unsubscribe

func (c *Combined) Unsubscribe(ctx context.Context, id string) error

Unsubscribe implements the SubscriptionTransport interface.

type ExponentialBackoffOptions

type ExponentialBackoffOptions struct {
	// BaseDelay is the base delay before the first retry.
	BaseDelay time.Duration

	// MaxDelay is the maximum delay between retries.
	MaxDelay time.Duration

	// ExponentialFactor is the exponential factor to use for calculating the delay.
	// The delay is calculated as BaseDelay * ExponentialFactor ^ retryCount.
	ExponentialFactor float64
}

ExponentialBackoffOptions contains options for the ExponentialBackoff function.

type HTTP

type HTTP struct {
	// contains filtered or unexported fields
}

HTTP is a Transport implementation that uses the HTTP protocol.

func NewHTTP

func NewHTTP(opts HTTPOptions) (*HTTP, error)

NewHTTP creates a new HTTP instance.

func (*HTTP) Call

func (h *HTTP) Call(ctx context.Context, result any, method string, args ...any) error

Call implements the Transport interface.

type HTTPError

type HTTPError struct {
	Code int   // Code is the HTTP status code.
	Err  error // Err is an optional underlying error.
}

HTTPError is an HTTP error.

func (*HTTPError) Error

func (e *HTTPError) Error() string

Error implements the error interface.

type HTTPOptions

type HTTPOptions struct {
	// URL of the HTTP endpoint.
	URL string

	// HTTPClient is the HTTP client to use. If nil, http.DefaultClient is
	// used.
	HTTPClient *http.Client

	// HTTPHeader specifies the HTTP headers to send with each request.
	HTTPHeader http.Header
}

HTTPOptions contains options for the HTTP transport.

type IPC

type IPC struct {
	// contains filtered or unexported fields
}

IPC is a Transport implementation that uses the IPC protocol.

func NewIPC

func NewIPC(opts IPCOptions) (*IPC, error)

NewIPC creates a new IPC instance.

func (IPC) Call

func (s IPC) Call(ctx context.Context, result any, method string, args ...any) error

Call implements the Transport interface.

func (IPC) Subscribe

func (s IPC) Subscribe(ctx context.Context, method string, args ...any) (chan json.RawMessage, string, error)

Subscribe implements the SubscriptionTransport interface.

func (IPC) Unsubscribe

func (s IPC) Unsubscribe(ctx context.Context, id string) error

Unsubscribe implements the SubscriptionTransport interface.

type IPCOptions

type IPCOptions struct {
	// Context used to close the connection.
	Context context.Context

	// Path is the path to the IPC socket.
	Path string

	// Timeout is the timeout for the IPC requests. Default is 60s.
	Timout time.Duration

	// ErrorCh is an optional channel used to report errors.
	ErrorCh chan error
}

IPCOptions contains options for the IPC transport.

type RPCError

type RPCError struct {
	Code    int    // Code is the JSON-RPC error code.
	Message string // Message is the error message.
	Data    any    // Data associated with the error.
}

RPCError is an JSON-RPC error.

func (*RPCError) Error

func (e *RPCError) Error() string

Error implements the error interface.

type Retry

type Retry struct {
	// contains filtered or unexported fields
}

Retry is a wrapper around another transport that retries requests.

func NewRetry

func NewRetry(opts RetryOptions) (*Retry, error)

NewRetry creates a new Retry instance.

func (*Retry) Call

func (c *Retry) Call(ctx context.Context, result any, method string, args ...any) (err error)

Call implements the Transport interface.

func (*Retry) Subscribe

func (c *Retry) Subscribe(ctx context.Context, method string, args ...any) (ch chan json.RawMessage, id string, err error)

Subscribe implements the SubscriptionTransport interface.

func (*Retry) Unsubscribe

func (c *Retry) Unsubscribe(ctx context.Context, id string) (err error)

Unsubscribe implements the SubscriptionTransport interface.

type RetryOptions

type RetryOptions struct {
	// Transport is the underlying transport to use.
	Transport Transport

	// RetryFunc is a function that returns true if the request should be
	// retried. The RetryOnAnyError and RetryOnLimitExceeded functions can be
	// used or a custom function can be provided.
	RetryFunc func(error) bool

	// BackoffFunc is a function that returns the delay before the next retry.
	// It takes the current retry count as an argument.
	BackoffFunc func(int) time.Duration

	// MaxRetries is the maximum number of retries. If negative, there is no limit.
	MaxRetries int
}

RetryOptions contains options for the Retry transport.

type SubscriptionTransport

type SubscriptionTransport interface {
	Transport

	// Subscribe starts a new subscription. It returns a channel that receives
	// subscription messages and a subscription ID.
	Subscribe(ctx context.Context, method string, args ...any) (ch chan json.RawMessage, id string, err error)

	// Unsubscribe cancels a subscription. The channel returned by Subscribe
	// will be closed.
	Unsubscribe(ctx context.Context, id string) error
}

SubscriptionTransport is transport that supports subscriptions.

type Transport

type Transport interface {
	// Call performs a JSON-RPC call.
	Call(ctx context.Context, result any, method string, args ...any) error
}

Transport handles the transport layer of the JSON-RPC protocol.

func New

func New(ctx context.Context, rpcURL string) (Transport, error)

New returns a new Transport instance based on the URL scheme. Supported schemes are: http, https, ws, wss. If scheme is empty, it will use IPC.

The context is used to close the underlying connection when the transport uses a websocket or IPC.

type Websocket

type Websocket struct {
	// contains filtered or unexported fields
}

Websocket is a Transport implementation that uses the websocket protocol.

func NewWebsocket

func NewWebsocket(opts WebsocketOptions) (*Websocket, error)

NewWebsocket creates a new Websocket instance.

func (Websocket) Call

func (s Websocket) Call(ctx context.Context, result any, method string, args ...any) error

Call implements the Transport interface.

func (Websocket) Subscribe

func (s Websocket) Subscribe(ctx context.Context, method string, args ...any) (chan json.RawMessage, string, error)

Subscribe implements the SubscriptionTransport interface.

func (Websocket) Unsubscribe

func (s Websocket) Unsubscribe(ctx context.Context, id string) error

Unsubscribe implements the SubscriptionTransport interface.

type WebsocketOptions

type WebsocketOptions struct {
	// Context used to close the connection.
	Context context.Context

	// URL of the websocket endpoint.
	URL string

	// HTTPClient is the HTTP client to use. If nil, http.DefaultClient is
	// used.
	HTTPClient *http.Client

	// HTTPHeader specifies the HTTP headers to be included in the
	// websocket handshake request.
	HTTPHeader http.Header

	// Timeout is the timeout for the websocket requests. Default is 60s.
	Timout time.Duration

	// ErrorCh is an optional channel used to report errors.
	ErrorCh chan error
}

WebsocketOptions contains options for the websocket transport.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL