mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2024-11-23 12:16:38 +00:00
c097745c38
Bumps [go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc](https://github.com/open-telemetry/opentelemetry-go) from 1.24.0 to 1.25.0. - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.24.0...v1.25.0) --- updated-dependencies: - dependency-name: go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
74 lines
1.8 KiB
Go
74 lines
1.8 KiB
Go
/*
|
|
*
|
|
* Copyright 2021 gRPC 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 pretty defines helper functions to pretty-print structs for logging.
|
|
package pretty
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
|
|
"google.golang.org/protobuf/encoding/protojson"
|
|
"google.golang.org/protobuf/protoadapt"
|
|
)
|
|
|
|
const jsonIndent = " "
|
|
|
|
// ToJSON marshals the input into a json string.
|
|
//
|
|
// If marshal fails, it falls back to fmt.Sprintf("%+v").
|
|
func ToJSON(e any) string {
|
|
if ee, ok := e.(protoadapt.MessageV1); ok {
|
|
e = protoadapt.MessageV2Of(ee)
|
|
}
|
|
|
|
if ee, ok := e.(protoadapt.MessageV2); ok {
|
|
mm := protojson.MarshalOptions{
|
|
Indent: jsonIndent,
|
|
Multiline: true,
|
|
}
|
|
ret, err := mm.Marshal(ee)
|
|
if err != nil {
|
|
// This may fail for proto.Anys, e.g. for xDS v2, LDS, the v2
|
|
// messages are not imported, and this will fail because the message
|
|
// is not found.
|
|
return fmt.Sprintf("%+v", ee)
|
|
}
|
|
return string(ret)
|
|
}
|
|
|
|
ret, err := json.MarshalIndent(e, "", jsonIndent)
|
|
if err != nil {
|
|
return fmt.Sprintf("%+v", e)
|
|
}
|
|
return string(ret)
|
|
}
|
|
|
|
// FormatJSON formats the input json bytes with indentation.
|
|
//
|
|
// If Indent fails, it returns the unchanged input as string.
|
|
func FormatJSON(b []byte) string {
|
|
var out bytes.Buffer
|
|
err := json.Indent(&out, b, "", jsonIndent)
|
|
if err != nil {
|
|
return string(b)
|
|
}
|
|
return out.String()
|
|
}
|