123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 |
- // Copyright The OpenTelemetry Authors
- // SPDX-License-Identifier: Apache-2.0
- package azureeventhubreceiver // import "github.com/open-telemetry/opentelemetry-collector-contrib/receiver/azureeventhubreceiver"
- import (
- "context"
- "errors"
- "fmt"
- eventhub "github.com/Azure/azure-event-hubs-go/v3"
- "go.opentelemetry.io/collector/component"
- "go.opentelemetry.io/collector/consumer"
- "go.opentelemetry.io/collector/pdata/plog"
- "go.opentelemetry.io/collector/pdata/pmetric"
- "go.opentelemetry.io/collector/receiver"
- "go.opentelemetry.io/collector/receiver/receiverhelper"
- "go.uber.org/zap"
- "github.com/open-telemetry/opentelemetry-collector-contrib/receiver/azureeventhubreceiver/internal/metadata"
- )
- type dataConsumer interface {
- consume(ctx context.Context, event *eventhub.Event) error
- setNextLogsConsumer(nextLogsConsumer consumer.Logs)
- setNextMetricsConsumer(nextLogsConsumer consumer.Metrics)
- }
- type eventLogsUnmarshaler interface {
- UnmarshalLogs(event *eventhub.Event) (plog.Logs, error)
- }
- type eventMetricsUnmarshaler interface {
- UnmarshalMetrics(event *eventhub.Event) (pmetric.Metrics, error)
- }
- type eventhubReceiver struct {
- eventHandler eventHandler
- dataType component.Type
- logger *zap.Logger
- logsUnmarshaler eventLogsUnmarshaler
- metricsUnmarshaler eventMetricsUnmarshaler
- nextLogsConsumer consumer.Logs
- nextMetricsConsumer consumer.Metrics
- obsrecv *receiverhelper.ObsReport
- }
- func (receiver *eventhubReceiver) Start(ctx context.Context, host component.Host) error {
- err := receiver.eventHandler.run(ctx, host)
- return err
- }
- func (receiver *eventhubReceiver) Shutdown(ctx context.Context) error {
- return receiver.eventHandler.close(ctx)
- }
- func (receiver *eventhubReceiver) setNextLogsConsumer(nextLogsConsumer consumer.Logs) {
- receiver.nextLogsConsumer = nextLogsConsumer
- }
- func (receiver *eventhubReceiver) setNextMetricsConsumer(nextMetricsConsumer consumer.Metrics) {
- receiver.nextMetricsConsumer = nextMetricsConsumer
- }
- func (receiver *eventhubReceiver) consume(ctx context.Context, event *eventhub.Event) error {
- switch receiver.dataType {
- case component.DataTypeLogs:
- return receiver.consumeLogs(ctx, event)
- case component.DataTypeMetrics:
- return receiver.consumeMetrics(ctx, event)
- case component.DataTypeTraces:
- fallthrough
- default:
- return fmt.Errorf("invalid data type: %v", receiver.dataType)
- }
- }
- func (receiver *eventhubReceiver) consumeLogs(ctx context.Context, event *eventhub.Event) error {
- if receiver.nextLogsConsumer == nil {
- return nil
- }
- if receiver.logsUnmarshaler == nil {
- return errors.New("unable to unmarshal logs with configured format")
- }
- logsContext := receiver.obsrecv.StartLogsOp(ctx)
- logs, err := receiver.logsUnmarshaler.UnmarshalLogs(event)
- if err != nil {
- return fmt.Errorf("failed to unmarshal logs: %w", err)
- }
- receiver.logger.Debug("Log Records", zap.Any("logs", logs))
- err = receiver.nextLogsConsumer.ConsumeLogs(logsContext, logs)
- receiver.obsrecv.EndLogsOp(logsContext, metadata.Type, 1, err)
- return err
- }
- func (receiver *eventhubReceiver) consumeMetrics(ctx context.Context, event *eventhub.Event) error {
- if receiver.nextMetricsConsumer == nil {
- return nil
- }
- if receiver.metricsUnmarshaler == nil {
- return errors.New("unable to unmarshal metrics with configured format")
- }
- metricsContext := receiver.obsrecv.StartMetricsOp(ctx)
- metrics, err := receiver.metricsUnmarshaler.UnmarshalMetrics(event)
- if err != nil {
- return fmt.Errorf("failed to unmarshal metrics: %w", err)
- }
- receiver.logger.Debug("Metric Records", zap.Any("metrics", metrics))
- err = receiver.nextMetricsConsumer.ConsumeMetrics(metricsContext, metrics)
- receiver.obsrecv.EndMetricsOp(metricsContext, metadata.Type, 1, err)
- return err
- }
- func newReceiver(
- receiverType component.Type,
- logsUnmarshaler eventLogsUnmarshaler,
- metricsUnmarshaler eventMetricsUnmarshaler,
- eventHandler eventHandler,
- settings receiver.CreateSettings,
- ) (component.Component, error) {
- obsrecv, err := receiverhelper.NewObsReport(receiverhelper.ObsReportSettings{
- ReceiverID: settings.ID,
- Transport: "event",
- ReceiverCreateSettings: settings,
- })
- if err != nil {
- return nil, err
- }
- eventhubReceiver := &eventhubReceiver{
- dataType: receiverType,
- eventHandler: eventHandler,
- logger: settings.Logger,
- logsUnmarshaler: logsUnmarshaler,
- metricsUnmarshaler: metricsUnmarshaler,
- obsrecv: obsrecv,
- }
- eventHandler.setDataConsumer(eventhubReceiver)
- return eventhubReceiver, nil
- }
|