rproxymod

package
v2.0.3+incompatible Latest Latest
Warning

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

Go to latest
Published: Apr 27, 2022 License: MIT Imports: 8 Imported by: 21

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func CreateResponse

func CreateResponse(status int, body string) *http.Response

CreateResponse is a shorthand for making simple responses

func ServerHostName

func ServerHostName() string

ServerHostName returns the os.Hostname as set by init()

Types

type BaseModule

type BaseModule struct{}

Generic Ozone ReverseProxy Module base implementation with empty functions Other modules can use this as a Base and then implement required functionality.

func (*BaseModule) Deinit

func (appCtx *BaseModule) Deinit() error

func (*BaseModule) ModifyResponse

func (appCtx *BaseModule) ModifyResponse(reqCtx *RequestContext, inReq *http.Request, resp *http.Response) error

func (*BaseModule) ProcessRequest

func (appCtx *BaseModule) ProcessRequest(reqCtx *RequestContext, inReq *http.Request, proxyReq *http.Request) (*http.Response, error)

type Cache

type Cache interface {
	// Set a cache value, potentially with a TTL
	Set(key []byte, value []byte, ttl time.Duration) error

	// Get the value of a key
	Get(key []byte) (value []byte, err error)

	// Get a value and fetch it in case of cache miss.
	GetAndStore(key []byte, fetcher CacheFetcher) (value []byte, err error)

	// Delete a key from the cache
	Delete(key []byte)

	// Clear the cache
	Clear()

	// Close the cache
	Close() error

	// Get statistics about cache usage.
	GetCacheStats() (stats *CacheStats)
}

Cache defines the interface of a cache the reverse proxy can use to cache cross-request information.

type CacheFetcher

type CacheFetcher interface {
	Fetch(key []byte) (value []byte, ttl time.Duration, err error)
}

CacheFetcher is used by the cache to retrieve a value for a key after a cache miss.

type CacheStats

type CacheStats struct {
	CacheHitsCount   int64
	CacheMissesCount int64
	CacheErrorCount  int64
}

Statitics about cache usage.

type ProxyModule

type ProxyModule interface {

	// ProcessRequest is called in sequence for each proxy module. If it returns (nil,nil) the
	// request (proxyReq) is passed down the chain to the next module until pushed to the HTTP Transport
	// Otherwise the http.Response is returned - or, if nil and err is non-nil: 500 Internal server error
	// inReq is provided for information containing the original request before module modification
	// reqCtx contains cross module context, a logger and a proxy global cache.
	ProcessRequest(reqCtx *RequestContext, inReq *http.Request, proxyReq *http.Request) (*http.Response, error)

	// ModifyResponse allows you to modify the response from the backend.
	// It's called in reverse module order.
	ModifyResponse(reqCtx *RequestContext, inReq *http.Request, resp *http.Response) error

	// Deinitilize Module, cleanup operations like close DB handles
	// Could be used to cleanup older connection during graceful configuration reloads
	Deinit() error
}

Generic Ozone Reverse-Proxy Module

type RequestContext

type RequestContext struct {

	// CtxCache provides cross-request caching
	CtxCache Cache

	// Log will attach request session id to all log output
	Log *log.Logger
	// contains filtered or unexported fields
}

RequestContext is used to pass additional across the chain of rproxy modules.

func NewRequestContext

func NewRequestContext(ctxCache Cache, logger *log.Logger, key, id string) (*RequestContext, error)

NewRequestContext is used by the reverse proxy to create a new context for each request

func (*RequestContext) EnsureWritableHeader

func (ctx *RequestContext) EnsureWritableHeader(outgoing, incomming *http.Request)

func (*RequestContext) GetRequestCtxInfo

func (ctx *RequestContext) GetRequestCtxInfo(k string) string

GetRequestCtxInfo

func (*RequestContext) GetRequestCtxInfoKeys

func (ctx *RequestContext) GetRequestCtxInfoKeys() []string

GetRequestCtxInfoKeys return the session info keys

func (*RequestContext) GetSessionId

func (ctx *RequestContext) GetSessionId() string

GetSessionID returns the request session id

func (*RequestContext) SetRequestCtxInfo

func (ctx *RequestContext) SetRequestCtxInfo(k, v string)

Jump to

Keyboard shortcuts

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