mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 10:03:42 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright The OpenTelemetry 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 otelhttp // import "go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp"
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"sync"
 | 
						|
 | 
						|
	"go.opentelemetry.io/otel/attribute"
 | 
						|
)
 | 
						|
 | 
						|
// Labeler is used to allow instrumented HTTP handlers to add custom attributes to
 | 
						|
// the metrics recorded by the net/http instrumentation.
 | 
						|
type Labeler struct {
 | 
						|
	mu         sync.Mutex
 | 
						|
	attributes []attribute.KeyValue
 | 
						|
}
 | 
						|
 | 
						|
// Add attributes to a Labeler.
 | 
						|
func (l *Labeler) Add(ls ...attribute.KeyValue) {
 | 
						|
	l.mu.Lock()
 | 
						|
	defer l.mu.Unlock()
 | 
						|
	l.attributes = append(l.attributes, ls...)
 | 
						|
}
 | 
						|
 | 
						|
// Get returns a copy of the attributes added to the Labeler.
 | 
						|
func (l *Labeler) Get() []attribute.KeyValue {
 | 
						|
	l.mu.Lock()
 | 
						|
	defer l.mu.Unlock()
 | 
						|
	ret := make([]attribute.KeyValue, len(l.attributes))
 | 
						|
	copy(ret, l.attributes)
 | 
						|
	return ret
 | 
						|
}
 | 
						|
 | 
						|
type labelerContextKeyType int
 | 
						|
 | 
						|
const lablelerContextKey labelerContextKeyType = 0
 | 
						|
 | 
						|
func injectLabeler(ctx context.Context, l *Labeler) context.Context {
 | 
						|
	return context.WithValue(ctx, lablelerContextKey, l)
 | 
						|
}
 | 
						|
 | 
						|
// LabelerFromContext retrieves a Labeler instance from the provided context if
 | 
						|
// one is available.  If no Labeler was found in the provided context a new, empty
 | 
						|
// Labeler is returned and the second return value is false.  In this case it is
 | 
						|
// safe to use the Labeler but any attributes added to it will not be used.
 | 
						|
func LabelerFromContext(ctx context.Context) (*Labeler, bool) {
 | 
						|
	l, ok := ctx.Value(lablelerContextKey).(*Labeler)
 | 
						|
	if !ok {
 | 
						|
		l = &Labeler{}
 | 
						|
	}
 | 
						|
	return l, ok
 | 
						|
}
 |