"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 detectResourceSync() 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 () => { const resolvedResource = await resourceOrPromise; 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