mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-08 19:29:17 +08:00

* Fix Dockerfile base Go version Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Update Go version and dependencies Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com>
75 lines
2.4 KiB
Go
75 lines
2.4 KiB
Go
package opentracing
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/opentracing/opentracing-go"
|
|
)
|
|
|
|
// EndpointOptions holds the options for tracing an endpoint
|
|
type EndpointOptions struct {
|
|
// IgnoreBusinessError if set to true will not treat a business error
|
|
// identified through the endpoint.Failer interface as a span error.
|
|
IgnoreBusinessError bool
|
|
|
|
// GetOperationName is an optional function that can set the span operation name based on the existing one
|
|
// for the endpoint and information in the context.
|
|
//
|
|
// If the function is nil, or the returned name is empty, the existing name for the endpoint is used.
|
|
GetOperationName func(ctx context.Context, name string) string
|
|
|
|
// Tags holds the default tags which will be set on span
|
|
// creation by our Endpoint middleware.
|
|
Tags opentracing.Tags
|
|
|
|
// GetTags is an optional function that can extract tags
|
|
// from the context and add them to the span.
|
|
GetTags func(ctx context.Context) opentracing.Tags
|
|
}
|
|
|
|
// EndpointOption allows for functional options to endpoint tracing middleware.
|
|
type EndpointOption func(*EndpointOptions)
|
|
|
|
// WithOptions sets all configuration options at once by use of the EndpointOptions struct.
|
|
func WithOptions(options EndpointOptions) EndpointOption {
|
|
return func(o *EndpointOptions) {
|
|
*o = options
|
|
}
|
|
}
|
|
|
|
// WithIgnoreBusinessError if set to true will not treat a business error
|
|
// identified through the endpoint.Failer interface as a span error.
|
|
func WithIgnoreBusinessError(ignoreBusinessError bool) EndpointOption {
|
|
return func(o *EndpointOptions) {
|
|
o.IgnoreBusinessError = ignoreBusinessError
|
|
}
|
|
}
|
|
|
|
// WithOperationNameFunc allows to set function that can set the span operation name based on the existing one
|
|
// for the endpoint and information in the context.
|
|
func WithOperationNameFunc(getOperationName func(ctx context.Context, name string) string) EndpointOption {
|
|
return func(o *EndpointOptions) {
|
|
o.GetOperationName = getOperationName
|
|
}
|
|
}
|
|
|
|
// WithTags adds default tags for the spans created by the Endpoint tracer.
|
|
func WithTags(tags opentracing.Tags) EndpointOption {
|
|
return func(o *EndpointOptions) {
|
|
if o.Tags == nil {
|
|
o.Tags = make(opentracing.Tags)
|
|
}
|
|
|
|
for key, value := range tags {
|
|
o.Tags[key] = value
|
|
}
|
|
}
|
|
}
|
|
|
|
// WithTagsFunc set the func to extracts additional tags from the context.
|
|
func WithTagsFunc(getTags func(ctx context.Context) opentracing.Tags) EndpointOption {
|
|
return func(o *EndpointOptions) {
|
|
o.GetTags = getTags
|
|
}
|
|
}
|