Documentation
¶
Index ¶
- func MergeHeaders(left, right http.Header) http.Header
- func QueryValues(v interface{}) (url.Values, error)
- func StringifyJSON(value interface{}) (string, error)
- func WriteMultipartJSON(writer *multipart.Writer, field string, value interface{}) error
- type APIError
- type BaseURLOption
- type CallParams
- type Caller
- type CallerParams
- type ClientNameOption
- type Date
- type DateTime
- type ErrorDecoder
- type HTTPClient
- type HTTPClientOption
- type HTTPHeaderOption
- type MaxAttemptsOption
- type QueryEncoder
- type RequestOption
- type RequestOptions
- type Retrier
- type RetryFunc
- type RetryOption
- type Stream
- type StreamOption
- type StreamParams
- type Streamer
- type TokenOption
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func MergeHeaders ¶ added in v2.5.2
MergeHeaders merges the given headers together, where the right takes precedence over the left.
func QueryValues ¶ added in v2.5.2
QueryValues encodes url.Values from request objects.
Note: This type is inspired by Google's query encoding library, but supports far less customization and is tailored to fit this SDK's use case.
func StringifyJSON ¶
StringifyJSON returns a pretty JSON string representation of the given value.
Types ¶
type APIError ¶
type APIError struct { StatusCode int `json:"-"` // contains filtered or unexported fields }
APIError is a lightweight wrapper around the standard error interface that preserves the status code from the RPC, if any.
func NewAPIError ¶
NewAPIError constructs a new API error.
type BaseURLOption ¶ added in v2.5.2
type BaseURLOption struct {
BaseURL string
}
BaseURLOption implements the RequestOption interface.
type CallParams ¶
type CallParams struct { URL string Method string MaxAttempts uint Headers http.Header Client HTTPClient Request interface{} Response interface{} ResponseIsOptional bool ErrorDecoder ErrorDecoder }
CallParams represents the parameters used to issue an API call.
type Caller ¶
type Caller struct {
// contains filtered or unexported fields
}
Caller calls APIs and deserializes their response, if any.
func NewCaller ¶
func NewCaller(params *CallerParams) *Caller
NewCaller returns a new *Caller backed by the given parameters.
type CallerParams ¶ added in v2.5.2
type CallerParams struct { Client HTTPClient MaxAttempts uint }
CallerParams represents the parameters used to constrcut a new *Caller.
type ClientNameOption ¶ added in v2.5.2
type ClientNameOption struct {
ClientName *string
}
ClientNameOption implements the RequestOption interface.
type Date ¶ added in v2.6.0
type Date struct {
// contains filtered or unexported fields
}
DateTime wraps time.Time and adapts its JSON representation to conform to a RFC3339 date (e.g. 2006-01-02).
Ref: https://ijmacd.github.io/rfc3339-iso8601
func NewDate ¶ added in v2.6.0
NewDate returns a new *Date. If the given time.Time is nil, nil will be returned.
func NewOptionalDate ¶ added in v2.6.0
NewOptionalDate returns a new *Date. If the given time.Time is nil, nil will be returned.
func (*Date) MarshalJSON ¶ added in v2.6.0
func (*Date) Time ¶ added in v2.6.0
Time returns the Date's underlying time, if any. If the date is nil, the zero value is returned.
func (*Date) TimePtr ¶ added in v2.6.0
TimePtr returns a pointer to the Date's underlying time.Time, if any.
func (*Date) UnmarshalJSON ¶ added in v2.6.0
type DateTime ¶ added in v2.6.0
type DateTime struct {
// contains filtered or unexported fields
}
DateTime wraps time.Time and adapts its JSON representation to conform to a RFC3339 date-time (e.g. 2017-07-21T17:32:28Z).
Ref: https://ijmacd.github.io/rfc3339-iso8601
func NewDateTime ¶ added in v2.6.0
NewDateTime returns a new *DateTime.
func NewOptionalDateTime ¶ added in v2.6.0
NewOptionalDateTime returns a new *DateTime. If the given time.Time is nil, nil will be returned.
func (*DateTime) MarshalJSON ¶ added in v2.6.0
func (*DateTime) Time ¶ added in v2.6.0
Time returns the DateTime's underlying time, if any. If the date-time is nil, the zero value is returned.
func (*DateTime) TimePtr ¶ added in v2.6.0
TimePtr returns a pointer to the DateTime's underlying time.Time, if any.
func (*DateTime) UnmarshalJSON ¶ added in v2.6.0
type ErrorDecoder ¶
ErrorDecoder decodes *http.Response errors and returns a typed API error (e.g. *APIError).
type HTTPClient ¶
HTTPClient is an interface for a subset of the *http.Client.
type HTTPClientOption ¶ added in v2.5.2
type HTTPClientOption struct {
HTTPClient HTTPClient
}
HTTPClientOption implements the RequestOption interface.
type HTTPHeaderOption ¶ added in v2.5.2
HTTPHeaderOption implements the RequestOption interface.
type MaxAttemptsOption ¶ added in v2.5.2
type MaxAttemptsOption struct {
MaxAttempts uint
}
MaxAttemptsOption implements the RequestOption interface.
type QueryEncoder ¶ added in v2.5.2
QueryEncoder is an interface implemented by any type that wishes to encode itself into URL values in a non-standard way.
type RequestOption ¶ added in v2.5.2
type RequestOption interface {
// contains filtered or unexported methods
}
RequestOption adapts the behavior of the client or an individual request.
type RequestOptions ¶ added in v2.5.2
type RequestOptions struct { BaseURL string HTTPClient HTTPClient HTTPHeader http.Header MaxAttempts uint Token string ClientName *string }
RequestOptions defines all of the possible request options.
This type is primarily used by the generated code and is not meant to be used directly; use the option package instead.
func NewRequestOptions ¶ added in v2.5.2
func NewRequestOptions(opts ...RequestOption) *RequestOptions
NewRequestOptions returns a new *RequestOptions value.
This function is primarily used by the generated code and is not meant to be used directly; use RequestOption instead.
func (*RequestOptions) ToHeader ¶ added in v2.5.2
func (r *RequestOptions) ToHeader() http.Header
ToHeader maps the configured request options into a http.Header used for the request(s).
type Retrier ¶ added in v2.5.2
type Retrier struct {
// contains filtered or unexported fields
}
Retrier retries failed requests a configurable number of times with an exponential back-off between each retry.
func NewRetrier ¶ added in v2.5.2
func NewRetrier(opts ...RetryOption) *Retrier
NewRetrier constructs a new *Retrier with the given options, if any.
func (*Retrier) Run ¶ added in v2.5.2
func (r *Retrier) Run( fn RetryFunc, request *http.Request, errorDecoder ErrorDecoder, opts ...RetryOption, ) (*http.Response, error)
Run issues the request and, upon failure, retries the request if possible.
The request will be retried as long as the request is deemed retriable and the number of retry attempts has not grown larger than the configured retry limit.
type RetryFunc ¶ added in v2.5.2
RetryFunc is a retriable HTTP function call (i.e. *http.Client.Do).
type RetryOption ¶ added in v2.5.2
type RetryOption func(*retryOptions)
RetryOption adapts the behavior the *Retrier.
func WithMaxAttempts ¶ added in v2.5.2
func WithMaxAttempts(attempts uint) RetryOption
WithMaxAttempts configures the maximum number of attempts of the *Retrier.
type Stream ¶
type Stream[T any] struct { // contains filtered or unexported fields }
Stream represents a stream of messages sent from a server.
type StreamOption ¶
type StreamOption func(*streamOptions)
StreamOption adapts the behavior of the Stream.
func WithDelimiter ¶
func WithDelimiter(delimiter string) StreamOption
WithDelimiter overrides the delimiter for the Stream.
By default, the Stream is newline-delimited.
type StreamParams ¶
type StreamParams struct { URL string Method string Delimiter string MaxAttempts uint Headers http.Header Client HTTPClient Request interface{} ErrorDecoder ErrorDecoder }
StreamParams represents the parameters used to issue an API streaming call.
type Streamer ¶
type Streamer[T any] struct { // contains filtered or unexported fields }
Streamer calls APIs and streams responses using a *Stream.
func NewStreamer ¶
NewStreamer returns a new *Streamer backed by the given caller's HTTP client.
type TokenOption ¶ added in v2.5.2
type TokenOption struct {
Token string
}
TokenOption implements the RequestOption interface.