@instana/shared-metrics
Version: 
Internal metrics plug-in package for Node.js monitoring with Instana
82 lines (68 loc) • 2.44 kB
JavaScript
/*
 * (c) Copyright IBM Corp. 2021
 * (c) Copyright Instana Inc. and contributors 2018
 */
;
const { util, uninstrumentedFs: fs } = require('@instana/core');
/** @type {import('@instana/core/src/core').GenericLogger} */
let logger;
/**
 * @param {import('@instana/core/src/config').InstanaConfig} config
 */
exports.init = function init(config) {
  logger = config.logger;
};
exports.payloadPrefix = 'directDependencies';
/** @type {Object.<string, *>} */
exports.currentPayload = {
  dependencies: {},
  peerDependencies: {},
  optionalDependencies: {}
};
const MAX_ATTEMPTS = 20;
const DELAY = 1000;
let attempts = 0;
exports.deactivate = function deactivate() {
  attempts = 0;
};
exports.activate = function activate() {
  attempts++;
  util.applicationUnderMonitoring.getMainPackageJsonPathStartingAtMainModule((err, packageJsonPath) => {
    if (err) {
      return logger.info(
        `Failed to determine main package.json for analysis of direct dependencies.
        Reason: ${err?.message} ${err?.stack}`
      );
    } else if (!packageJsonPath && attempts < MAX_ATTEMPTS) {
      setTimeout(exports.activate, DELAY).unref();
      return;
    } else if (!packageJsonPath) {
      // final attempt failed, ignore silently
      return;
    }
    addDirectDependenciesFromMainPackageJson(packageJsonPath);
  });
};
/**
 * @param {string} packageJsonPath
 */
function addDirectDependenciesFromMainPackageJson(packageJsonPath) {
  logger.debug(`addDirectDependenciesFromMainPackageJson: ${packageJsonPath}`);
  const started = Date.now();
  fs.readFile(packageJsonPath, { encoding: 'utf8' }, (err, contents) => {
    if (err) {
      return logger.debug(`Failed to analyze direct dependencies dependency due to: ${err?.message}`);
    }
    try {
      const pckg = JSON.parse(contents);
      exports.currentPayload.dependencies = pckg.dependencies || {};
      exports.currentPayload.peerDependencies = pckg.peerDependencies || {};
      exports.currentPayload.optionalDependencies = pckg.optionalDependencies || {};
      exports.currentPayload[pckg.name] = pckg.version;
      logger.debug(`Collection of direct dependencies took ${Date.now() - started} ms.`);
    } catch (subErr) {
      logger.debug(`Collection of direct dependencies took ${Date.now() - started} ms.`);
      return logger.debug(`Failed to parse package.json ${packageJsonPath} dependency due to: ${subErr?.message}`);
    }
  });
}