UNPKG

@aws-cdk/core

Version:

AWS Cloud Development Kit Core Library

84 lines 11.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.constructInfoFromStack = exports.constructInfoFromConstruct = void 0; const stack_1 = require("../stack"); const stage_1 = require("../stage"); const ALLOWED_FQN_PREFIXES = [ // SCOPES '@aws-cdk/', '@aws-cdk-containers/', '@aws-solutions-konstruk/', '@aws-solutions-constructs/', '@amzn/', // PACKAGES 'aws-rfdk.', 'aws-cdk-lib.', 'monocdk.', ]; /** * Symbol for accessing jsii runtime information * * Introduced in jsii 1.19.0, cdk 1.90.0. */ const JSII_RUNTIME_SYMBOL = Symbol.for('jsii.rtti'); function constructInfoFromConstruct(construct) { const jsiiRuntimeInfo = Object.getPrototypeOf(construct).constructor[JSII_RUNTIME_SYMBOL]; if (typeof jsiiRuntimeInfo === 'object' && jsiiRuntimeInfo !== null && typeof jsiiRuntimeInfo.fqn === 'string' && typeof jsiiRuntimeInfo.version === 'string') { return { fqn: jsiiRuntimeInfo.fqn, version: jsiiRuntimeInfo.version }; } else if (jsiiRuntimeInfo) { // There is something defined, but doesn't match our expectations. Fail fast and hard. throw new Error(`malformed jsii runtime info for construct: '${construct.node.path}'`); } return undefined; } exports.constructInfoFromConstruct = constructInfoFromConstruct; /** * For a given stack, walks the tree and finds the runtime info for all constructs within the tree. * Returns the unique list of construct info present in the stack, * as long as the construct fully-qualified names match the defined allow list. */ function constructInfoFromStack(stack) { const isDefined = (value) => value !== undefined; const allConstructInfos = constructsInStack(stack) .map(construct => constructInfoFromConstruct(construct)) .filter(isDefined) .filter(info => ALLOWED_FQN_PREFIXES.find(prefix => info.fqn.startsWith(prefix))); // Adds the jsii runtime as a psuedo construct for reporting purposes. allConstructInfos.push({ fqn: 'jsii-runtime.Runtime', version: getJsiiAgentVersion(), }); // Filter out duplicate values const uniqKeys = new Set(); return allConstructInfos.filter(construct => { const constructKey = `${construct.fqn}@${construct.version}`; const isDuplicate = uniqKeys.has(constructKey); uniqKeys.add(constructKey); return !isDuplicate; }); } exports.constructInfoFromStack = constructInfoFromStack; /** * Returns all constructs under the parent construct (including the parent), * stopping when it reaches a boundary of another stack (e.g., Stack, Stage, NestedStack). */ function constructsInStack(construct) { const constructs = [construct]; construct.node.children .filter(child => !stage_1.Stage.isStage(child) && !stack_1.Stack.isStack(child)) .forEach(child => constructs.push(...constructsInStack(child))); return constructs; } function getJsiiAgentVersion() { let jsiiAgent = process.env.JSII_AGENT; // if JSII_AGENT is not specified, we will assume this is a node.js runtime // and plug in our node.js version if (!jsiiAgent) { jsiiAgent = `node.js/${process.version}`; } // Sanitize the agent to remove characters which might mess with the downstream // prefix encoding & decoding. In particular the .NET jsii agent takes a form like: // DotNet/5.0.3/.NETCoreApp,Version=v3.1/1.0.0.0 // The `,` in the above messes with the prefix decoding when reporting the analytics. jsiiAgent = jsiiAgent.replace(/[^a-z0-9.-/=_]/gi, '-'); return jsiiAgent; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime-info.js","sourceRoot":"","sources":["runtime-info.ts"],"names":[],"mappings":"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","sourcesContent":["import { IConstruct } from '../construct-compat';\nimport { Stack } from '../stack';\nimport { Stage } from '../stage';\n\nconst ALLOWED_FQN_PREFIXES = [\n  // SCOPES\n  '@aws-cdk/', '@aws-cdk-containers/', '@aws-solutions-konstruk/', '@aws-solutions-constructs/', '@amzn/',\n  // PACKAGES\n  'aws-rfdk.', 'aws-cdk-lib.', 'monocdk.',\n];\n\n/**\n * Symbol for accessing jsii runtime information\n *\n * Introduced in jsii 1.19.0, cdk 1.90.0.\n */\nconst JSII_RUNTIME_SYMBOL = Symbol.for('jsii.rtti');\n\n/**\n * Source information on a construct (class fqn and version)\n */\nexport interface ConstructInfo {\n  readonly fqn: string;\n  readonly version: string;\n}\n\nexport function constructInfoFromConstruct(construct: IConstruct): ConstructInfo | undefined {\n  const jsiiRuntimeInfo = Object.getPrototypeOf(construct).constructor[JSII_RUNTIME_SYMBOL];\n  if (typeof jsiiRuntimeInfo === 'object'\n    && jsiiRuntimeInfo !== null\n    && typeof jsiiRuntimeInfo.fqn === 'string'\n    && typeof jsiiRuntimeInfo.version === 'string') {\n    return { fqn: jsiiRuntimeInfo.fqn, version: jsiiRuntimeInfo.version };\n  } else if (jsiiRuntimeInfo) {\n    // There is something defined, but doesn't match our expectations. Fail fast and hard.\n    throw new Error(`malformed jsii runtime info for construct: '${construct.node.path}'`);\n  }\n  return undefined;\n}\n\n/**\n * For a given stack, walks the tree and finds the runtime info for all constructs within the tree.\n * Returns the unique list of construct info present in the stack,\n * as long as the construct fully-qualified names match the defined allow list.\n */\nexport function constructInfoFromStack(stack: Stack): ConstructInfo[] {\n  const isDefined = (value: ConstructInfo | undefined): value is ConstructInfo => value !== undefined;\n\n  const allConstructInfos = constructsInStack(stack)\n    .map(construct => constructInfoFromConstruct(construct))\n    .filter(isDefined)\n    .filter(info => ALLOWED_FQN_PREFIXES.find(prefix => info.fqn.startsWith(prefix)));\n\n  // Adds the jsii runtime as a psuedo construct for reporting purposes.\n  allConstructInfos.push({\n    fqn: 'jsii-runtime.Runtime',\n    version: getJsiiAgentVersion(),\n  });\n\n  // Filter out duplicate values\n  const uniqKeys = new Set();\n  return allConstructInfos.filter(construct => {\n    const constructKey = `${construct.fqn}@${construct.version}`;\n    const isDuplicate = uniqKeys.has(constructKey);\n    uniqKeys.add(constructKey);\n    return !isDuplicate;\n  });\n}\n\n/**\n * Returns all constructs under the parent construct (including the parent),\n * stopping when it reaches a boundary of another stack (e.g., Stack, Stage, NestedStack).\n */\nfunction constructsInStack(construct: IConstruct): IConstruct[] {\n  const constructs = [construct];\n  construct.node.children\n    .filter(child => !Stage.isStage(child) && !Stack.isStack(child))\n    .forEach(child => constructs.push(...constructsInStack(child)));\n  return constructs;\n}\n\nfunction getJsiiAgentVersion() {\n  let jsiiAgent = process.env.JSII_AGENT;\n\n  // if JSII_AGENT is not specified, we will assume this is a node.js runtime\n  // and plug in our node.js version\n  if (!jsiiAgent) {\n    jsiiAgent = `node.js/${process.version}`;\n  }\n\n  // Sanitize the agent to remove characters which might mess with the downstream\n  // prefix encoding & decoding. In particular the .NET jsii agent takes a form like:\n  // DotNet/5.0.3/.NETCoreApp,Version=v3.1/1.0.0.0\n  // The `,` in the above messes with the prefix decoding when reporting the analytics.\n  jsiiAgent = jsiiAgent.replace(/[^a-z0-9.-/=_]/gi, '-');\n\n  return jsiiAgent;\n}\n"]}