diff options
author | 2023-11-23 19:10:51 +0100 | |
---|---|---|
committer | 2023-11-23 19:10:51 +0100 | |
commit | 2b9cf56f565517b947b0eb71d2086764e9edf2be (patch) | |
tree | 4e4d1e50001f93e64a624caeae6a7200ae317716 /internal/api/metrics/metrics.go | |
parent | [documentation] add poll and poll vote details to gotosocial federating doc (... (diff) | |
download | gotosocial-2b9cf56f565517b947b0eb71d2086764e9edf2be.tar.xz |
[chore/bugfix] Fix double gzip on prometheus endpoint (#2383)
* [chore] Move "/metrics" into separate API module
* use our own gzip middleware for prom
Diffstat (limited to 'internal/api/metrics/metrics.go')
-rw-r--r-- | internal/api/metrics/metrics.go | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/internal/api/metrics/metrics.go b/internal/api/metrics/metrics.go new file mode 100644 index 000000000..d89e56ad5 --- /dev/null +++ b/internal/api/metrics/metrics.go @@ -0,0 +1,54 @@ +// GoToSocial +// Copyright (C) GoToSocial Authors admin@gotosocial.org +// SPDX-License-Identifier: AGPL-3.0-or-later +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU Affero General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + +package metrics + +import ( + "net/http" + + "github.com/gin-gonic/gin" + "github.com/prometheus/client_golang/prometheus" + "github.com/prometheus/client_golang/prometheus/promhttp" +) + +type Module struct { + handler http.Handler +} + +func New() *Module { + // Use our own gzip handler. + opts := promhttp.HandlerOpts{ + DisableCompression: true, + } + + // Instrument handler itself. + handler := promhttp.InstrumentMetricHandler( + prometheus.DefaultRegisterer, + promhttp.HandlerFor(prometheus.DefaultGatherer, opts), + ) + + return &Module{ + handler: handler, + } +} + +func (m *Module) Route(attachHandler func(method string, path string, f ...gin.HandlerFunc) gin.IRoutes) { + attachHandler(http.MethodGet, "", func(c *gin.Context) { + // Defer all "/metrics" handling to prom. + m.handler.ServeHTTP(c.Writer, c.Request) + }) +} |