Socket
Socket
Sign inDemoInstall

@aws-cdk/cdk

Package Overview
Dependencies
Maintainers
4
Versions
42
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/cdk - npm Package Compare versions

Comparing version 0.16.0 to 0.17.0

9

lib/cloudformation/stack.d.ts

@@ -93,2 +93,11 @@ import cxapi = require('@aws-cdk/cx-api');

/**
* Returns the AWS account ID of this Stack,
* or throws an exception if the account ID is not set in the environment.
*
* @param why more information about why is the account ID required
* @returns the AWS account ID of this Stack
*/
requireAccountId(why?: string): string;
parentApp(): App | undefined;
/**
* Indicate that a context key was expected

@@ -95,0 +104,0 @@ *

23

lib/cloudformation/stack.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const cxapi = require("@aws-cdk/cx-api");
const app_1 = require("../app");
const construct_1 = require("../core/construct");

@@ -124,2 +125,22 @@ const tokens_1 = require("../core/tokens");

/**
* Returns the AWS account ID of this Stack,
* or throws an exception if the account ID is not set in the environment.
*
* @param why more information about why is the account ID required
* @returns the AWS account ID of this Stack
*/
requireAccountId(why) {
if (!this.env.account) {
throw new Error(`${why ? why + '. ' : ''}Stack requires account information. ` +
'It can be supplied either via the "env" property when creating the Stack, or by using "aws configure"');
}
return this.env.account;
}
parentApp() {
const parent = this.parent;
return parent instanceof app_1.App
? parent
: undefined;
}
/**
* Indicate that a context key was expected

@@ -315,2 +336,2 @@ *

exports.Ref = Ref;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack.js","sourceRoot":"","sources":["stack.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { App } from '../app';\nimport { Construct, PATH_SEP } from '../core/construct';\nimport { resolve, Token } from '../core/tokens';\nimport { Environment } from '../environment';\nimport { CloudFormationToken } from './cloudformation-token';\nimport { HashedAddressingScheme, IAddressingScheme, LogicalIDs } from './logical-id';\nimport { Resource } from './resource';\n\nexport interface StackProps {\n  /**\n   * The AWS environment (account/region) where this stack will be deployed.\n   *\n   * If not supplied, the `default-account` and `default-region` context parameters will be\n   * used. If they are undefined, it will not be possible to deploy the stack.\n   */\n  env?: Environment;\n\n  /**\n   * Strategy for logical ID generation\n   *\n   * Optional. If not supplied, the HashedNamingScheme will be used.\n   */\n  namingScheme?: IAddressingScheme;\n}\n\n/**\n * A root construct which represents a single CloudFormation stack.\n */\nexport class Stack extends Construct {\n  /**\n   * Traverses the tree and looks up for the Stack root.\n   * @param node A construct in the tree\n   * @returns The Stack object (throws if the node is not part of a Stack-rooted tree)\n   */\n  public static find(node: Construct): Stack {\n    let curr: Construct | undefined = node;\n    while (curr != null && !isStack(curr)) {\n      curr = curr.parent;\n    }\n\n    if (curr == null) {\n      throw new Error(`Cannot find a Stack parent for '${node.toString()}'`);\n    }\n    return curr;\n  }\n\n  /**\n   * Adds a metadata annotation \"aws:cdk:physical-name\" to the construct if physicalName\n   * is non-null. This can be used later by tools and aspects to determine if resources\n   * have been created with physical names.\n   */\n  public static annotatePhysicalName(construct: Construct, physicalName?: string) {\n    if (physicalName == null) {\n      return;\n    }\n\n    construct.addMetadata('aws:cdk:physical-name', physicalName);\n  }\n\n  private static readonly VALID_STACK_NAME_REGEX = /^[A-Za-z][A-Za-z0-9-]*$/;\n\n  /**\n   * Lists all missing contextual information.\n   * This is returned when the stack is synthesized under the 'missing' attribute\n   * and allows tooling to obtain the context and re-synthesize.\n   */\n  public readonly missingContext: { [key: string]: cxapi.MissingContext } = { };\n\n  /**\n   * The environment in which this stack is deployed.\n   */\n  public readonly env: Environment;\n\n  /**\n   * Used to determine if this construct is a stack.\n   */\n  public readonly isStack = true;\n\n  /**\n   * Logical ID generation strategy\n   */\n  public readonly logicalIds: LogicalIDs;\n\n  /**\n   * Options for CloudFormation template (like version, transform, description).\n   */\n  public readonly templateOptions: TemplateOptions = {};\n\n  /**\n   * The CloudFormation stack name.\n   */\n  public readonly name: string;\n\n  /**\n   * Creates a new stack.\n   *\n   * @param parent Parent of this stack, usually a Program instance.\n   * @param name The name of the CloudFormation stack. Defaults to \"Stack\".\n   * @param props Stack properties.\n   */\n  public constructor(parent?: App, name?: string, props?: StackProps) {\n    // For unit test convenience parents are optional, so bypass the type check when calling the parent.\n    super(parent!, name!);\n    this.env = this.parseEnvironment(props);\n\n    this.logicalIds = new LogicalIDs(props && props.namingScheme ? props.namingScheme : new HashedAddressingScheme());\n    this.name = name || 'Stack';\n  }\n\n  /**\n   * Looks up a resource by path.\n   *\n   * @returns The Resource or undefined if not found\n   */\n  public findResource(path: string): Resource | undefined {\n    const r = this.findChild(path);\n    if (!r) { return undefined; }\n\n    // found an element, check if it's a resource (duck-type)\n    if (!('resourceType' in r)) {\n      throw new Error(`Found a stack element for ${path} but it is not a resource: ${r.toString()}`);\n    }\n\n    return r as Resource;\n  }\n\n  /**\n   * Returns the CloudFormation template for this stack by traversing\n   * the tree and invoking toCloudFormation() on all Entity objects.\n   */\n  public toCloudFormation() {\n    // before we begin synthesis, we shall lock this stack, so children cannot be added\n    this.lock();\n\n    try {\n      const template: any = {\n        Description: this.templateOptions.description,\n        Transform: this.templateOptions.transform,\n        AWSTemplateFormatVersion: this.templateOptions.templateFormatVersion,\n        Metadata: this.templateOptions.metadata\n      };\n\n      const elements = stackElements(this);\n      const fragments = elements.map(e => e.toCloudFormation());\n\n      // merge in all CloudFormation fragments collected from the tree\n      for (const fragment of fragments) {\n        merge(template, fragment);\n      }\n\n      // resolve all tokens and remove all empties\n      const ret = resolve(template) || { };\n\n      this.logicalIds.assertAllRenamesApplied();\n\n      return ret;\n    } finally {\n      // allow mutations after synthesis is finished.\n      this.unlock();\n    }\n  }\n\n  /**\n   * @param why more information about why region is required.\n   * @returns The region in which this stack is deployed. Throws if region is not defined.\n   */\n  public requireRegion(why?: string) {\n    if (!this.env.region) {\n      throw new Error(`${why ? why + '. ' : ''}Stack requires region information. It can be either supplied via the \"env\" property, ` +\n          `via the \"${cxapi.DEFAULT_REGION_CONTEXT_KEY}\" context parameters or using \"aws configure\"`);\n    }\n\n    return this.env.region;\n  }\n\n  /**\n   * Indicate that a context key was expected\n   *\n   * Contains instructions on how the key should be supplied.\n   * @param key Key that uniquely identifies this missing context.\n   * @param details The set of parameters needed to obtain the context (specific to context provider).\n   */\n  public reportMissingContext(key: string, details: cxapi.MissingContext) {\n    this.missingContext[key] = details;\n  }\n\n  /**\n   * Rename a generated logical identities\n   */\n  public renameLogical(oldId: string, newId: string) {\n    // tslint:disable-next-line:no-console\n    if (this.children.length > 0) {\n      throw new Error(\"All renames must be set up before adding elements to the stack\");\n    }\n\n    this.logicalIds.renameLogical(oldId, newId);\n  }\n\n  /**\n   * Validate stack name\n   *\n   * CloudFormation stack names can include dashes in addition to the regular identifier\n   * character classes, and we don't allow one of the magic markers.\n   */\n  protected _validateId(name: string) {\n    if (!Stack.VALID_STACK_NAME_REGEX.test(name)) {\n      throw new Error(`Stack name must match the regular expression: ${Stack.VALID_STACK_NAME_REGEX.toString()}, got '${name}'`);\n    }\n  }\n\n  /**\n   * Applied defaults to environment attributes.\n   */\n  private parseEnvironment(props?: StackProps) {\n    // start with `env`.\n    const env: Environment = (props && props.env) || { };\n\n    // if account is not specified, attempt to read from context.\n    if (!env.account) {\n      env.account = this.getContext(cxapi.DEFAULT_ACCOUNT_CONTEXT_KEY);\n    }\n\n    // if region is not specified, attempt to read from context.\n    if (!env.region) {\n      env.region = this.getContext(cxapi.DEFAULT_REGION_CONTEXT_KEY);\n    }\n\n    return env;\n  }\n}\n\nfunction merge(template: any, part: any) {\n  for (const section of Object.keys(part)) {\n    const src = part[section];\n\n    // create top-level section if it doesn't exist\n    let dest = template[section];\n    if (!dest) {\n      template[section] = dest = src;\n    } else {\n      // add all entities from source section to destination section\n      for (const id of Object.keys(src)) {\n        if (id in dest) {\n          throw new Error(`section '${section}' already contains '${id}'`);\n        }\n        dest[id] = src[id];\n      }\n    }\n  }\n}\n\nconst LOGICAL_ID_MD = 'aws:cdk:logicalId';\n\n/**\n * Represents a construct that can be \"depended on\" via `addDependency`.\n */\nexport interface IDependable {\n  /**\n   * Returns the set of all stack elements (resources, parameters, conditions)\n   * that should be added when a resource \"depends on\" this construct.\n   */\n  readonly dependencyElements: IDependable[];\n}\n\n/**\n * An element of a CloudFormation stack.\n */\nexport abstract class StackElement extends Construct implements IDependable {\n  /**\n   * Returns `true` if a construct is a stack element (i.e. part of the\n   * synthesized cloudformation template).\n   *\n   * Uses duck-typing instead of `instanceof` to allow stack elements from different\n   * versions of this library to be included in the same stack.\n   *\n   * @returns The construct as a stack element or undefined if it is not a stack element.\n   */\n  public static _asStackElement(construct: Construct): StackElement | undefined {\n    if ('logicalId' in construct && 'toCloudFormation' in construct) {\n      return construct as StackElement;\n    } else {\n      return undefined;\n    }\n  }\n\n  /**\n   * The logical ID for this CloudFormation stack element\n   */\n  public readonly logicalId: string;\n\n  /**\n   * The stack this Construct has been made a part of\n   */\n  protected stack: Stack;\n\n  /**\n   * Creates an entity and binds it to a tree.\n   * Note that the root of the tree must be a Stack object (not just any Root).\n   *\n   * @param parent The parent construct\n   * @param props Construct properties\n   */\n  constructor(parent: Construct, name: string) {\n    super(parent, name);\n    const s = Stack.find(this);\n    if (!s) {\n      throw new Error('The tree root must be derived from \"Stack\"');\n    }\n    this.stack = s;\n\n    this.addMetadata(LOGICAL_ID_MD, new Token(() => this.logicalId), this.constructor);\n\n    this.logicalId = this.stack.logicalIds.getLogicalId(this);\n  }\n\n  /**\n   * @returns the stack trace of the point where this Resource was created from, sourced\n   *      from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most\n   *      node +internal+ entries filtered.\n   */\n  public get creationStackTrace(): string[] {\n    return filterStackTrace(this.metadata.find(md => md.type === LOGICAL_ID_MD)!.trace);\n\n    function filterStackTrace(stack: string[]): string[] {\n      const result = Array.of(...stack);\n      while (result.length > 0 && shouldFilter(result[result.length - 1])) {\n        result.pop();\n      }\n      // It's weird if we filtered everything, so return the whole stack...\n      return result.length === 0 ? stack : result;\n    }\n\n    function shouldFilter(str: string): boolean {\n      return str.match(/[^(]+\\(internal\\/.*/) !== null;\n    }\n  }\n\n  /**\n   * Return the path with respect to the stack\n   */\n  public get stackPath(): string {\n    return this.ancestors(this.stack).map(c => c.id).join(PATH_SEP);\n  }\n\n  public get dependencyElements(): IDependable[] {\n    return [ this ];\n  }\n\n  /**\n   * Returns the CloudFormation 'snippet' for this entity. The snippet will only be merged\n   * at the root level to ensure there are no identity conflicts.\n   *\n   * For example, a Resource class will return something like:\n   * {\n   *   Resources: {\n   *     [this.logicalId]: {\n   *       Type: this.resourceType,\n   *       Properties: this.props,\n   *       Condition: this.condition\n   *     }\n   *   }\n   * }\n   */\n  public abstract toCloudFormation(): object;\n}\n\n/**\n * CloudFormation template options for a stack.\n */\nexport interface TemplateOptions {\n  /**\n   * Gets or sets the description of this stack.\n   * If provided, it will be included in the CloudFormation template's \"Description\" attribute.\n   */\n  description?: string;\n\n  /**\n   * Gets or sets the AWSTemplateFormatVersion field of the CloudFormation template.\n   */\n  templateFormatVersion?: string;\n\n  /**\n   * Gets or sets the top-level template transform for this stack (e.g. \"AWS::Serverless-2016-10-31\").\n   */\n  transform?: string;\n\n  /**\n   * Metadata associated with the CloudFormation template.\n   */\n   metadata?: { [key: string]: any };\n}\n\n/**\n * Base class for referenceable CloudFormation constructs which are not Resources\n *\n * These constructs are things like Conditions and Parameters, can be\n * referenced by taking the `.ref` attribute.\n *\n * Resource constructs do not inherit from Referenceable because they have their\n * own, more specific types returned from the .ref attribute. Also, some\n * resources aren't referenceable at all (such as BucketPolicies or GatewayAttachments).\n */\nexport abstract class Referenceable extends StackElement {\n  /**\n   * Returns a token to a CloudFormation { Ref } that references this entity based on it's logical ID.\n   */\n  public get ref(): string {\n    return new Ref(this).toString();\n  }\n}\n\n/**\n * Return whether the given object is a Stack.\n *\n * We do attribute detection since we can't reliably use 'instanceof'.\n */\nfunction isStack(construct: Construct): construct is Stack {\n  return (construct as any).isStack;\n}\n\n/**\n * Collect all StackElements from a construct\n *\n * @param node Root node to collect all StackElements from\n * @param into Array to append StackElements to\n * @returns The same array as is being collected into\n */\nfunction stackElements(node: Construct, into: StackElement[] = []): StackElement[] {\n  const element = StackElement._asStackElement(node);\n  if (element) {\n    into.push(element);\n  }\n\n  for (const child of node.children) {\n    stackElements(child, into);\n  }\n\n  return into;\n}\n\n/**\n * A generic, untyped reference to a Stack Element\n */\nexport class Ref extends CloudFormationToken {\n  constructor(element: StackElement) {\n    super({ Ref: element.logicalId }, `${element.logicalId}.Ref`);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack.js","sourceRoot":"","sources":["stack.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { App } from '../app';\nimport { Construct, PATH_SEP } from '../core/construct';\nimport { resolve, Token } from '../core/tokens';\nimport { Environment } from '../environment';\nimport { CloudFormationToken } from './cloudformation-token';\nimport { HashedAddressingScheme, IAddressingScheme, LogicalIDs } from './logical-id';\nimport { Resource } from './resource';\n\nexport interface StackProps {\n  /**\n   * The AWS environment (account/region) where this stack will be deployed.\n   *\n   * If not supplied, the `default-account` and `default-region` context parameters will be\n   * used. If they are undefined, it will not be possible to deploy the stack.\n   */\n  env?: Environment;\n\n  /**\n   * Strategy for logical ID generation\n   *\n   * Optional. If not supplied, the HashedNamingScheme will be used.\n   */\n  namingScheme?: IAddressingScheme;\n}\n\n/**\n * A root construct which represents a single CloudFormation stack.\n */\nexport class Stack extends Construct {\n  /**\n   * Traverses the tree and looks up for the Stack root.\n   * @param node A construct in the tree\n   * @returns The Stack object (throws if the node is not part of a Stack-rooted tree)\n   */\n  public static find(node: Construct): Stack {\n    let curr: Construct | undefined = node;\n    while (curr != null && !isStack(curr)) {\n      curr = curr.parent;\n    }\n\n    if (curr == null) {\n      throw new Error(`Cannot find a Stack parent for '${node.toString()}'`);\n    }\n    return curr;\n  }\n\n  /**\n   * Adds a metadata annotation \"aws:cdk:physical-name\" to the construct if physicalName\n   * is non-null. This can be used later by tools and aspects to determine if resources\n   * have been created with physical names.\n   */\n  public static annotatePhysicalName(construct: Construct, physicalName?: string) {\n    if (physicalName == null) {\n      return;\n    }\n\n    construct.addMetadata('aws:cdk:physical-name', physicalName);\n  }\n\n  private static readonly VALID_STACK_NAME_REGEX = /^[A-Za-z][A-Za-z0-9-]*$/;\n\n  /**\n   * Lists all missing contextual information.\n   * This is returned when the stack is synthesized under the 'missing' attribute\n   * and allows tooling to obtain the context and re-synthesize.\n   */\n  public readonly missingContext: { [key: string]: cxapi.MissingContext } = { };\n\n  /**\n   * The environment in which this stack is deployed.\n   */\n  public readonly env: Environment;\n\n  /**\n   * Used to determine if this construct is a stack.\n   */\n  public readonly isStack = true;\n\n  /**\n   * Logical ID generation strategy\n   */\n  public readonly logicalIds: LogicalIDs;\n\n  /**\n   * Options for CloudFormation template (like version, transform, description).\n   */\n  public readonly templateOptions: TemplateOptions = {};\n\n  /**\n   * The CloudFormation stack name.\n   */\n  public readonly name: string;\n\n  /**\n   * Creates a new stack.\n   *\n   * @param parent Parent of this stack, usually a Program instance.\n   * @param name The name of the CloudFormation stack. Defaults to \"Stack\".\n   * @param props Stack properties.\n   */\n  public constructor(parent?: App, name?: string, props?: StackProps) {\n    // For unit test convenience parents are optional, so bypass the type check when calling the parent.\n    super(parent!, name!);\n    this.env = this.parseEnvironment(props);\n\n    this.logicalIds = new LogicalIDs(props && props.namingScheme ? props.namingScheme : new HashedAddressingScheme());\n    this.name = name || 'Stack';\n  }\n\n  /**\n   * Looks up a resource by path.\n   *\n   * @returns The Resource or undefined if not found\n   */\n  public findResource(path: string): Resource | undefined {\n    const r = this.findChild(path);\n    if (!r) { return undefined; }\n\n    // found an element, check if it's a resource (duck-type)\n    if (!('resourceType' in r)) {\n      throw new Error(`Found a stack element for ${path} but it is not a resource: ${r.toString()}`);\n    }\n\n    return r as Resource;\n  }\n\n  /**\n   * Returns the CloudFormation template for this stack by traversing\n   * the tree and invoking toCloudFormation() on all Entity objects.\n   */\n  public toCloudFormation() {\n    // before we begin synthesis, we shall lock this stack, so children cannot be added\n    this.lock();\n\n    try {\n      const template: any = {\n        Description: this.templateOptions.description,\n        Transform: this.templateOptions.transform,\n        AWSTemplateFormatVersion: this.templateOptions.templateFormatVersion,\n        Metadata: this.templateOptions.metadata\n      };\n\n      const elements = stackElements(this);\n      const fragments = elements.map(e => e.toCloudFormation());\n\n      // merge in all CloudFormation fragments collected from the tree\n      for (const fragment of fragments) {\n        merge(template, fragment);\n      }\n\n      // resolve all tokens and remove all empties\n      const ret = resolve(template) || { };\n\n      this.logicalIds.assertAllRenamesApplied();\n\n      return ret;\n    } finally {\n      // allow mutations after synthesis is finished.\n      this.unlock();\n    }\n  }\n\n  /**\n   * @param why more information about why region is required.\n   * @returns The region in which this stack is deployed. Throws if region is not defined.\n   */\n  public requireRegion(why?: string) {\n    if (!this.env.region) {\n      throw new Error(`${why ? why + '. ' : ''}Stack requires region information. It can be either supplied via the \"env\" property, ` +\n          `via the \"${cxapi.DEFAULT_REGION_CONTEXT_KEY}\" context parameters or using \"aws configure\"`);\n    }\n\n    return this.env.region;\n  }\n\n  /**\n   * Returns the AWS account ID of this Stack,\n   * or throws an exception if the account ID is not set in the environment.\n   *\n   * @param why more information about why is the account ID required\n   * @returns the AWS account ID of this Stack\n   */\n  public requireAccountId(why?: string): string {\n    if (!this.env.account) {\n      throw new Error(`${why ? why + '. ' : ''}Stack requires account information. ` +\n        'It can be supplied either via the \"env\" property when creating the Stack, or by using \"aws configure\"');\n    }\n\n    return this.env.account;\n  }\n\n  public parentApp(): App | undefined {\n    const parent = this.parent;\n    return parent instanceof App\n      ? parent\n      : undefined;\n  }\n\n  /**\n   * Indicate that a context key was expected\n   *\n   * Contains instructions on how the key should be supplied.\n   * @param key Key that uniquely identifies this missing context.\n   * @param details The set of parameters needed to obtain the context (specific to context provider).\n   */\n  public reportMissingContext(key: string, details: cxapi.MissingContext) {\n    this.missingContext[key] = details;\n  }\n\n  /**\n   * Rename a generated logical identities\n   */\n  public renameLogical(oldId: string, newId: string) {\n    // tslint:disable-next-line:no-console\n    if (this.children.length > 0) {\n      throw new Error(\"All renames must be set up before adding elements to the stack\");\n    }\n\n    this.logicalIds.renameLogical(oldId, newId);\n  }\n\n  /**\n   * Validate stack name\n   *\n   * CloudFormation stack names can include dashes in addition to the regular identifier\n   * character classes, and we don't allow one of the magic markers.\n   */\n  protected _validateId(name: string) {\n    if (!Stack.VALID_STACK_NAME_REGEX.test(name)) {\n      throw new Error(`Stack name must match the regular expression: ${Stack.VALID_STACK_NAME_REGEX.toString()}, got '${name}'`);\n    }\n  }\n\n  /**\n   * Applied defaults to environment attributes.\n   */\n  private parseEnvironment(props?: StackProps) {\n    // start with `env`.\n    const env: Environment = (props && props.env) || { };\n\n    // if account is not specified, attempt to read from context.\n    if (!env.account) {\n      env.account = this.getContext(cxapi.DEFAULT_ACCOUNT_CONTEXT_KEY);\n    }\n\n    // if region is not specified, attempt to read from context.\n    if (!env.region) {\n      env.region = this.getContext(cxapi.DEFAULT_REGION_CONTEXT_KEY);\n    }\n\n    return env;\n  }\n}\n\nfunction merge(template: any, part: any) {\n  for (const section of Object.keys(part)) {\n    const src = part[section];\n\n    // create top-level section if it doesn't exist\n    let dest = template[section];\n    if (!dest) {\n      template[section] = dest = src;\n    } else {\n      // add all entities from source section to destination section\n      for (const id of Object.keys(src)) {\n        if (id in dest) {\n          throw new Error(`section '${section}' already contains '${id}'`);\n        }\n        dest[id] = src[id];\n      }\n    }\n  }\n}\n\nconst LOGICAL_ID_MD = 'aws:cdk:logicalId';\n\n/**\n * Represents a construct that can be \"depended on\" via `addDependency`.\n */\nexport interface IDependable {\n  /**\n   * Returns the set of all stack elements (resources, parameters, conditions)\n   * that should be added when a resource \"depends on\" this construct.\n   */\n  readonly dependencyElements: IDependable[];\n}\n\n/**\n * An element of a CloudFormation stack.\n */\nexport abstract class StackElement extends Construct implements IDependable {\n  /**\n   * Returns `true` if a construct is a stack element (i.e. part of the\n   * synthesized cloudformation template).\n   *\n   * Uses duck-typing instead of `instanceof` to allow stack elements from different\n   * versions of this library to be included in the same stack.\n   *\n   * @returns The construct as a stack element or undefined if it is not a stack element.\n   */\n  public static _asStackElement(construct: Construct): StackElement | undefined {\n    if ('logicalId' in construct && 'toCloudFormation' in construct) {\n      return construct as StackElement;\n    } else {\n      return undefined;\n    }\n  }\n\n  /**\n   * The logical ID for this CloudFormation stack element\n   */\n  public readonly logicalId: string;\n\n  /**\n   * The stack this Construct has been made a part of\n   */\n  protected stack: Stack;\n\n  /**\n   * Creates an entity and binds it to a tree.\n   * Note that the root of the tree must be a Stack object (not just any Root).\n   *\n   * @param parent The parent construct\n   * @param props Construct properties\n   */\n  constructor(parent: Construct, name: string) {\n    super(parent, name);\n    const s = Stack.find(this);\n    if (!s) {\n      throw new Error('The tree root must be derived from \"Stack\"');\n    }\n    this.stack = s;\n\n    this.addMetadata(LOGICAL_ID_MD, new Token(() => this.logicalId), this.constructor);\n\n    this.logicalId = this.stack.logicalIds.getLogicalId(this);\n  }\n\n  /**\n   * @returns the stack trace of the point where this Resource was created from, sourced\n   *      from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most\n   *      node +internal+ entries filtered.\n   */\n  public get creationStackTrace(): string[] {\n    return filterStackTrace(this.metadata.find(md => md.type === LOGICAL_ID_MD)!.trace);\n\n    function filterStackTrace(stack: string[]): string[] {\n      const result = Array.of(...stack);\n      while (result.length > 0 && shouldFilter(result[result.length - 1])) {\n        result.pop();\n      }\n      // It's weird if we filtered everything, so return the whole stack...\n      return result.length === 0 ? stack : result;\n    }\n\n    function shouldFilter(str: string): boolean {\n      return str.match(/[^(]+\\(internal\\/.*/) !== null;\n    }\n  }\n\n  /**\n   * Return the path with respect to the stack\n   */\n  public get stackPath(): string {\n    return this.ancestors(this.stack).map(c => c.id).join(PATH_SEP);\n  }\n\n  public get dependencyElements(): IDependable[] {\n    return [ this ];\n  }\n\n  /**\n   * Returns the CloudFormation 'snippet' for this entity. The snippet will only be merged\n   * at the root level to ensure there are no identity conflicts.\n   *\n   * For example, a Resource class will return something like:\n   * {\n   *   Resources: {\n   *     [this.logicalId]: {\n   *       Type: this.resourceType,\n   *       Properties: this.props,\n   *       Condition: this.condition\n   *     }\n   *   }\n   * }\n   */\n  public abstract toCloudFormation(): object;\n}\n\n/**\n * CloudFormation template options for a stack.\n */\nexport interface TemplateOptions {\n  /**\n   * Gets or sets the description of this stack.\n   * If provided, it will be included in the CloudFormation template's \"Description\" attribute.\n   */\n  description?: string;\n\n  /**\n   * Gets or sets the AWSTemplateFormatVersion field of the CloudFormation template.\n   */\n  templateFormatVersion?: string;\n\n  /**\n   * Gets or sets the top-level template transform for this stack (e.g. \"AWS::Serverless-2016-10-31\").\n   */\n  transform?: string;\n\n  /**\n   * Metadata associated with the CloudFormation template.\n   */\n   metadata?: { [key: string]: any };\n}\n\n/**\n * Base class for referenceable CloudFormation constructs which are not Resources\n *\n * These constructs are things like Conditions and Parameters, can be\n * referenced by taking the `.ref` attribute.\n *\n * Resource constructs do not inherit from Referenceable because they have their\n * own, more specific types returned from the .ref attribute. Also, some\n * resources aren't referenceable at all (such as BucketPolicies or GatewayAttachments).\n */\nexport abstract class Referenceable extends StackElement {\n  /**\n   * Returns a token to a CloudFormation { Ref } that references this entity based on it's logical ID.\n   */\n  public get ref(): string {\n    return new Ref(this).toString();\n  }\n}\n\n/**\n * Return whether the given object is a Stack.\n *\n * We do attribute detection since we can't reliably use 'instanceof'.\n */\nfunction isStack(construct: Construct): construct is Stack {\n  return (construct as any).isStack;\n}\n\n/**\n * Collect all StackElements from a construct\n *\n * @param node Root node to collect all StackElements from\n * @param into Array to append StackElements to\n * @returns The same array as is being collected into\n */\nfunction stackElements(node: Construct, into: StackElement[] = []): StackElement[] {\n  const element = StackElement._asStackElement(node);\n  if (element) {\n    into.push(element);\n  }\n\n  for (const child of node.children) {\n    stackElements(child, into);\n  }\n\n  return into;\n}\n\n/**\n * A generic, untyped reference to a Stack Element\n */\nexport class Ref extends CloudFormationToken {\n  constructor(element: StackElement) {\n    super({ Ref: element.logicalId }, `${element.logicalId}.Ref`);\n  }\n}\n"]}

2

node_modules/cli-color/package.json

@@ -24,3 +24,3 @@ {

"_spec": "cli-color@~0.1.6",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk/node_modules/json-diff",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk/node_modules/json-diff",
"author": {

@@ -27,0 +27,0 @@ "name": "Mariusz Nowak",

@@ -24,3 +24,3 @@ {

"_spec": "difflib@~0.2.1",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk/node_modules/json-diff",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk/node_modules/json-diff",
"author": {

@@ -27,0 +27,0 @@ "name": "Xueqiao Xu",

@@ -24,3 +24,3 @@ {

"_spec": "dreamopt@~0.6.0",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk/node_modules/json-diff",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk/node_modules/json-diff",
"author": {

@@ -27,0 +27,0 @@ "name": "Andrey Tarantsov",

@@ -24,3 +24,3 @@ {

"_spec": "es5-ext@0.8.x",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk/node_modules/cli-color",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk/node_modules/cli-color",
"author": {

@@ -27,0 +27,0 @@ "name": "Mariusz Nowak",

@@ -24,3 +24,3 @@ {

"_spec": "heap@>= 0.2.0",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk/node_modules/difflib",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk/node_modules/difflib",
"author": {

@@ -27,0 +27,0 @@ "name": "Xueqiao Xu",

@@ -24,3 +24,3 @@ {

"_spec": "js-base64@^2.4.5",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk",
"author": {

@@ -27,0 +27,0 @@ "name": "Dan Kogai"

@@ -24,3 +24,3 @@ {

"_spec": "json-diff@^0.3.1",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk",
"author": {

@@ -27,0 +27,0 @@ "name": "Andrey Tarantsov",

@@ -24,3 +24,3 @@ {

"_spec": "wordwrap@>=0.0.2",
"_where": "/codebuild/output/src680494326/src/packages/@aws-cdk/cdk/node_modules/dreamopt",
"_where": "/codebuild/output/src254171234/src/packages/@aws-cdk/cdk/node_modules/dreamopt",
"author": {

@@ -27,0 +27,0 @@ "name": "James Halliday",

{
"name": "@aws-cdk/cdk",
"version": "0.16.0",
"version": "0.17.0",
"description": "AWS Cloud Development Kit Core Library",

@@ -57,10 +57,10 @@ "main": "lib/index.js",

"@types/lodash": "^4.14.117",
"cdk-build-tools": "^0.16.0",
"cfn2ts": "^0.16.0",
"cdk-build-tools": "^0.17.0",
"cfn2ts": "^0.17.0",
"fast-check": "^1.7.0",
"lodash": "^4.17.11",
"pkglint": "^0.16.0"
"pkglint": "^0.17.0"
},
"dependencies": {
"@aws-cdk/cx-api": "^0.16.0",
"@aws-cdk/cx-api": "^0.17.0",
"js-base64": "^2.4.5",

@@ -75,4 +75,4 @@ "json-diff": "^0.3.1"

"peerDependencies": {
"@aws-cdk/cx-api": "^0.16.0"
"@aws-cdk/cx-api": "^0.17.0"
}
}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc