mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-03 22:12:26 -06:00 
			
		
		
		
	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>
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			73 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()
 | 
						|
}
 |