package prometheus import ( "context" "fmt" "time" "github.com/influxdata/platform" "github.com/prometheus/client_golang/prometheus" ) // AuthorizationService manages authorizations. type AuthorizationService struct { requestCount *prometheus.CounterVec requestDuration *prometheus.HistogramVec AuthorizationService platform.AuthorizationService } // NewAuthorizationService creates an instance of AuthorizationService. func NewAuthorizationService() *AuthorizationService { // TODO: what to make these values namespace := "auth" subsystem := "prometheus" s := &AuthorizationService{ requestCount: prometheus.NewCounterVec(prometheus.CounterOpts{ Namespace: namespace, Subsystem: subsystem, Name: "requests_total", Help: "Number of http requests received", }, []string{"method", "error"}), requestDuration: prometheus.NewHistogramVec(prometheus.HistogramOpts{ Namespace: namespace, Subsystem: subsystem, Name: "request_duration_seconds", Help: "Time taken to respond to HTTP request", // TODO(desa): determine what spacing these buckets should have. Buckets: prometheus.ExponentialBuckets(0.001, 1.5, 25), }, []string{"method", "error"}), } return s } // FindAuthorizationByID returns an authorization given a id, records function call latency, and counts function calls. func (s *AuthorizationService) FindAuthorizationByID(ctx context.Context, id platform.ID) (a *platform.Authorization, err error) { defer func(start time.Time) { labels := prometheus.Labels{ "method": "FindAuthorizationByID", "error": fmt.Sprint(err != nil), } s.requestCount.With(labels).Add(1) s.requestDuration.With(labels).Observe(time.Since(start).Seconds()) }(time.Now()) return s.AuthorizationService.FindAuthorizationByID(ctx, id) } // FindAuthorizationByToken returns an authorization given a token, records function call latency, and counts function calls. func (s *AuthorizationService) FindAuthorizationByToken(ctx context.Context, t string) (a *platform.Authorization, err error) { defer func(start time.Time) { labels := prometheus.Labels{ "method": "FindAuthorizationByToken", "error": fmt.Sprint(err != nil), } s.requestCount.With(labels).Add(1) s.requestDuration.With(labels).Observe(time.Since(start).Seconds()) }(time.Now()) return s.AuthorizationService.FindAuthorizationByToken(ctx, t) } // FindAuthorizations returns authorizations given a filter, records function call latency, and counts function calls. func (s *AuthorizationService) FindAuthorizations(ctx context.Context, filter platform.AuthorizationFilter, opt ...platform.FindOptions) (as []*platform.Authorization, i int, err error) { defer func(start time.Time) { labels := prometheus.Labels{ "method": "FindAuthorizations", "error": fmt.Sprint(err != nil), } s.requestCount.With(labels).Add(1) s.requestDuration.With(labels).Observe(time.Since(start).Seconds()) }(time.Now()) return s.AuthorizationService.FindAuthorizations(ctx, filter, opt...) } // CreateAuthorization creates an authorization, records function call latency, and counts function calls. func (s *AuthorizationService) CreateAuthorization(ctx context.Context, a *platform.Authorization) (err error) { defer func(start time.Time) { labels := prometheus.Labels{ "method": "CreateAuthorization", "error": fmt.Sprint(err != nil), } s.requestCount.With(labels).Add(1) s.requestDuration.With(labels).Observe(time.Since(start).Seconds()) }(time.Now()) return s.AuthorizationService.CreateAuthorization(ctx, a) } // DeleteAuthorization deletes an authorization, records function call latency, and counts function calls. func (s *AuthorizationService) DeleteAuthorization(ctx context.Context, id platform.ID) (err error) { defer func(start time.Time) { labels := prometheus.Labels{ "method": "DeleteAuthorization", "error": fmt.Sprint(err != nil), } s.requestCount.With(labels).Add(1) s.requestDuration.With(labels).Observe(time.Since(start).Seconds()) }(time.Now()) return s.AuthorizationService.DeleteAuthorization(ctx, id) } // SetAuthorizationStatus updates the status of the authorization. Useful // for setting an authorization to inactive or active. func (s *AuthorizationService) SetAuthorizationStatus(ctx context.Context, id platform.ID, status platform.Status) (err error) { defer func(start time.Time) { labels := prometheus.Labels{ "method": "setAuthorizationStatus", "error": fmt.Sprint(err != nil), } s.requestCount.With(labels).Add(1) s.requestDuration.With(labels).Observe(time.Since(start).Seconds()) }(time.Now()) return s.AuthorizationService.SetAuthorizationStatus(ctx, id, status) } // PrometheusCollectors returns all authorization service prometheus collectors. func (s *AuthorizationService) PrometheusCollectors() []prometheus.Collector { return []prometheus.Collector{ s.requestCount, s.requestDuration, } }