roundtripper

package
v0.1.2 Latest Latest
Warning

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

Go to latest
Published: Dec 16, 2024 License: MIT Imports: 11 Imported by: 1

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func New

func New(options ...Option) http.RoundTripper

New returns a RoundTripper that implements the behaviour as specified by the different Option parameters. New will construct a cascading roundTripper in the order of the provided options. E.g.

r := New(WithRequestMetrics(...), WithCache(...))

returns a roundTripper that measures the client metrics, and then attempts to get the response from cache. Metrics are therefor captured for cached and non-cached responses. On the other hand:

r := New(WithCache(...), WithRequestMetrics(...))

first attempts to get the response from cache, and failing that, performs real call, recording its http metrics. Metrics will therefore only be captured for real http calls.

New makes no attempt to sanitize the order of the provided options. E.g. WithRoundTripper does not cascade to a next roundTripper; it directly performs the http call using the provided transport. Therefore, if we create the following RoundTripper:

r := New(WithRoundTripper(...), WithRequestMetrics(...))

the WithRequestMetrics option will not be used at all.

If no options are provided, or the final option isn't WithRoundTripper, the http call is done using http.DefaultTransport.

Types

type CacheMetrics

type CacheMetrics interface {
	Measure(r *http.Request, found bool)
	prometheus.Collector
}

func NewCacheMetrics

func NewCacheMetrics(options CacheMetricsOptions) CacheMetrics

NewCacheMetrics returns CacheMetrics that measure the total cache attempts and the cache hits (both as Counters).

type CacheMetricsOptions

type CacheMetricsOptions struct {
	// Namespace to prepend to the metric name
	Namespace string
	// Subsystem to prepend to the metric name
	Subsystem string
	// ConstLabels to add to the metric
	ConstLabels prometheus.Labels
	// GetPath returns the path to use in the metric's path label. Can be used to reduce metric cardinality when many paths are cached.
	GetPath func(r *http.Request) string
}

CacheMetricsOptions provides configuration options for NewCacheMetrics

type CacheOptions

type CacheOptions struct {
	// CacheTable determines which requests are cached and for how long. If empty, all requests are cached.
	CacheTable
	// DefaultExpiration defines how long requests are cached when CacheTable is empty.
	DefaultExpiration time.Duration
	// CleanupInterval defines how often the cache is scrubbed (i.e. when stale requests are removed).
	// If zero, stale requests are never removed.
	CleanupInterval time.Duration
	// GetKey returns the cache key for a request. By default, the request's method and path are used.
	GetKey func(*http.Request) string
	// Metrics contains the Prometheus metrics for the cache. The caller must register the requests with a Prometheus registry.
	// If nil, no metrics are collected.
	CacheMetrics
}

CacheOptions contains configuration options for a caching roundTripper.

type CacheTable

type CacheTable []*CacheTableEntry

CacheTable defines which responses are cached. If table is empty, all responses will be cached.

var DefaultCacheTable CacheTable

DefaultCacheTable caches all requests.

type CacheTableEntry

type CacheTableEntry struct {
	// Path is the URL Path for requests whose responses should be cached. If blank, all paths will be cached.
	// Can be a literal path, or a regular expression. In the latter case, set IsRegExp to true
	Path string
	// Methods is the list of HTTP Methods for which requests the response should be cached.
	// If empty, requests for any method will be cached.
	Methods []string
	// IsRegExp indicates if the Path is a regular expression.
	// CacheTableEntry will panic if Path does not contain a valid regular expression.
	IsRegExp bool
	// Expiry indicates how long a response should be cached.
	Expiry time.Duration
	// contains filtered or unexported fields
}

CacheTableEntry contains a single endpoint that should be cached. If the Path is a regular expression, IsRegExp must be true.

type Option

type Option func(current http.RoundTripper) http.RoundTripper

Option is a function that can be passed to New to specify the behaviour of the RoundTripper. See WithMetrics, WithCache, etc. for examples.

func WithCache

func WithCache(options CacheOptions) Option

WithCache creates a RoundTripper that caches the HTTP responses. See CacheOptions for the available options.

func WithInflightMetrics

func WithInflightMetrics(m *metrics.InflightMetrics) Option

WithInflightMetrics creates a http.RoundTripper that measures outstanding requests. The caller must register the metrics with a Prometheus registry.

func WithLimiter

func WithLimiter(maxParallel int64) Option

WithLimiter creates a RoundTripper that limits the number concurrent http requests to maxParallel.

func WithRequestMetrics

func WithRequestMetrics(m metrics.RequestMetrics) Option

WithRequestMetrics creates a http.RoundTripper that measures request count and duration. The caller must register the metrics with a Prometheus registry.

func WithRoundTripper

func WithRoundTripper(roundTripper http.RoundTripper) Option

WithRoundTripper specifies the http.RoundTripper to make the final http client call. If no WithRoundTripper is provided, RoundTripper defaults to http.DefaultTransport. Providing a nil roundTripper causes RoundTripper to panic.

type RoundTripperFunc

type RoundTripperFunc func(*http.Request) (*http.Response, error)

The RoundTripperFunc type is an adapter to allow the use of ordinary functions as HTTP roundTrippers. If f is a function with the appropriate signature, RoundTripperFunc(f) is a roundTripper that calls f.

func (RoundTripperFunc) RoundTrip

func (f RoundTripperFunc) RoundTrip(req *http.Request) (*http.Response, error)

RoundTrip calls f(req)

Directories

Path Synopsis
internal

Jump to

Keyboard shortcuts

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