Rocky_Mountain_Vending/.pnpm-store/v10/files/ff/5f594a7eb02413fac3618c30ed880a98b014d7538495d80c6968d738b2b0e330db07f8a6830d8cfaff173e02911b2cd06b11a7bc9c2a4ebfa7877a6142a6f6
DMleadgen 46d973904b
Initial commit: Rocky Mountain Vending website
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>
2026-02-12 16:22:15 -07:00

109 lines
No EOL
4.5 KiB
Text

"use strict";
/*
* 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.
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.detectResourcesSync = exports.detectResources = void 0;
const Resource_1 = require("./Resource");
const api_1 = require("@opentelemetry/api");
const utils_1 = require("./utils");
/**
* Runs all resource detectors and returns the results merged into a single Resource. Promise
* does not resolve until all the underlying detectors have resolved, unlike
* detectResourcesSync.
*
* @deprecated use detectResourcesSync() instead.
* @param config Configuration for resource detection
*/
const detectResources = async (config = {}) => {
const resources = await Promise.all((config.detectors || []).map(async (d) => {
try {
const resource = await d.detect(config);
api_1.diag.debug(`${d.constructor.name} found resource.`, resource);
return resource;
}
catch (e) {
api_1.diag.debug(`${d.constructor.name} failed: ${e.message}`);
return Resource_1.Resource.empty();
}
}));
// Future check if verbose logging is enabled issue #1903
logResources(resources);
return resources.reduce((acc, resource) => acc.merge(resource), Resource_1.Resource.empty());
};
exports.detectResources = detectResources;
/**
* Runs all resource detectors synchronously, merging their results. In case of attribute collision later resources will take precedence.
*
* @param config Configuration for resource detection
*/
const detectResourcesSync = (config = {}) => {
var _a;
const resources = ((_a = config.detectors) !== null && _a !== void 0 ? _a : []).map((d) => {
try {
const resourceOrPromise = d.detect(config);
let resource;
if ((0, utils_1.isPromiseLike)(resourceOrPromise)) {
const createPromise = async () => {
var _a;
const resolvedResource = await resourceOrPromise;
await ((_a = resolvedResource.waitForAsyncAttributes) === null || _a === void 0 ? void 0 : _a.call(resolvedResource));
return resolvedResource.attributes;
};
resource = new Resource_1.Resource({}, createPromise());
}
else {
resource = resourceOrPromise;
}
if (resource.waitForAsyncAttributes) {
void resource
.waitForAsyncAttributes()
.then(() => api_1.diag.debug(`${d.constructor.name} found resource.`, resource));
}
else {
api_1.diag.debug(`${d.constructor.name} found resource.`, resource);
}
return resource;
}
catch (e) {
api_1.diag.error(`${d.constructor.name} failed: ${e.message}`);
return Resource_1.Resource.empty();
}
});
const mergedResources = resources.reduce((acc, resource) => acc.merge(resource), Resource_1.Resource.empty());
if (mergedResources.waitForAsyncAttributes) {
void mergedResources.waitForAsyncAttributes().then(() => {
// Future check if verbose logging is enabled issue #1903
logResources(resources);
});
}
return mergedResources;
};
exports.detectResourcesSync = detectResourcesSync;
/**
* Writes debug information about the detected resources to the logger defined in the resource detection config, if one is provided.
*
* @param resources The array of {@link Resource} that should be logged. Empty entries will be ignored.
*/
const logResources = (resources) => {
resources.forEach(resource => {
// Print only populated resources
if (Object.keys(resource.attributes).length > 0) {
const resourceDebugString = JSON.stringify(resource.attributes, null, 4);
api_1.diag.verbose(resourceDebugString);
}
});
};
//# sourceMappingURL=detect-resources.js.map