diff options
| author | 2023-11-20 17:43:55 +0200 | |
|---|---|---|
| committer | 2023-11-20 16:43:55 +0100 | |
| commit | 1ba3e14b36c8f00475bdd41cd4a487ef7636836e (patch) | |
| tree | 17405b2de75bb6faaefb9bbfc6487fd7a5efc35a /vendor/github.com/technologize/otel-go-contrib/otelginmetrics/config.go | |
| parent | [bugfix] self-referencing collection pages for status replies (#2364) (diff) | |
| download | gotosocial-1ba3e14b36c8f00475bdd41cd4a487ef7636836e.tar.xz | |
[feature] Initial Prometheus metrics implementation (#2334)
* feat: Initial OTEL metrics
* docs: add metrics documentation
* fix: metrics endpoint conditional check
* feat: metrics endpoint basic auth
* fix: make metrics-auth-enabled default false
* fix: go fmt helpers.gen.go
* fix: add metric-related env vars to envparsing.sh
* fix: metrics docs
* fix: metrics related stuff in envparsing.sh
* fix: metrics docs
* chore: metrics docs wording
* fix: metrics stuff in envparsing?
* bump otel versions
---------
Co-authored-by: Tsuribori <user@acertaindebian>
Co-authored-by: Tsuribori <none@example.org>
Co-authored-by: tsmethurst <tobi.smethurst@protonmail.com>
Diffstat (limited to 'vendor/github.com/technologize/otel-go-contrib/otelginmetrics/config.go')
| -rw-r--r-- | vendor/github.com/technologize/otel-go-contrib/otelginmetrics/config.go | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/vendor/github.com/technologize/otel-go-contrib/otelginmetrics/config.go b/vendor/github.com/technologize/otel-go-contrib/otelginmetrics/config.go new file mode 100644 index 000000000..f33fe38ed --- /dev/null +++ b/vendor/github.com/technologize/otel-go-contrib/otelginmetrics/config.go @@ -0,0 +1,45 @@ +package otelginmetrics + +import ( + "net/http" + + "go.opentelemetry.io/otel/attribute" + semconv "go.opentelemetry.io/otel/semconv/v1.7.0" +) + +type config struct { + recordInFlight bool + recordSize bool + recordDuration bool + groupedStatus bool + recorder Recorder + attributes func(serverName, route string, request *http.Request) []attribute.KeyValue + shouldRecord func(serverName, route string, request *http.Request) bool +} + +func defaultConfig() *config { + return &config{ + recordInFlight: true, + recordDuration: true, + recordSize: true, + groupedStatus: true, + attributes: DefaultAttributes, + shouldRecord: func(_, _ string, _ *http.Request) bool { + return true + }, + } +} + +var DefaultAttributes = func(serverName, route string, request *http.Request) []attribute.KeyValue { + attrs := []attribute.KeyValue{ + semconv.HTTPMethodKey.String(request.Method), + } + + if serverName != "" { + attrs = append(attrs, semconv.HTTPServerNameKey.String(serverName)) + } + if route != "" { + attrs = append(attrs, semconv.HTTPRouteKey.String(route)) + } + return attrs +} |
