Bumps the go-deps group with 11 updates in the / directory: | Package | From | To | | --- | --- | --- | | [cloud.google.com/go/compute](https://github.com/googleapis/google-cloud-go) | `1.25.1` | `1.26.0` | | [github.com/Azure/azure-sdk-for-go/sdk/azidentity](https://github.com/Azure/azure-sdk-for-go) | `1.5.1` | `1.5.2` | | [github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/compute/armcompute/v5](https://github.com/Azure/azure-sdk-for-go) | `5.5.0` | `5.7.0` | | [github.com/aws/aws-sdk-go](https://github.com/aws/aws-sdk-go) | `1.51.25` | `1.52.0` | | [github.com/getsentry/sentry-go](https://github.com/getsentry/sentry-go) | `0.26.0` | `0.27.0` | | [github.com/gophercloud/gophercloud](https://github.com/gophercloud/gophercloud) | `1.10.0` | `1.11.0` | | [github.com/jackc/pgtype](https://github.com/jackc/pgtype) | `1.14.1` | `1.14.3` | | [github.com/labstack/echo/v4](https://github.com/labstack/echo) | `4.11.4` | `4.12.0` | | [github.com/openshift-online/ocm-sdk-go](https://github.com/openshift-online/ocm-sdk-go) | `0.1.398` | `0.1.418` | | [github.com/osbuild/images](https://github.com/osbuild/images) | `0.56.0` | `0.58.0` | | [github.com/prometheus/client_golang](https://github.com/prometheus/client_golang) | `1.18.0` | `1.19.0` | Updates `cloud.google.com/go/compute` from 1.25.1 to 1.26.0 - [Release notes](https://github.com/googleapis/google-cloud-go/releases) - [Changelog](https://github.com/googleapis/google-cloud-go/blob/main/documentai/CHANGES.md) - [Commits](https://github.com/googleapis/google-cloud-go/compare/pubsub/v1.25.1...pubsub/v1.26.0) Updates `github.com/Azure/azure-sdk-for-go/sdk/azidentity` from 1.5.1 to 1.5.2 - [Release notes](https://github.com/Azure/azure-sdk-for-go/releases) - [Changelog](https://github.com/Azure/azure-sdk-for-go/blob/main/documentation/release.md) - [Commits](https://github.com/Azure/azure-sdk-for-go/compare/sdk/internal/v1.5.1...sdk/internal/v1.5.2) Updates `github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/compute/armcompute/v5` from 5.5.0 to 5.7.0 - [Release notes](https://github.com/Azure/azure-sdk-for-go/releases) - [Changelog](https://github.com/Azure/azure-sdk-for-go/blob/main/documentation/release.md) - [Commits](https://github.com/Azure/azure-sdk-for-go/compare/sdk/resourcemanager/compute/armcompute/v5.5.0...sdk/resourcemanager/compute/armcompute/v5.7.0) Updates `github.com/aws/aws-sdk-go` from 1.51.25 to 1.52.0 - [Release notes](https://github.com/aws/aws-sdk-go/releases) - [Commits](https://github.com/aws/aws-sdk-go/compare/v1.51.25...v1.52.0) Updates `github.com/getsentry/sentry-go` from 0.26.0 to 0.27.0 - [Release notes](https://github.com/getsentry/sentry-go/releases) - [Changelog](https://github.com/getsentry/sentry-go/blob/master/CHANGELOG.md) - [Commits](https://github.com/getsentry/sentry-go/compare/v0.26.0...v0.27.0) Updates `github.com/gophercloud/gophercloud` from 1.10.0 to 1.11.0 - [Release notes](https://github.com/gophercloud/gophercloud/releases) - [Changelog](https://github.com/gophercloud/gophercloud/blob/v1.11.0/CHANGELOG.md) - [Commits](https://github.com/gophercloud/gophercloud/compare/v1.10.0...v1.11.0) Updates `github.com/jackc/pgtype` from 1.14.1 to 1.14.3 - [Changelog](https://github.com/jackc/pgtype/blob/master/CHANGELOG.md) - [Commits](https://github.com/jackc/pgtype/compare/v1.14.1...v1.14.3) Updates `github.com/jackc/pgx/v4` from 4.18.1 to 4.18.2 - [Changelog](https://github.com/jackc/pgx/blob/v4.18.2/CHANGELOG.md) - [Commits](https://github.com/jackc/pgx/compare/v4.18.1...v4.18.2) Updates `github.com/labstack/echo/v4` from 4.11.4 to 4.12.0 - [Release notes](https://github.com/labstack/echo/releases) - [Changelog](https://github.com/labstack/echo/blob/master/CHANGELOG.md) - [Commits](https://github.com/labstack/echo/compare/v4.11.4...v4.12.0) Updates `github.com/openshift-online/ocm-sdk-go` from 0.1.398 to 0.1.418 - [Release notes](https://github.com/openshift-online/ocm-sdk-go/releases) - [Changelog](https://github.com/openshift-online/ocm-sdk-go/blob/main/CHANGES.md) - [Commits](https://github.com/openshift-online/ocm-sdk-go/compare/v0.1.398...v0.1.418) Updates `github.com/osbuild/images` from 0.56.0 to 0.58.0 - [Release notes](https://github.com/osbuild/images/releases) - [Commits](https://github.com/osbuild/images/compare/v0.56.0...v0.58.0) Updates `github.com/prometheus/client_golang` from 1.18.0 to 1.19.0 - [Release notes](https://github.com/prometheus/client_golang/releases) - [Changelog](https://github.com/prometheus/client_golang/blob/main/CHANGELOG.md) - [Commits](https://github.com/prometheus/client_golang/compare/v1.18.0...v1.19.0) Updates `golang.org/x/sync` from 0.6.0 to 0.7.0 - [Commits](https://github.com/golang/sync/compare/v0.6.0...v0.7.0) Updates `google.golang.org/api` from 0.175.0 to 0.177.0 - [Release notes](https://github.com/googleapis/google-api-go-client/releases) - [Changelog](https://github.com/googleapis/google-api-go-client/blob/main/CHANGES.md) - [Commits](https://github.com/googleapis/google-api-go-client/compare/v0.175.0...v0.177.0) --- updated-dependencies: - dependency-name: cloud.google.com/go/compute dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/Azure/azure-sdk-for-go/sdk/azidentity dependency-type: direct:production update-type: version-update:semver-patch dependency-group: go-deps - dependency-name: github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/compute/armcompute/v5 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/aws/aws-sdk-go dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/getsentry/sentry-go dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/gophercloud/gophercloud dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/jackc/pgtype dependency-type: direct:production update-type: version-update:semver-patch dependency-group: go-deps - dependency-name: github.com/jackc/pgx/v4 dependency-type: direct:production update-type: version-update:semver-patch dependency-group: go-deps - dependency-name: github.com/labstack/echo/v4 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/openshift-online/ocm-sdk-go dependency-type: direct:production update-type: version-update:semver-patch dependency-group: go-deps - dependency-name: github.com/osbuild/images dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/prometheus/client_golang dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: golang.org/x/sync dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: google.golang.org/api dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps ... Signed-off-by: dependabot[bot] <support@github.com>
191 lines
6.6 KiB
Go
191 lines
6.6 KiB
Go
// Copyright 2015 The Prometheus Authors
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package expfmt
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"net/http"
|
|
|
|
"google.golang.org/protobuf/encoding/protodelim"
|
|
"google.golang.org/protobuf/encoding/prototext"
|
|
|
|
"github.com/prometheus/common/internal/bitbucket.org/ww/goautoneg"
|
|
"github.com/prometheus/common/model"
|
|
|
|
dto "github.com/prometheus/client_model/go"
|
|
)
|
|
|
|
// Encoder types encode metric families into an underlying wire protocol.
|
|
type Encoder interface {
|
|
Encode(*dto.MetricFamily) error
|
|
}
|
|
|
|
// Closer is implemented by Encoders that need to be closed to finalize
|
|
// encoding. (For example, OpenMetrics needs a final `# EOF` line.)
|
|
//
|
|
// Note that all Encoder implementations returned from this package implement
|
|
// Closer, too, even if the Close call is a no-op. This happens in preparation
|
|
// for adding a Close method to the Encoder interface directly in a (mildly
|
|
// breaking) release in the future.
|
|
type Closer interface {
|
|
Close() error
|
|
}
|
|
|
|
type encoderCloser struct {
|
|
encode func(*dto.MetricFamily) error
|
|
close func() error
|
|
}
|
|
|
|
func (ec encoderCloser) Encode(v *dto.MetricFamily) error {
|
|
return ec.encode(v)
|
|
}
|
|
|
|
func (ec encoderCloser) Close() error {
|
|
return ec.close()
|
|
}
|
|
|
|
// Negotiate returns the Content-Type based on the given Accept header. If no
|
|
// appropriate accepted type is found, FmtText is returned (which is the
|
|
// Prometheus text format). This function will never negotiate FmtOpenMetrics,
|
|
// as the support is still experimental. To include the option to negotiate
|
|
// FmtOpenMetrics, use NegotiateOpenMetrics.
|
|
func Negotiate(h http.Header) Format {
|
|
escapingScheme := Format(fmt.Sprintf("; escaping=%s", Format(model.NameEscapingScheme.String())))
|
|
for _, ac := range goautoneg.ParseAccept(h.Get(hdrAccept)) {
|
|
if escapeParam := ac.Params[model.EscapingKey]; escapeParam != "" {
|
|
switch Format(escapeParam) {
|
|
case model.AllowUTF8, model.EscapeUnderscores, model.EscapeDots, model.EscapeValues:
|
|
escapingScheme = Format(fmt.Sprintf("; escaping=%s", escapeParam))
|
|
default:
|
|
// If the escaping parameter is unknown, ignore it.
|
|
}
|
|
}
|
|
ver := ac.Params["version"]
|
|
if ac.Type+"/"+ac.SubType == ProtoType && ac.Params["proto"] == ProtoProtocol {
|
|
switch ac.Params["encoding"] {
|
|
case "delimited":
|
|
return fmtProtoDelim + escapingScheme
|
|
case "text":
|
|
return fmtProtoText + escapingScheme
|
|
case "compact-text":
|
|
return fmtProtoCompact + escapingScheme
|
|
}
|
|
}
|
|
if ac.Type == "text" && ac.SubType == "plain" && (ver == TextVersion || ver == "") {
|
|
return fmtText + escapingScheme
|
|
}
|
|
}
|
|
return fmtText + escapingScheme
|
|
}
|
|
|
|
// NegotiateIncludingOpenMetrics works like Negotiate but includes
|
|
// FmtOpenMetrics as an option for the result. Note that this function is
|
|
// temporary and will disappear once FmtOpenMetrics is fully supported and as
|
|
// such may be negotiated by the normal Negotiate function.
|
|
func NegotiateIncludingOpenMetrics(h http.Header) Format {
|
|
escapingScheme := Format(fmt.Sprintf("; escaping=%s", Format(model.NameEscapingScheme.String())))
|
|
for _, ac := range goautoneg.ParseAccept(h.Get(hdrAccept)) {
|
|
if escapeParam := ac.Params[model.EscapingKey]; escapeParam != "" {
|
|
switch Format(escapeParam) {
|
|
case model.AllowUTF8, model.EscapeUnderscores, model.EscapeDots, model.EscapeValues:
|
|
escapingScheme = Format(fmt.Sprintf("; escaping=%s", escapeParam))
|
|
default:
|
|
// If the escaping parameter is unknown, ignore it.
|
|
}
|
|
}
|
|
ver := ac.Params["version"]
|
|
if ac.Type+"/"+ac.SubType == ProtoType && ac.Params["proto"] == ProtoProtocol {
|
|
switch ac.Params["encoding"] {
|
|
case "delimited":
|
|
return fmtProtoDelim + escapingScheme
|
|
case "text":
|
|
return fmtProtoText + escapingScheme
|
|
case "compact-text":
|
|
return fmtProtoCompact + escapingScheme
|
|
}
|
|
}
|
|
if ac.Type == "text" && ac.SubType == "plain" && (ver == TextVersion || ver == "") {
|
|
return fmtText + escapingScheme
|
|
}
|
|
if ac.Type+"/"+ac.SubType == OpenMetricsType && (ver == OpenMetricsVersion_0_0_1 || ver == OpenMetricsVersion_1_0_0 || ver == "") {
|
|
switch ver {
|
|
case OpenMetricsVersion_1_0_0:
|
|
return fmtOpenMetrics_1_0_0 + escapingScheme
|
|
default:
|
|
return fmtOpenMetrics_0_0_1 + escapingScheme
|
|
}
|
|
}
|
|
}
|
|
return fmtText + escapingScheme
|
|
}
|
|
|
|
// NewEncoder returns a new encoder based on content type negotiation. All
|
|
// Encoder implementations returned by NewEncoder also implement Closer, and
|
|
// callers should always call the Close method. It is currently only required
|
|
// for FmtOpenMetrics, but a future (breaking) release will add the Close method
|
|
// to the Encoder interface directly. The current version of the Encoder
|
|
// interface is kept for backwards compatibility.
|
|
// In cases where the Format does not allow for UTF-8 names, the global
|
|
// NameEscapingScheme will be applied.
|
|
func NewEncoder(w io.Writer, format Format) Encoder {
|
|
escapingScheme := format.ToEscapingScheme()
|
|
|
|
switch format.FormatType() {
|
|
case TypeProtoDelim:
|
|
return encoderCloser{
|
|
encode: func(v *dto.MetricFamily) error {
|
|
_, err := protodelim.MarshalTo(w, v)
|
|
return err
|
|
},
|
|
close: func() error { return nil },
|
|
}
|
|
case TypeProtoCompact:
|
|
return encoderCloser{
|
|
encode: func(v *dto.MetricFamily) error {
|
|
_, err := fmt.Fprintln(w, model.EscapeMetricFamily(v, escapingScheme).String())
|
|
return err
|
|
},
|
|
close: func() error { return nil },
|
|
}
|
|
case TypeProtoText:
|
|
return encoderCloser{
|
|
encode: func(v *dto.MetricFamily) error {
|
|
_, err := fmt.Fprintln(w, prototext.Format(model.EscapeMetricFamily(v, escapingScheme)))
|
|
return err
|
|
},
|
|
close: func() error { return nil },
|
|
}
|
|
case TypeTextPlain:
|
|
return encoderCloser{
|
|
encode: func(v *dto.MetricFamily) error {
|
|
_, err := MetricFamilyToText(w, model.EscapeMetricFamily(v, escapingScheme))
|
|
return err
|
|
},
|
|
close: func() error { return nil },
|
|
}
|
|
case TypeOpenMetrics:
|
|
return encoderCloser{
|
|
encode: func(v *dto.MetricFamily) error {
|
|
_, err := MetricFamilyToOpenMetrics(w, model.EscapeMetricFamily(v, escapingScheme))
|
|
return err
|
|
},
|
|
close: func() error {
|
|
_, err := FinalizeOpenMetrics(w)
|
|
return err
|
|
},
|
|
}
|
|
}
|
|
panic(fmt.Errorf("expfmt.NewEncoder: unknown format %q", format))
|
|
}
|