Documentation ¶
Overview ¶
Package manager creates and manages multiple streams, providing an API for performing CRUD operations.
Index ¶
- Variables
- func LoadStreamConfigsFromDirectory(replaceEnvVars bool, dir string) (map[string]stream.Config, error)
- func OptAddProcessors(procs ...StreamProcConstructorFunc) func(*Type)
- func OptSetAPITimeout(tout time.Duration) func(*Type)
- func OptSetLogger(log log.Modular) func(*Type)
- func OptSetManager(mgr types.Manager) func(*Type)
- func OptSetStats(stats metrics.Type) func(*Type)
- type ConfigSet
- type NamespacedManager
- func (n *NamespacedManager) GetCache(name string) (types.Cache, error)
- func (n *NamespacedManager) GetCondition(name string) (types.Condition, error)
- func (n *NamespacedManager) GetPipe(name string) (<-chan types.Transaction, error)
- func (n *NamespacedManager) GetPlugin(name string) (interface{}, error)
- func (n *NamespacedManager) GetRateLimit(name string) (types.RateLimit, error)
- func (n *NamespacedManager) GetUnderlying() types.Manager
- func (n *NamespacedManager) RegisterEndpoint(p, desc string, h http.HandlerFunc)
- func (n *NamespacedManager) SetPipe(name string, t <-chan types.Transaction)
- func (n *NamespacedManager) UnsetPipe(name string, t <-chan types.Transaction)
- type StreamProcConstructorFunc
- type StreamStatus
- type Type
- func (m *Type) Create(id string, conf stream.Config) error
- func (m *Type) Delete(id string, timeout time.Duration) error
- func (m *Type) HandleStreamCRUD(w http.ResponseWriter, r *http.Request)
- func (m *Type) HandleStreamStats(w http.ResponseWriter, r *http.Request)
- func (m *Type) HandleStreamsCRUD(w http.ResponseWriter, r *http.Request)
- func (m *Type) Read(id string) (*StreamStatus, error)
- func (m *Type) Stop(timeout time.Duration) error
- func (m *Type) Update(id string, conf stream.Config, timeout time.Duration) error
Constants ¶
This section is empty.
Variables ¶
var ( ErrStreamExists = errors.New("stream already exists") ErrStreamDoesNotExist = errors.New("stream does not exist") )
Errors specifically returned by a stream manager.
Functions ¶
func LoadStreamConfigsFromDirectory ¶ added in v0.13.0
func LoadStreamConfigsFromDirectory(replaceEnvVars bool, dir string) (map[string]stream.Config, error)
LoadStreamConfigsFromDirectory reads a map of stream ids to configurations by walking a directory of .json and .yaml files.
func OptAddProcessors ¶ added in v0.13.0
func OptAddProcessors(procs ...StreamProcConstructorFunc) func(*Type)
OptAddProcessors adds processor constructors that will be called for every new stream and attached to the processor pipelines. The constructor is given the name of the stream as an argument.
func OptSetAPITimeout ¶ added in v0.12.0
OptSetAPITimeout sets the default timeout for HTTP API requests.
func OptSetLogger ¶
OptSetLogger sets the logging output to be used by the manager and all child streams.
func OptSetManager ¶
OptSetManager sets the service manager to be used by the stream manager and all child streams.
func OptSetStats ¶
OptSetStats sets the metrics aggregator to be used by the manager and all child streams.
Types ¶
type ConfigSet ¶ added in v0.13.0
ConfigSet is a map of stream configurations mapped by ID, which can be YAML parsed without losing default values inside the stream configs.
func (ConfigSet) UnmarshalYAML ¶ added in v0.13.0
UnmarshalYAML ensures that when parsing configs that are in a map or slice the default values are still applied.
type NamespacedManager ¶ added in v0.34.9
type NamespacedManager struct {
// contains filtered or unexported fields
}
NamespacedManager is a types.Manager implementation that wraps an underlying implementation with a namespace that prefixes registered endpoints, etc.
func (*NamespacedManager) GetCache ¶ added in v0.34.9
func (n *NamespacedManager) GetCache(name string) (types.Cache, error)
GetCache attempts to find a service wide cache by its name.
func (*NamespacedManager) GetCondition ¶ added in v0.34.9
func (n *NamespacedManager) GetCondition(name string) (types.Condition, error)
GetCondition attempts to find a service wide condition by its name.
func (*NamespacedManager) GetPipe ¶ added in v0.34.9
func (n *NamespacedManager) GetPipe(name string) (<-chan types.Transaction, error)
GetPipe returns a named pipe transaction channel.
func (*NamespacedManager) GetPlugin ¶ added in v1.2.0
func (n *NamespacedManager) GetPlugin(name string) (interface{}, error)
GetPlugin attempts to find a service wide resource plugin by its name.
func (*NamespacedManager) GetRateLimit ¶ added in v0.34.9
func (n *NamespacedManager) GetRateLimit(name string) (types.RateLimit, error)
GetRateLimit attempts to find a service wide rate limit by its name.
func (*NamespacedManager) GetUnderlying ¶ added in v0.34.9
func (n *NamespacedManager) GetUnderlying() types.Manager
GetUnderlying returns the underlying types.Manager implementation.
func (*NamespacedManager) RegisterEndpoint ¶ added in v0.34.9
func (n *NamespacedManager) RegisterEndpoint(p, desc string, h http.HandlerFunc)
RegisterEndpoint registers a server wide HTTP endpoint.
func (*NamespacedManager) SetPipe ¶ added in v0.34.9
func (n *NamespacedManager) SetPipe(name string, t <-chan types.Transaction)
SetPipe sets a named pipe.
func (*NamespacedManager) UnsetPipe ¶ added in v0.34.9
func (n *NamespacedManager) UnsetPipe(name string, t <-chan types.Transaction)
UnsetPipe unsets a named pipe.
type StreamProcConstructorFunc ¶ added in v0.13.0
StreamProcConstructorFunc is a closure type that constructs a processor type for new streams, where the id of the stream is provided as an argument.
type StreamStatus ¶
type StreamStatus struct {
// contains filtered or unexported fields
}
StreamStatus tracks a stream along with information regarding its internals.
func NewStreamStatus ¶ added in v0.15.3
func NewStreamStatus( conf stream.Config, strm *stream.Type, logger log.Modular, stats *metrics.Local, ) *StreamStatus
NewStreamStatus creates a new StreamStatus.
func (*StreamStatus) Config ¶
func (s *StreamStatus) Config() stream.Config
Config returns the configuration of the stream.
func (*StreamStatus) IsRunning ¶ added in v0.15.3
func (s *StreamStatus) IsRunning() bool
IsRunning returns a boolean indicating whether the stream is currently running.
func (*StreamStatus) Logger ¶ added in v0.15.3
func (s *StreamStatus) Logger() log.Modular
Logger returns the logger of the stream.
func (*StreamStatus) Metrics ¶ added in v0.15.3
func (s *StreamStatus) Metrics() *metrics.Local
Metrics returns a metrics aggregator of the stream.
func (*StreamStatus) Uptime ¶
func (s *StreamStatus) Uptime() time.Duration
Uptime returns a time.Duration indicating the current uptime of the stream.
type Type ¶
type Type struct {
// contains filtered or unexported fields
}
Type manages a collection of streams, providing APIs for CRUD operations on the streams.
func (*Type) Create ¶
Create attempts to construct and run a new stream under a unique ID. If the ID already exists an error is returned.
func (*Type) Delete ¶
Delete attempts to stop and remove a stream by its ID. Returns an error if the stream was not found, or if clean shutdown fails in the specified period of time.
func (*Type) HandleStreamCRUD ¶ added in v0.13.0
func (m *Type) HandleStreamCRUD(w http.ResponseWriter, r *http.Request)
HandleStreamCRUD is an http.HandleFunc for performing CRUD operations on individual streams.
func (*Type) HandleStreamStats ¶ added in v0.15.3
func (m *Type) HandleStreamStats(w http.ResponseWriter, r *http.Request)
HandleStreamStats is an http.HandleFunc for obtaining metrics for a stream.
func (*Type) HandleStreamsCRUD ¶ added in v0.13.0
func (m *Type) HandleStreamsCRUD(w http.ResponseWriter, r *http.Request)
HandleStreamsCRUD is an http.HandleFunc for returning maps of active benthos streams by their id, status and uptime or overwriting the entire set of streams.
func (*Type) Read ¶
func (m *Type) Read(id string) (*StreamStatus, error)
Read attempts to obtain the status of a managed stream. Returns an error if the stream does not exist.