Documentation ¶
Overview ¶
Package manager implements the types.Manager interface used for creating and sharing resources across a Benthos service.
Index ¶
- func AddExamples(c *Config)
- func DocumentPlugin(typeString, description string, configSanitiser PluginConfigSanitiser)
- func PluginDescriptions() string
- func RegisterPlugin(typeString string, configConstructor PluginConfigConstructor, ...)
- func SanitiseConfig(conf Config) (interface{}, error)
- type APIReg
- type Config
- type PluginConfig
- type PluginConfigConstructor
- type PluginConfigSanitiser
- type PluginConstructor
- type Type
- func (t *Type) CloseAsync()
- func (t *Type) GetCache(name string) (types.Cache, error)
- func (t *Type) GetCondition(name string) (types.Condition, error)
- func (t *Type) GetPipe(name string) (<-chan types.Transaction, error)
- func (t *Type) GetPlugin(name string) (interface{}, error)
- func (t *Type) GetRateLimit(name string) (types.RateLimit, error)
- func (t *Type) RegisterEndpoint(path, desc string, h http.HandlerFunc)
- func (t *Type) SetPipe(name string, tran <-chan types.Transaction)
- func (t *Type) UnsetPipe(name string, tran <-chan types.Transaction)
- func (t *Type) WaitForClose(timeout time.Duration) error
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AddExamples ¶ added in v0.16.2
func AddExamples(c *Config)
AddExamples inserts example caches and conditions if none exist in the config.
func DocumentPlugin ¶ added in v1.2.0
func DocumentPlugin( typeString, description string, configSanitiser PluginConfigSanitiser, )
DocumentPlugin adds a description and an optional configuration sanitiser function to the definition of a registered plugin. This improves the documentation generated by PluginDescriptions.
func PluginDescriptions ¶ added in v1.2.0
func PluginDescriptions() string
PluginDescriptions generates and returns a markdown formatted document listing each registered plugin and an example configuration for it.
func RegisterPlugin ¶ added in v1.2.0
func RegisterPlugin( typeString string, configConstructor PluginConfigConstructor, constructor PluginConstructor, )
RegisterPlugin registers a plugin by a unique name so that it can be constucted similar to regular resources. A constructor for both the plugin itself as well as its configuration struct must be provided.
A constructed resource plugin can be any type and is wrapped as an interface{} type.
func SanitiseConfig ¶ added in v0.16.2
SanitiseConfig creates a sanitised version of a manager config.
Types ¶
type APIReg ¶
type APIReg interface {
RegisterEndpoint(path, desc string, h http.HandlerFunc)
}
APIReg is an interface representing an API builder.
type Config ¶
type Config struct { Caches map[string]cache.Config `json:"caches" yaml:"caches"` Conditions map[string]condition.Config `json:"conditions" yaml:"conditions"` RateLimits map[string]ratelimit.Config `json:"rate_limits" yaml:"rate_limits"` Plugins map[string]PluginConfig `json:"plugins,omitempty" yaml:"plugins,omitempty"` }
Config contains all configuration fields for a Benthos service manager.
type PluginConfig ¶ added in v1.2.0
type PluginConfig struct { Type string `json:"type" yaml:"type"` Plugin interface{} `json:"plugin" yaml:"plugin"` }
PluginConfig is a config struct representing a resource plugin.
func (*PluginConfig) UnmarshalJSON ¶ added in v1.2.0
func (p *PluginConfig) UnmarshalJSON(bytes []byte) error
UnmarshalJSON ensures that when parsing configs that are in a map or slice the default values are still applied.
func (*PluginConfig) UnmarshalYAML ¶ added in v1.2.0
func (p *PluginConfig) UnmarshalYAML(unmarshal func(interface{}) error) error
UnmarshalYAML ensures that when parsing configs that are in a map or slice the default values are still applied.
type PluginConfigConstructor ¶ added in v1.2.0
type PluginConfigConstructor func() interface{}
PluginConfigConstructor is a func that returns a pointer to a new and fully populated configuration struct for a plugin type. It is valid to return a pointer to an empty struct (&struct{}{}) if no configuration fields are needed.
type PluginConfigSanitiser ¶ added in v1.2.0
type PluginConfigSanitiser func(conf interface{}) interface{}
PluginConfigSanitiser is a function that takes a configuration object for a plugin and returns a sanitised (minimal) version of it for printing in examples and plugin documentation.
This function is useful for when a plugins configuration struct is very large and complex, but can sometimes be expressed in a more concise way without losing the original intent.
type PluginConstructor ¶ added in v1.2.0
type PluginConstructor func( config interface{}, manager types.Manager, logger log.Modular, metrics metrics.Type, ) (interface{}, error)
PluginConstructor is a func that constructs a Benthos resource plugin. These are shareable resources that can be accessed by any other type within Benthos.
The configuration object will be the result of the PluginConfigConstructor after overlaying the user configuration.
type Type ¶
type Type struct {
// contains filtered or unexported fields
}
Type is an implementation of types.Manager, which is expected by Benthos components that need to register service wide behaviours such as HTTP endpoints and event listeners, and obtain service wide shared resources such as caches and labelled conditions.
func New ¶
New returns an instance of manager.Type, which can be shared amongst components and logical threads of a Benthos service.
func (*Type) CloseAsync ¶ added in v1.2.1
func (t *Type) CloseAsync()
CloseAsync triggers the shut down of all resource types that implement the lifetime interface types.Closable. TODO: Simplify this in V2.
func (*Type) GetCondition ¶
GetCondition attempts to find a service wide condition by its name.
func (*Type) GetPipe ¶ added in v0.15.4
func (t *Type) GetPipe(name string) (<-chan types.Transaction, error)
GetPipe attempts to obtain and return a named output Pipe
func (*Type) GetPlugin ¶ added in v1.2.0
GetPlugin attempts to find a service wide resource plugin by its name.
func (*Type) GetRateLimit ¶ added in v0.31.3
GetRateLimit attempts to find a service wide rate limit by its name.
func (*Type) RegisterEndpoint ¶
func (t *Type) RegisterEndpoint(path, desc string, h http.HandlerFunc)
RegisterEndpoint registers a server wide HTTP endpoint.
func (*Type) SetPipe ¶ added in v0.15.4
func (t *Type) SetPipe(name string, tran <-chan types.Transaction)
SetPipe registers a new transaction chan to a named pipe.