From 0e4c3d0f94e87556c4f6c5595bfb71004a25ca7e Mon Sep 17 00:00:00 2001 From: ZeynabRezaei <72091463+ZeynabRezaei@users.noreply.github.com> Date: Sun, 7 Apr 2024 14:46:48 +0330 Subject: [PATCH] add webservice label to metrics --- pkg/auth/metrics.go | 25 +++++++++++++++++-------- pkg/auth/server.go | 2 ++ 2 files changed, 19 insertions(+), 8 deletions(-) diff --git a/pkg/auth/metrics.go b/pkg/auth/metrics.go index 10c8d74..afcca39 100644 --- a/pkg/auth/metrics.go +++ b/pkg/auth/metrics.go @@ -13,6 +13,7 @@ const ( HasUpstreamAuth = "upstream_auth_enabled" ObjectKindLabel = "kind" WithDownstreamDeadlineLabel = "with_downstream_deadline" + WebserviceLabel = "webservice" MetricsKindSecret = "secret" MetricsKindWebservice = "webservice" @@ -33,7 +34,7 @@ var ( Name: "check_request_count", Help: "CheckRequest count", }, - []string{CerberusReasonLabel, CheckRequestVersionLabel, HasUpstreamAuth}, + []string{CerberusReasonLabel, CheckRequestVersionLabel, HasUpstreamAuth, WebserviceLabel}, ) reqLatency = prometheus.NewHistogramVec( @@ -42,7 +43,7 @@ var ( Help: "CheckRequest durations (response times)", Buckets: DurationBuckets, }, - []string{CerberusReasonLabel, CheckRequestVersionLabel, HasUpstreamAuth}, + []string{CerberusReasonLabel, CheckRequestVersionLabel, HasUpstreamAuth, WebserviceLabel}, ) cacheUpdateCount = prometheus.NewCounter( @@ -128,7 +129,7 @@ var ( Name: "upstream_auth_failed_requests_total", Help: "Total number of failed UpstreamAuth requests", }, - []string{"with_downstream_deadline"}, + []string{WithDownstreamDeadlineLabel}, ) ) @@ -149,7 +150,7 @@ func init() { upstreamAuthFailedRequests, ) } - +///server func AddReasonLabel(labels prometheus.Labels, reason CerberusReason) prometheus.Labels { if labels == nil { labels = prometheus.Labels{} @@ -157,7 +158,7 @@ func AddReasonLabel(labels prometheus.Labels, reason CerberusReason) prometheus. labels[CerberusReasonLabel] = string(reason) return labels } - +///auth-cache func AddKindLabel(labels prometheus.Labels, kind string) prometheus.Labels { if labels == nil { labels = prometheus.Labels{} @@ -165,7 +166,7 @@ func AddKindLabel(labels prometheus.Labels, kind string) prometheus.Labels { labels[ObjectKindLabel] = kind return labels } - +///auth func AddStatusLabel(labels prometheus.Labels, status int) prometheus.Labels { if labels == nil { labels = prometheus.Labels{} @@ -173,7 +174,7 @@ func AddStatusLabel(labels prometheus.Labels, status int) prometheus.Labels { labels[StatusCode] = strconv.Itoa(status) return labels } - +///server func AddUpstreamAuthLabel(labels prometheus.Labels, hasUpstreamAuth string) prometheus.Labels { if labels == nil { labels = prometheus.Labels{} @@ -181,7 +182,7 @@ func AddUpstreamAuthLabel(labels prometheus.Labels, hasUpstreamAuth string) prom labels[HasUpstreamAuth] = hasUpstreamAuth return labels } - +//auth func AddWithDownstreamDeadlineLabel(labels prometheus.Labels, hasDeadline bool) prometheus.Labels { if labels == nil { labels = prometheus.Labels{} @@ -193,3 +194,11 @@ func AddWithDownstreamDeadlineLabel(labels prometheus.Labels, hasDeadline bool) } return labels } +///server +func AddWebserviceLabel(labels prometheus.Labels, wsvc string) prometheus.Labels { + if labels == nil { + labels = prometheus.Labels{} + } + labels[WebserviceLabel] = wsvc + return labels +} \ No newline at end of file diff --git a/pkg/auth/server.go b/pkg/auth/server.go index 574f052..2179541 100644 --- a/pkg/auth/server.go +++ b/pkg/auth/server.go @@ -47,6 +47,7 @@ func (a *authV2) Check(ctx context.Context, check *CheckRequestV2) (*CheckRespon reason := CerberusReason(response.Response.Header.Get(CerberusHeaderReasonHeader)) labels := AddReasonLabel(nil, reason) labels = AddUpstreamAuthLabel(labels, request.Context[HasUpstreamAuth]) + labels = AddWebserviceLabel(labels, string(CerberusHeaderWebservice)) labels[CheckRequestVersionLabel] = MetricsCheckRequestVersion2 reqCount.With(labels).Inc() reqLatency.With(labels).Observe(time.Since(reqStartTime).Seconds()) @@ -73,6 +74,7 @@ func (a *authV3) Check(ctx context.Context, check *CheckRequestV3) (*CheckRespon reason := CerberusReason(response.Response.Header.Get(CerberusHeaderReasonHeader)) labels := AddReasonLabel(nil, reason) labels = AddUpstreamAuthLabel(labels, request.Context[HasUpstreamAuth]) + labels = AddWebserviceLabel(labels, string(CerberusHeaderWebservice)) labels[CheckRequestVersionLabel] = MetricsCheckRequestVersion3 reqCount.With(labels).Inc() reqLatency.With(labels).Observe(time.Since(reqStartTime).Seconds())