forked from newrelic/opentelemetry-collector-components
/
factory.go
68 lines (57 loc) · 1.78 KB
/
factory.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
// Copyright New Relic Corporation. All rights reserved.
// SPDX-License-Identifier: Apache-2.0
package apmconnector // import "apmconnector"
//go:generate mdatagen metadata.yaml
import (
"context"
"go.opentelemetry.io/collector/component"
"go.opentelemetry.io/collector/connector"
"go.opentelemetry.io/collector/consumer"
)
// FIXME copying this from the metadata/generated_status to be able to build the component externally
const (
Type = "newrelicapm"
TracesToMetricsStability = component.StabilityLevelDevelopment
TracesToLogsStability = component.StabilityLevelDevelopment
)
// NewFactory returns a ConnectorFactory.
func NewFactory() connector.Factory {
return connector.NewFactory(
Type,
createDefaultConfig,
connector.WithTracesToMetrics(createTracesToMetrics, TracesToMetricsStability),
connector.WithTracesToLogs(createTracesToLogs, TracesToLogsStability),
)
}
// createDefaultConfig creates the default configuration.
func createDefaultConfig() component.Config {
return &Config{}
}
// createTracesToMetrics creates a traces to metrics connector based on provided config.
func createTracesToMetrics(
_ context.Context,
set connector.CreateSettings,
cfg component.Config,
nextConsumer consumer.Metrics,
) (connector.Traces, error) {
c := cfg.(*Config)
return &ApmMetricConnector{
config: c,
metricsConsumer: nextConsumer,
logger: set.Logger,
}, nil
}
// createTracesToLogs creates a traces to logs connector based on provided config.
func createTracesToLogs(
_ context.Context,
set connector.CreateSettings,
cfg component.Config,
nextConsumer consumer.Logs,
) (connector.Traces, error) {
c := cfg.(*Config)
return &ApmLogConnector{
config: c,
logsConsumer: nextConsumer,
logger: set.Logger,
}, nil
}