2023-08-03 13:34:48 -07:00
|
|
|
// Code created by gotmpl. DO NOT MODIFY.
|
|
|
|
// source: internal/shared/otlp/partialsuccess.go
|
|
|
|
|
|
|
|
// Copyright The OpenTelemetry Authors
|
2024-02-29 07:05:28 +01:00
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
2023-08-03 13:34:48 -07:00
|
|
|
|
|
|
|
package internal
|
|
|
|
|
|
|
|
import "fmt"
|
|
|
|
|
|
|
|
// PartialSuccess represents the underlying error for all handling
|
|
|
|
// OTLP partial success messages. Use `errors.Is(err,
|
|
|
|
// PartialSuccess{})` to test whether an error passed to the OTel
|
|
|
|
// error handler belongs to this category.
|
|
|
|
type PartialSuccess struct {
|
|
|
|
ErrorMessage string
|
|
|
|
RejectedItems int64
|
|
|
|
RejectedKind string
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ error = PartialSuccess{}
|
|
|
|
|
|
|
|
// Error implements the error interface.
|
|
|
|
func (ps PartialSuccess) Error() string {
|
|
|
|
msg := ps.ErrorMessage
|
|
|
|
if msg == "" {
|
|
|
|
msg = "empty message"
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("OTLP partial success: %s (%d %s rejected)", msg, ps.RejectedItems, ps.RejectedKind)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Is supports the errors.Is() interface.
|
|
|
|
func (ps PartialSuccess) Is(err error) bool {
|
|
|
|
_, ok := err.(PartialSuccess)
|
|
|
|
return ok
|
|
|
|
}
|
|
|
|
|
|
|
|
// TracePartialSuccessError returns an error describing a partial success
|
|
|
|
// response for the trace signal.
|
|
|
|
func TracePartialSuccessError(itemsRejected int64, errorMessage string) error {
|
|
|
|
return PartialSuccess{
|
|
|
|
ErrorMessage: errorMessage,
|
|
|
|
RejectedItems: itemsRejected,
|
|
|
|
RejectedKind: "spans",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// MetricPartialSuccessError returns an error describing a partial success
|
|
|
|
// response for the metric signal.
|
|
|
|
func MetricPartialSuccessError(itemsRejected int64, errorMessage string) error {
|
|
|
|
return PartialSuccess{
|
|
|
|
ErrorMessage: errorMessage,
|
|
|
|
RejectedItems: itemsRejected,
|
|
|
|
RejectedKind: "metric data points",
|
|
|
|
}
|
|
|
|
}
|