Documentation ¶
Index ¶
- Variables
- func APIErrToGRPC(err error) error
- func AsErrNotFound(msg string, args ...interface{}) error
- func AsValidationError(msg string, args ...interface{}) error
- func BindArgs(i interface{}, c echo.Context) error
- func BindPatch(i interface{}, c echo.Context) error
- func CORSWithTargetedOrigin(next echo.HandlerFunc) echo.HandlerFunc
- func EchoErrToGRPC(err error) (bool, error)
- func EffectiveLimit(limit int, offset int, total int) int
- func EffectiveOffset(reqOffset int, total int) (offset int)
- func EffectiveOffsetNLimit(reqOffset int, reqLimit int, totalItems int) (offset int, limit int)
- func GrpcErrToEcho(err error) (bool, error)
- func JSONErrorHandler(err error, c echo.Context)
- func Route(handler func(c echo.Context) (interface{}, error)) echo.HandlerFunc
- func WebSocketRoute(handler func(socket *websocket.Conn, c echo.Context) error) echo.HandlerFunc
- type Batch
- type BatchOfOne
- type BatchRequest
- type BatchResult
- type BatchStreamProcessor
- type FetchBatchFn
- type Filter
- type FilterOperation
- type MaybeInt
- type OnBatchFn
- type Pagination
- type TerminationCheckFn
Constants ¶
This section is empty.
Variables ¶
var ( // ErrInvalid is the inner error for errors that convert to a 400. Currently // only apiServer.askAtDefaultSystem respects this. ErrInvalid = errors.New("invalid arguments") // ErrNotFound is the inner error for errors that convert to a 404. ErrNotFound = errors.New("not found") // ErrNotImplemented is the inner error for errors that convert to a 501. ErrNotImplemented = errors.New("not implemented") // ErrAPIRemoved is an error to inform the client they are calling an old, removed API. ErrAPIRemoved = errors.New(`the API being called was removed, please ensure the client consuming the API is up to date and report a bug if the problem persists`) )
Functions ¶
func APIErrToGRPC ¶
APIErrToGRPC converts internal api error categories into grpc status.Errors.
func AsErrNotFound ¶
AsErrNotFound returns an error that wraps ErrNotFound, so that errors.Is can identify it.
func AsValidationError ¶
AsValidationError returns an error that wraps ErrInvalid, so that errors.Is can identify it.
func BindArgs ¶
func BindArgs(i interface{}, c echo.Context) error
BindArgs binds path and query parameters in the context to struct fields.
func BindPatch ¶
func BindPatch(i interface{}, c echo.Context) error
BindPatch binds the request body of PATCH requests to the provided interface.
func CORSWithTargetedOrigin ¶
func CORSWithTargetedOrigin(next echo.HandlerFunc) echo.HandlerFunc
CORSWithTargetedOrigin builds on labstack/echo CORS by dynamically setting the origin header to the request's origin.
func EchoErrToGRPC ¶
EchoErrToGRPC converts internal api error categories into grpc status.Errors.
func EffectiveLimit ¶
EffectiveLimit computes a hard limit based on the offset and total available items if there is a limit set. Input: non-negative offset.
func EffectiveOffset ¶
EffectiveOffset translated negative offsets into positive ones.
func EffectiveOffsetNLimit ¶
EffectiveOffsetNLimit chains EffectiveOffset and EffectiveLimit together.
func GrpcErrToEcho ¶
GrpcErrToEcho converts grpc status.Errors into internal api error categories.
func JSONErrorHandler ¶
func JSONErrorHandler(err error, c echo.Context)
JSONErrorHandler sends a JSON response with a single "message" key containing the error message.
func Route ¶
func Route(handler func(c echo.Context) (interface{}, error)) echo.HandlerFunc
Route returns an echo compatible handler for JSON requests.
func WebSocketRoute ¶
WebSocketRoute upgrades incoming requests to websocket requests.
Types ¶
type BatchOfOne ¶
type BatchOfOne struct {
Inner interface{}
}
BatchOfOne is a wrapper for a single log that implements Batch.
func ToBatchOfOne ¶
func ToBatchOfOne(x interface{}) BatchOfOne
ToBatchOfOne wraps a single entry as a BatchOfOne that implements Batch.
func (BatchOfOne) ForEach ¶
func (l BatchOfOne) ForEach(f func(interface{}) error) error
ForEach implements Batch.
type BatchRequest ¶
BatchRequest describes the parameters needed to target a subset of logs.
type BatchResult ¶
type BatchResult struct {
// contains filtered or unexported fields
}
BatchResult contains either a batch or an error.
func ErrBatchResult ¶
func ErrBatchResult(err error) BatchResult
ErrBatchResult returns a BatchResult with an error and no batch.
func OkBatchResult ¶
func OkBatchResult(b Batch) BatchResult
OkBatchResult returns a BatchResult with a valid batch and nil error.
func (*BatchResult) Batch ¶
func (r *BatchResult) Batch() Batch
Batch returns the inner batch or nil.
type BatchStreamProcessor ¶
type BatchStreamProcessor struct {
// contains filtered or unexported fields
}
BatchStreamProcessor is an actor that fetches batches and processes them. It handles common logic around limits, offsets and backpressure.
The type of batches produced by the FetchBatchFn must match those handled by the OnBatchFn or the actor will panic.
func NewBatchStreamProcessor ¶
func NewBatchStreamProcessor( req BatchRequest, fetcher FetchBatchFn, terminateCheck TerminationCheckFn, alwaysCheckTermination bool, batchWaitTime *time.Duration, batchMissWaitTime *time.Duration, ) *BatchStreamProcessor
NewBatchStreamProcessor creates a new BatchStreamProcessor.
func (*BatchStreamProcessor) Run ¶
func (p *BatchStreamProcessor) Run(ctx context.Context, res chan BatchResult)
Run runs the batch stream processor. There is an implicit assumption upstream that errors won't be sent forever, so after encountering an error in Run, we should log and continue or send and return.
type FetchBatchFn ¶
type FetchBatchFn func(BatchRequest) (Batch, error)
FetchBatchFn fetches returns a batch.
type Filter ¶
type Filter struct { Field string Operation FilterOperation Values interface{} }
Filter is a general representation for a filter provided to an API.
type FilterOperation ¶
type FilterOperation int
FilterOperation is an operation in a filter.
const ( // FilterOperationIn checks set membership. FilterOperationIn FilterOperation = iota // FilterOperationInOrNull checks membership or a NULL option. FilterOperationInOrNull // FilterOperationGreaterThan checks if the field is greater than a value. FilterOperationGreaterThan // FilterOperationLessThanEqual checks if the field is less than or equal to a value. FilterOperationLessThanEqual // FilterOperationStringContainment checks if the field contains a value as a substring. FilterOperationStringContainment )
type MaybeInt ¶
MaybeInt allows JSON users to distinguish between absent and null values. It should be used as a non-pointer value in structs. After unmarshaling, IsPresent will be true if the corresponding key is present, whether or not the value is null; Value will be nil or not, depending on the value.
Based on: https://www.calhoun.io/how-to-determine-if-a-json-key-has-been-set-to-null-or-not-provided/
func (*MaybeInt) UnmarshalJSON ¶
UnmarshalJSON unmarshals the given data, which should be an integer or null.
type Pagination ¶
Pagination contains resolved pagination indices.
func Paginate ¶
func Paginate(total, offset, limit int) (*Pagination, error)
Paginate calculates pagination values. Negative offsets denotes that offsets should be calculated from the end. Input offset: the number of entries you wish to skip.
type TerminationCheckFn ¶
TerminationCheckFn checks whether the log processing should stop or not.