Next.js website for Rocky Mountain Vending company featuring: - Product catalog with Stripe integration - Service areas and parts pages - Admin dashboard with Clerk authentication - SEO optimized pages with JSON-LD structured data Co-authored-by: Cursor <cursoragent@cursor.com>
76 lines
No EOL
2.9 KiB
Text
76 lines
No EOL
2.9 KiB
Text
/*
|
|
* 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
|
|
*
|
|
* https://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.
|
|
*/
|
|
import { diag, } from '@opentelemetry/api';
|
|
/** Combines multiple propagators into a single propagator. */
|
|
export class CompositePropagator {
|
|
/**
|
|
* Construct a composite propagator from a list of propagators.
|
|
*
|
|
* @param [config] Configuration object for composite propagator
|
|
*/
|
|
constructor(config = {}) {
|
|
var _a;
|
|
this._propagators = (_a = config.propagators) !== null && _a !== void 0 ? _a : [];
|
|
this._fields = Array.from(new Set(this._propagators
|
|
// older propagators may not have fields function, null check to be sure
|
|
.map(p => (typeof p.fields === 'function' ? p.fields() : []))
|
|
.reduce((x, y) => x.concat(y), [])));
|
|
}
|
|
/**
|
|
* Run each of the configured propagators with the given context and carrier.
|
|
* Propagators are run in the order they are configured, so if multiple
|
|
* propagators write the same carrier key, the propagator later in the list
|
|
* will "win".
|
|
*
|
|
* @param context Context to inject
|
|
* @param carrier Carrier into which context will be injected
|
|
*/
|
|
inject(context, carrier, setter) {
|
|
for (const propagator of this._propagators) {
|
|
try {
|
|
propagator.inject(context, carrier, setter);
|
|
}
|
|
catch (err) {
|
|
diag.warn(`Failed to inject with ${propagator.constructor.name}. Err: ${err.message}`);
|
|
}
|
|
}
|
|
}
|
|
/**
|
|
* Run each of the configured propagators with the given context and carrier.
|
|
* Propagators are run in the order they are configured, so if multiple
|
|
* propagators write the same context key, the propagator later in the list
|
|
* will "win".
|
|
*
|
|
* @param context Context to add values to
|
|
* @param carrier Carrier from which to extract context
|
|
*/
|
|
extract(context, carrier, getter) {
|
|
return this._propagators.reduce((ctx, propagator) => {
|
|
try {
|
|
return propagator.extract(ctx, carrier, getter);
|
|
}
|
|
catch (err) {
|
|
diag.warn(`Failed to extract with ${propagator.constructor.name}. Err: ${err.message}`);
|
|
}
|
|
return ctx;
|
|
}, context);
|
|
}
|
|
fields() {
|
|
// return a new array so our fields cannot be modified
|
|
return this._fields.slice();
|
|
}
|
|
}
|
|
//# sourceMappingURL=composite.js.map |