Documentation ¶
Index ¶
- Constants
- func Backoff(f F) error
- func BackoffExtended(f F, maxTries int, minimumCycle time.Duration, maxCycle time.Duration) error
- func CalculateBackoff(r *rand.Rand, attempt int, minimumCycle time.Duration, maxCycle time.Duration) time.Duration
- func GetInt16Value(values url.Values, key string, def int16) int16
- func GetInt32Value(values url.Values, key string, def int32) int32
- func GetInt64Value(values url.Values, key string, def int64) int64
- func GetInt8Value(values url.Values, key string, def int8) int8
- func GetIntValue(values url.Values, key string, def int) int
- func GetUint16Value(values url.Values, key string, def uint16) uint16
- func GetUint32Value(values url.Values, key string, def uint32) uint32
- func GetUint64Value(values url.Values, key string, def uint64) uint64
- func GetUint8Value(values url.Values, key string, def uint8) uint8
- func GetUintValue(values url.Values, key string, def uint) uint
- func NewBadStatusError(method string, url string, status int) errors.TracerError
- func NewEmptyAddressError() errors.TracerError
- func NewInvalidRedisAddressError(address string, err error) error
- func RandomizeIPArray(a []nnet.IP) []nnet.IP
- func ValidateIPv4Address(s string) bool
- func ValidateIPv6Address(s string) bool
- type Address
- type BadStatusError
- type DoHTTPRequest
- type EmptyAddressError
- type F
- type GetListenerGetTask
- type InvalidRedisAddressError
- type JRPC2Client
- type JRPC2Request
- type JRPC2Response
- type MockAddr
- type MockConn
- func (conn *MockConn) Close() error
- func (conn *MockConn) LocalAddr() net.Addr
- func (conn *MockConn) Read(b []byte) (n int, err error)
- func (conn *MockConn) RemoteAddr() net.Addr
- func (conn *MockConn) SetDeadline(t time.Time) error
- func (conn *MockConn) SetReadDeadline(t time.Time) error
- func (conn *MockConn) SetWriteDeadline(t time.Time) error
- func (conn *MockConn) Write(b []byte) (n int, err error)
- type MockHTTPClient
- func (client *MockHTTPClient) AddCookieJar(jar http.CookieJar)
- func (client *MockHTTPClient) Cookies(url *url.URL) []*http.Cookie
- func (client *MockHTTPClient) Do(req *http.Request) (*http.Response, errors.TracerError)
- func (client *MockHTTPClient) DoCalledPop() *http.Request
- func (client *MockHTTPClient) DoWithContext(ctx context.Context, req *http.Request) (*http.Response, errors.TracerError)
- func (client *MockHTTPClient) SetCookies(url *url.URL, cookies []*http.Cookie)
- type MockListener
- type NameSpacedRedis
- type SimpleDoRequest
- func (m *SimpleDoRequest) AddCookieJar(jar http.CookieJar)
- func (m *SimpleDoRequest) Cookies(url *url.URL) []*http.Cookie
- func (m *SimpleDoRequest) Do(req *http.Request) (*http.Response, errors.TracerError)
- func (m *SimpleDoRequest) DoWithContext(ctx context.Context, req *http.Request) (*http.Response, errors.TracerError)
- func (m *SimpleDoRequest) SetCookies(url *url.URL, cookies []*http.Cookie)
- type TCPServer
Constants ¶
const ( // DefaultMaxRetries is used as the maximum retries in the backoff when Backoff is called. DefaultMaxRetries = 5 // DefaultMinimumCycle is used as the minimum cycle duration when Backoff is called. DefaultMinimumCycle = 100 * time.Millisecond // DefaultCeiling is used as the maximum wait time between executions when Backoff is called. DefaultCeiling = 15 * time.Second )
const ( // HeaderAuthorization is the HTTP header for Authorization HeaderAuthorization = "Authorization" // HeaderContentType is the HTTP header Content Type HeaderContentType = "Content-Type" // HeaderAccept is the HTTP header Accept HeaderAccept = "Accept" // HeaderHost specifies the domain name of the server HeaderHost = "Host" // HeaderKeepAlive allows the sender to hint about how the connection may be used to set a timeout and max # of requests HeaderKeepAlive = "Keep-Alive" // HeaderConnection controls whether or not the network connection stays open after the transaction finishes HeaderConnection = "Connection" // HeaderUserAgent allows network peers to identify the application type, os, software vendor or version of requesting software user agent HeaderUserAgent = "User-Agent" // HeaderCacheControl specifies directives for caching mechanisms in both requests and responses HeaderCacheControl = "Cache-Control" // MIMEAppJSON is the HTTP value application/json for ContentType MIMEAppJSON = "application/json" // MIMEAppFormURLEncoded is the HTTP value application/x-www-form-urlencoded for ContentType MIMEAppFormURLEncoded = "application/x-www-form-urlencoded" // CacheControlNone is the Cache-Control value for disabling cacheing CacheControlNone = "no-cache" )
const ( DefaultMinWorkers = 300 DefaultBufferedTasks = 10000 DefaultIdleTimeout = 24 * time.Hour )
Sensible Defaults
const (
// DefaultJRPC2Port for JSON RPC 2
DefaultJRPC2Port = 44100
)
Variables ¶
This section is empty.
Functions ¶
func Backoff ¶
Backoff Executes the passed function with exponential back off up to a maximum a number of tries with the minimum amount of time per cycle using default values.
func BackoffExtended ¶
BackoffExtended Executes the passed function with exponential back off up to a maximum a number of tries with the minimum amount of time per cycle.
func CalculateBackoff ¶
func CalculateBackoff(r *rand.Rand, attempt int, minimumCycle time.Duration, maxCycle time.Duration) time.Duration
CalculateBackoff returns a duration for exponential backoff
func GetInt16Value ¶
GetInt16Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetInt32Value ¶
GetInt32Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetInt64Value ¶
GetInt64Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetInt8Value ¶
GetInt8Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetIntValue ¶
GetIntValue attempts to retrieve the value from url.Values, otherwise returns the default
func GetUint16Value ¶
GetUint16Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetUint32Value ¶
GetUint32Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetUint64Value ¶
GetUint64Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetUint8Value ¶
GetUint8Value attempts to retrieve the value from url.Values, otherwise returns the default
func GetUintValue ¶
GetUintValue attempts to retrieve the value from url.Values, otherwise returns the default
func NewBadStatusError ¶
func NewBadStatusError(method string, url string, status int) errors.TracerError
NewBadStatusError for a http request
func NewEmptyAddressError ¶
func NewEmptyAddressError() errors.TracerError
NewEmptyAddressError instantiates a EmptyAddressError with a stack trace
func NewInvalidRedisAddressError ¶
NewInvalidRedisAddressError for the passed address and underlying error.
func RandomizeIPArray ¶
RandomizeIPArray for basic load balancing
func ValidateIPv4Address ¶
ValidateIPv4Address with or without a port and return a boolean indicating success.
func ValidateIPv6Address ¶
ValidateIPv6Address with or without a port and return a boolean indicating success.
Types ¶
type Address ¶
Address of a remote host with port information. Does not handle Zones.
func NewAddressFromConnection ¶
NewAddressFromConnection if the RemoteAddr is set to a valid address.
func ParseAddress ¶
func ParseAddress(address string) (*Address, errors.TracerError)
ParseAddress from the passed string and return it.
func (*Address) MarshalString ¶
MarshalString from the address.
func (*Address) UnmarshalString ¶
UnmarshalString to an address
type BadStatusError ¶
type BadStatusError struct { Method string URL string Status int // contains filtered or unexported fields }
BadStatusError is returned when a request results in a non-successful status code ![200-299]
func (*BadStatusError) Error ¶
func (err *BadStatusError) Error() string
type DoHTTPRequest ¶
type DoHTTPRequest interface { // Do the request by sending the payload to the remote server and returning the response and any errors Do(*http.Request) (*http.Response, errors.TracerError) // DoWithContext the request by sending the payload to the remote server and returning the response and any errors // cancelling the request at the transport level when the context returns on it's 'Done' channel. DoWithContext(context.Context, *http.Request) (*http.Response, errors.TracerError) // AddCookieJar to http client to make cookies available to future requests AddCookieJar(http.CookieJar) // Cookies lists cookies in the jar Cookies(url *url.URL) []*http.Cookie // SetCookies adds cookies to the jar SetCookies(url *url.URL, cookies []*http.Cookie) }
DoHTTPRequest provides an interface for an HTTP Client.
func NewHTTPRedirectClient ¶
func NewHTTPRedirectClient(timeout time.Duration) DoHTTPRequest
NewHTTPRedirectClient is the default net/http client with headers being set on redirect
type EmptyAddressError ¶
type EmptyAddressError struct {
// contains filtered or unexported fields
}
EmptyAddressError is returned when an empty string is passed as the address
func (*EmptyAddressError) Error ¶
func (err *EmptyAddressError) Error() string
func (*EmptyAddressError) Trace ¶
func (err *EmptyAddressError) Trace() []string
Trace returns the stack trace for the error
type GetListenerGetTask ¶
type GetListenerGetTask interface { // GetListener for accepting connections. GetListener() (net.Listener, error) // GetTask to be executed in response to an inbound connection. GetTask(conn net.Conn) (dispatcher.Task, error) }
GetListenerGetTask provides functions for getting a listener and a task from a connection.
type InvalidRedisAddressError ¶
InvalidRedisAddressError is returned in an invalid address is passed to the Redis Client initializer.
func (*InvalidRedisAddressError) Error ¶
func (err *InvalidRedisAddressError) Error() string
type JRPC2Client ¶
type JRPC2Client interface { // Send the passed request Send(JRPC2Request) (*JRPC2Response, errors.TracerError) }
JRPC2Client for sending JSON RPC 2 requests
func NewJRPC2Client ¶
func NewJRPC2Client(host string, port int) JRPC2Client
NewJRPC2Client for communicating with the specified host and port.
type JRPC2Request ¶
type JRPC2Request struct { ID string `json:"id"` Method string `json:"method"` Params interface{} `json:"params"` // array or map }
JRPC2Request for calling remote procedures via JSON and a JRPC2Client
func NewJRPC2Request ¶
func NewJRPC2Request(method string, params interface{}) JRPC2Request
NewJRPC2Request creates a new request with the passed method and params and generates a new ID.
type JRPC2Response ¶
type JRPC2Response struct { JSONRPC string `json:"jsonrpc"` ID string `json:"id"` Result interface{} `json:"result"` Error interface{} `json:"error"` }
JRPC2Response for calling remote procedures via JSON and a JRPC2Client
type MockAddr ¶
MockAddr implements the net.MockAddr interface
type MockConn ¶
type MockConn struct { ID int RAddress net.Addr LAddress net.Addr Closed bool ReadComplete bool ReadMultiple bool Deadline time.Time ReadDeadline time.Time WriteDeadline time.Time ReadF func(b []byte) (n int, err error) WriteF func(b []byte) (n int, err error) }
MockConn is a mock implementation of the io.ReadWriteCloser interface
func (*MockConn) LocalAddr ¶
LocalAddr returns a new mock Addr or the LAddress on the mock connection
func (*MockConn) RemoteAddr ¶
RemoteAddr returns a new mock Addr or the RAddress on the mock connection
func (*MockConn) SetDeadline ¶
SetDeadline is a no-op mock that returns nil
func (*MockConn) SetReadDeadline ¶
SetReadDeadline is a no-op mock that returns nil
func (*MockConn) SetWriteDeadline ¶
SetWriteDeadline is a no-op mock that returns nil
type MockHTTPClient ¶
type MockHTTPClient struct { DoReturn collection.Stack DoCalled collection.Stack // contains filtered or unexported fields }
MockHTTPClient mocks the DoHTTPRequest interface
func NewMockHTTPClient ¶
func NewMockHTTPClient(returnStackItems ...interface{}) *MockHTTPClient
NewMockHTTPClient returns a mocked version of the DoHTTPRequest interface
func (*MockHTTPClient) AddCookieJar ¶
func (client *MockHTTPClient) AddCookieJar(jar http.CookieJar)
AddCookieJar to http client to make them available to all future requests
func (*MockHTTPClient) Cookies ¶
func (client *MockHTTPClient) Cookies(url *url.URL) []*http.Cookie
Cookies lists cookies in the jar
func (*MockHTTPClient) Do ¶
func (client *MockHTTPClient) Do(req *http.Request) (*http.Response, errors.TracerError)
Do returns the http.Response / error from the DoReturn stack and records the request on the DoCalled stack
func (*MockHTTPClient) DoCalledPop ¶
func (client *MockHTTPClient) DoCalledPop() *http.Request
DoCalledPop pops the last http.Request from the DoCalled stack if it exists
func (*MockHTTPClient) DoWithContext ¶
func (client *MockHTTPClient) DoWithContext(ctx context.Context, req *http.Request) (*http.Response, errors.TracerError)
DoWithContext returns the http.Response / error from the DoReturn stack and records the request on the DoCalled stack
func (*MockHTTPClient) SetCookies ¶
func (client *MockHTTPClient) SetCookies(url *url.URL, cookies []*http.Cookie)
SetCookies adds cookies to the jar
type MockListener ¶
MockListener is a mock implementation of the net.MockListener interface
func (*MockListener) Accept ¶
func (listener *MockListener) Accept() (conn net.Conn, err error)
Accept returnes the MockConn and the AcceptError
func (*MockListener) Addr ¶
func (listener *MockListener) Addr() net.Addr
Addr returns the listener's network address.
type NameSpacedRedis ¶
type NameSpacedRedis interface { // Exists verifies the key is in Redis Exists(keys ...string) *redis.IntCmd // Del removes a key/value from Redis Del(keys ...string) *redis.IntCmd // Set add a key/value with an optional expiration (0 is no expiration) into Redis Set(key string, value interface{}, expiration time.Duration) *redis.StatusCmd // Get a value for a given key from Redis Get(key string) *redis.StringCmd // SAdd adds the specified members to the set stored at key SAdd(key string, members ...interface{}) *redis.IntCmd // SCard returns the cardinality of the set stored at key SCard(key string) *redis.IntCmd // SRem removes the specified members from the set stored at key SRem(key string, members ...interface{}) *redis.IntCmd // SRandMember When called with just the key argument, return a random element from the set value stored at key SRandMember(key string) *redis.StringCmd // SPop removes and returns one or more random elements from the set value store at key SPop(key string) *redis.StringCmd // FlushAll deletes all the keys of all the existing databases, not just the currently selected one FlushAll() *redis.StatusCmd }
NameSpacedRedis wraps certain redis commands with a namespace around key names to avoid collisions
func NewRedisClient ¶
func NewRedisClient(address string, namespace string) (NameSpacedRedis, error)
NewRedisClient that is appropriate for the passed address.
type SimpleDoRequest ¶
type SimpleDoRequest struct { DoFunc func(req *http.Request) (*http.Response, error) // contains filtered or unexported fields }
SimpleDoRequest allows for providing a function as a client.
func (*SimpleDoRequest) AddCookieJar ¶
func (m *SimpleDoRequest) AddCookieJar(jar http.CookieJar)
AddCookieJar to http client to make them available to all future requests
func (*SimpleDoRequest) Cookies ¶
func (m *SimpleDoRequest) Cookies(url *url.URL) []*http.Cookie
Cookies lists cookies in the jar
func (*SimpleDoRequest) Do ¶
func (m *SimpleDoRequest) Do(req *http.Request) (*http.Response, errors.TracerError)
Do implements DoHTTPRequest.Do
func (*SimpleDoRequest) DoWithContext ¶
func (m *SimpleDoRequest) DoWithContext(ctx context.Context, req *http.Request) (*http.Response, errors.TracerError)
DoWithContext implements DoHTTPRequest.DoWithContext
func (*SimpleDoRequest) SetCookies ¶
func (m *SimpleDoRequest) SetCookies(url *url.URL, cookies []*http.Cookie)
SetCookies adds cookies to the jar
type TCPServer ¶
type TCPServer struct { MaxConsecutiveErrors int MaxWorkers int Dispatcher dispatcher.Dispatcher // contains filtered or unexported fields }
TCPServer serves as a base struct for all TCP service instances that listen on a Port.
func NewTCPServer ¶
func NewTCPServer(maxConsecutiveErrors, maxWorkers int, getListenerGetTask GetListenerGetTask) *TCPServer
NewTCPServer that will exit listen on the number of MaxConsecutiveErrors specified and use the number of workers specified to asynchronously process incoming connections.
func (*TCPServer) Dispatch ¶
func (server *TCPServer) Dispatch(task dispatcher.Task)
Dispatch a task using this TCPServer's worker pool.
func (*TCPServer) Listen ¶
Listen for incoming connection, wrap them using GetTask and execute them asynchronously.
func (*TCPServer) SetIdleTimeout ¶
SetIdleTimeout and on idle handler for this server