Documentation ¶
Index ¶
- Variables
- func GetMetrics(sources []DataSource, aggregated bool) error
- func GetMetricsLevelFromPromCfg(prom *csconfig.PrometheusCfg) int
- func StartAcquisition(ctx context.Context, sources []DataSource, output chan types.Event, ...) error
- type DataSource
- func DataSourceConfigure(commonConfig configuration.DataSourceCommonCfg, metricsLevel int) (*DataSource, error)
- func GetDataSourceIface(dataSourceType string) (DataSource, error)
- func LoadAcquisitionFromDSN(dsn string, labels map[string]string, transformExpr string) ([]DataSource, error)
- func LoadAcquisitionFromFile(config *csconfig.CrowdsecServiceCfg, prom *csconfig.PrometheusCfg) ([]DataSource, error)
- type DataSourceUnavailableError
Constants ¶
This section is empty.
Variables ¶
View Source
var ( // We declare everything here so we can tell if they are unsupported, or excluded from the build AcquisitionSources = map[string]func() DataSource{} )
Functions ¶
func GetMetrics ¶ added in v1.1.0
func GetMetrics(sources []DataSource, aggregated bool) error
func GetMetricsLevelFromPromCfg ¶ added in v1.6.1
func GetMetricsLevelFromPromCfg(prom *csconfig.PrometheusCfg) int
func StartAcquisition ¶ added in v1.0.0
Types ¶
type DataSource ¶ added in v1.0.0
type DataSource interface { GetMetrics() []prometheus.Collector // Returns pointers to metrics that are managed by the module GetAggregMetrics() []prometheus.Collector // Returns pointers to metrics that are managed by the module (aggregated mode, limits cardinality) UnmarshalConfig([]byte) error // Decode and pre-validate the YAML datasource - anything that can be checked before runtime Configure([]byte, *log.Entry, int) error // Complete the YAML datasource configuration and perform runtime checks. ConfigureByDSN(string, map[string]string, *log.Entry, string) error // Configure the datasource GetMode() string // Get the mode (TAIL, CAT or SERVER) GetName() string // Get the name of the module OneShotAcquisition(context.Context, chan types.Event, *tomb.Tomb) error // Start one shot acquisition(eg, cat a file) StreamingAcquisition(context.Context, chan types.Event, *tomb.Tomb) error // Start live acquisition (eg, tail a file) CanRun() error // Whether the datasource can run or not (eg, journalctl on BSD is a non-sense) GetUuid() string // Get the unique identifier of the datasource Dump() interface{} }
The interface each datasource must implement
func DataSourceConfigure ¶ added in v1.0.0
func DataSourceConfigure(commonConfig configuration.DataSourceCommonCfg, metricsLevel int) (*DataSource, error)
DataSourceConfigure creates and returns a DataSource object from a configuration, if the configuration is not valid it returns an error. If the datasource can't be run (eg. journalctl not available), it still returns an error which can be checked for the appropriate action.
func GetDataSourceIface ¶ added in v1.1.0
func GetDataSourceIface(dataSourceType string) (DataSource, error)
func LoadAcquisitionFromDSN ¶ added in v1.1.0
func LoadAcquisitionFromFile ¶ added in v1.0.0
func LoadAcquisitionFromFile(config *csconfig.CrowdsecServiceCfg, prom *csconfig.PrometheusCfg) ([]DataSource, error)
LoadAcquisitionFromFile unmarshals the configuration item and checks its availability
type DataSourceUnavailableError ¶ added in v1.5.3
type DataSourceUnavailableError struct {}
func (*DataSourceUnavailableError) Error ¶ added in v1.5.3
func (e *DataSourceUnavailableError) Error() string
func (*DataSourceUnavailableError) Unwrap ¶ added in v1.5.3
func (e *DataSourceUnavailableError) Unwrap() error
Source Files ¶
Click to show internal directories.
Click to hide internal directories.