This repository has been archived by the owner on Oct 9, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 63
/
Copy pathpublisher.go
52 lines (44 loc) · 1.65 KB
/
publisher.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
package implementations
import (
"context"
"github.com/lyft/flyteadmin/pkg/async/notifications/interfaces"
"github.com/NYTimes/gizmo/pubsub"
"github.com/golang/protobuf/proto"
"github.com/lyft/flytestdlib/logger"
"github.com/lyft/flytestdlib/promutils"
"github.com/prometheus/client_golang/prometheus"
)
type publisherSystemMetrics struct {
Scope promutils.Scope
PublishTotal prometheus.Counter
PublishError prometheus.Counter
}
// TODO: Add a counter that encompasses the publisher stats grouped by project and domain.
type Publisher struct {
pub pubsub.Publisher
systemMetrics publisherSystemMetrics
}
// The key is the notification type as defined as an enum.
func (p *Publisher) Publish(ctx context.Context, notificationType string, msg proto.Message) error {
p.systemMetrics.PublishTotal.Inc()
logger.Debugf(ctx, "Publishing the following message [%s]", msg.String())
err := p.pub.Publish(ctx, notificationType, msg)
if err != nil {
p.systemMetrics.PublishError.Inc()
logger.Errorf(ctx, "Failed to publish a message with key [%s] and message [%s] and error: %v", notificationType, msg.String(), err)
}
return err
}
func newPublisherSystemMetrics(scope promutils.Scope) publisherSystemMetrics {
return publisherSystemMetrics{
Scope: scope,
PublishTotal: scope.MustNewCounter("publish_total", "overall count of publish messages"),
PublishError: scope.MustNewCounter("publish_errors", "count of publish errors"),
}
}
func NewPublisher(pub pubsub.Publisher, scope promutils.Scope) interfaces.Publisher {
return &Publisher{
pub: pub,
systemMetrics: newPublisherSystemMetrics(scope.NewSubScope("publisher")),
}
}