UNPKG

projen

Version:

CDK for software projects

178 lines • 19.8 kB
"use strict"; var _a, _b, _c, _d; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApprovalLevel = exports.CdkConfig = exports.CdkFeatureFlags = exports.CdkFeatureFlagsV2 = exports.CdkFeatureFlagsV1 = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const fast_json_patch_1 = require("fast-json-patch"); const component_1 = require("../component"); const json_1 = require("../json"); const util_1 = require("../util"); const internal_1 = require("./internal"); /** * CDK V1 feature flags configuration. * @deprecated CDK V1 is EOS. Upgrade to CDK V2. */ class CdkFeatureFlagsV1 { constructor(flags) { this.flags = flags; } } exports.CdkFeatureFlagsV1 = CdkFeatureFlagsV1; _a = JSII_RTTI_SYMBOL_1; CdkFeatureFlagsV1[_a] = { fqn: "projen.awscdk.CdkFeatureFlagsV1", version: "0.99.3" }; /** * Disable all feature flags. */ CdkFeatureFlagsV1.NONE = new CdkFeatureFlagsV1({}); /** * Enable all CDK V1 feature flags. */ CdkFeatureFlagsV1.ALL = new CdkFeatureFlagsV1(internal_1.FEATURE_FLAGS_V1); /** * CDK V2 feature flags configuration. */ class CdkFeatureFlagsV2 { /** * Attempt to load the feature flags from the `aws-cdk-lib/recommended-feature-flags.json` in a locally available npm package. * This file is typically only present in AWS CDK TypeScript projects, but can yield more accurate results. * * Falls back to all known feature flags if not found. */ static fromLocalAwsCdkLib() { try { const featureFlags = (0, util_1.tryReadFileSync)(require.resolve("aws-cdk-lib/recommended-feature-flags.json", { paths: [process.cwd()], })) || "{}"; return new CdkFeatureFlagsV2(JSON.parse(featureFlags)); } catch { return CdkFeatureFlags.V2.ALL; } } constructor(flags) { this.flags = flags; } } exports.CdkFeatureFlagsV2 = CdkFeatureFlagsV2; _b = JSII_RTTI_SYMBOL_1; CdkFeatureFlagsV2[_b] = { fqn: "projen.awscdk.CdkFeatureFlagsV2", version: "0.99.3" }; /** * Disable all feature flags. */ CdkFeatureFlagsV2.NONE = new CdkFeatureFlagsV2({}); /** * Enable all CDK V2 feature flags known to projen. * These might not include feature flags, if your version of projen isn't up-to-date. * * Make sure to double-check any changes to feature flags in `cdk.json` before deploying. * Unexpected changes may cause breaking changes in your CDK app. * You can overwrite any feature flag by passing it into the context field. */ CdkFeatureFlagsV2.ALL = new CdkFeatureFlagsV2(internal_1.FEATURE_FLAGS_V2); /** * CDK feature flags configuration. */ class CdkFeatureFlags { constructor(flags) { this.flags = flags; } } exports.CdkFeatureFlags = CdkFeatureFlags; _c = JSII_RTTI_SYMBOL_1; CdkFeatureFlags[_c] = { fqn: "projen.awscdk.CdkFeatureFlags", version: "0.99.3" }; /** * CDK V1 feature flags configuration. * @deprecated CDK V1 is EOS. Upgrade to CDK V2. */ CdkFeatureFlags.V1 = CdkFeatureFlagsV1; /** * CDK V2 feature flags configuration. */ CdkFeatureFlags.V2 = CdkFeatureFlagsV2; /** * Represents cdk.json file. */ class CdkConfig extends component_1.Component { constructor(project, options) { super(project); this.cdkout = options.cdkout ?? "cdk.out"; this._include = options.watchIncludes ?? []; this._exclude = options.watchExcludes ?? []; const flags = options.featureFlags?.flags ?? {}; this._context = { ...flags, // Customer context should take precedence over the default feature flags ...(options.context ?? {}), }; this.json = new json_1.JsonFile(project, "cdk.json", { omitEmpty: true, obj: { app: options.app, context: this._context, requireApproval: options.requireApproval, output: this.cdkout, build: options.buildCommand, watch: { include: () => this._include, exclude: () => this._exclude, }, }, }); project.gitignore.exclude(`/${this.cdkout}/`); project.gitignore.exclude(".cdk.staging/"); } /** * Add includes to `cdk.json`. * @param patterns The includes to add. */ addIncludes(...patterns) { this._include.push(...patterns); } /** * Add excludes to `cdk.json`. * @param patterns The excludes to add. */ addExcludes(...patterns) { this._exclude.push(...patterns); } /** * List of glob patterns to be included by CDK. */ get include() { return [...this._include]; } /** * List of glob patterns to be excluded by CDK. */ get exclude() { return [...this._exclude]; } /** * The context to write to cdk.json. */ get context() { return (0, fast_json_patch_1.deepClone)(this._context); } } exports.CdkConfig = CdkConfig; _d = JSII_RTTI_SYMBOL_1; CdkConfig[_d] = { fqn: "projen.awscdk.CdkConfig", version: "0.99.3" }; /** * Which approval is required when deploying CDK apps. */ var ApprovalLevel; (function (ApprovalLevel) { /** * Approval is never required */ ApprovalLevel["NEVER"] = "never"; /** * Requires approval on any IAM or security-group-related change */ ApprovalLevel["ANY_CHANGE"] = "any-change"; /** * Requires approval when IAM statements or traffic rules are added; removals don't require approval */ ApprovalLevel["BROADENING"] = "broadening"; })(ApprovalLevel || (exports.ApprovalLevel = ApprovalLevel = {})); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-config.js","sourceRoot":"","sources":["../../src/awscdk/cdk-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { deepClone } from \"fast-json-patch\";\nimport { Component } from \"../component\";\nimport { JsonFile } from \"../json\";\nimport { Project } from \"../project\";\nimport { tryReadFileSync } from \"../util\";\nimport { FEATURE_FLAGS_V1, FEATURE_FLAGS_V2 } from \"./internal\";\n\n/**\n * CDK V1 feature flags configuration.\n * @deprecated CDK V1 is EOS. Upgrade to CDK V2.\n */\nexport class CdkFeatureFlagsV1 implements ICdkFeatureFlags {\n  /**\n   * Disable all feature flags.\n   */\n  public static readonly NONE = new CdkFeatureFlagsV1({});\n\n  /**\n   * Enable all CDK V1 feature flags.\n   */\n  public static readonly ALL = new CdkFeatureFlagsV1(FEATURE_FLAGS_V1);\n\n  public readonly flags: Record<string, unknown>;\n\n  private constructor(flags: Record<string, unknown>) {\n    this.flags = flags;\n  }\n}\n\n/**\n * CDK V2 feature flags configuration.\n */\nexport class CdkFeatureFlagsV2 implements ICdkFeatureFlags {\n  /**\n   * Disable all feature flags.\n   */\n  public static readonly NONE = new CdkFeatureFlagsV2({});\n\n  /**\n   * Enable all CDK V2 feature flags known to projen.\n   * These might not include feature flags, if your version of projen isn't up-to-date.\n   *\n   * Make sure to double-check any changes to feature flags in `cdk.json` before deploying.\n   * Unexpected changes may cause breaking changes in your CDK app.\n   * You can overwrite any feature flag by passing it into the context field.\n   */\n  public static readonly ALL = new CdkFeatureFlagsV2(FEATURE_FLAGS_V2);\n\n  /**\n   * Attempt to load the feature flags from the `aws-cdk-lib/recommended-feature-flags.json` in a locally available npm package.\n   * This file is typically only present in AWS CDK TypeScript projects, but can yield more accurate results.\n   *\n   * Falls back to all known feature flags if not found.\n   */\n  public static fromLocalAwsCdkLib() {\n    try {\n      const featureFlags =\n        tryReadFileSync(\n          require.resolve(\"aws-cdk-lib/recommended-feature-flags.json\", {\n            paths: [process.cwd()],\n          })\n        ) || \"{}\";\n\n      return new CdkFeatureFlagsV2(JSON.parse(featureFlags));\n    } catch {\n      return CdkFeatureFlags.V2.ALL;\n    }\n  }\n\n  public readonly flags: Record<string, unknown>;\n\n  private constructor(flags: Record<string, unknown>) {\n    this.flags = flags;\n  }\n}\n\n/**\n *\n * @subclassable\n */\nexport interface ICdkFeatureFlags {\n  readonly flags: Record<string, unknown>;\n}\n\n/**\n * CDK feature flags configuration.\n */\nexport class CdkFeatureFlags implements ICdkFeatureFlags {\n  /**\n   * CDK V1 feature flags configuration.\n   * @deprecated CDK V1 is EOS. Upgrade to CDK V2.\n   */\n  public static readonly V1 = CdkFeatureFlagsV1;\n\n  /**\n   * CDK V2 feature flags configuration.\n   */\n  public static readonly V2 = CdkFeatureFlagsV2;\n\n  public readonly flags: Record<string, unknown>;\n\n  private constructor(flags: Record<string, unknown>) {\n    this.flags = flags;\n  }\n}\n\n/**\n * Common options for `cdk.json`.\n */\nexport interface CdkConfigCommonOptions {\n  /**\n   * Additional context to include in `cdk.json`.\n   *\n   * @default - no additional context\n   */\n  readonly context?: { [key: string]: any };\n\n  /**\n   * Feature flags that should be enabled in `cdk.json`.\n   *\n   * Make sure to double-check any changes to feature flags in `cdk.json` before deploying.\n   * Unexpected changes may cause breaking changes in your CDK app.\n   * You can overwrite any feature flag by passing it into the context field.\n   *\n   * @default - no feature flags are enabled by default\n   */\n  readonly featureFlags?: ICdkFeatureFlags;\n\n  /**\n   * To protect you against unintended changes that affect your security posture,\n   * the AWS CDK Toolkit prompts you to approve security-related changes before deploying them.\n   *\n   * @default ApprovalLevel.BROADENING\n   */\n  readonly requireApproval?: ApprovalLevel;\n\n  /**\n   * cdk.out directory.\n   *\n   * @default \"cdk.out\"\n   */\n  readonly cdkout?: string;\n\n  /**\n   * A command to execute before synthesis. This command will be called when\n   * running `cdk synth` or when `cdk watch` identifies a change in your source\n   * code before redeployment.\n   *\n   * @default - no build command\n   */\n  readonly buildCommand?: string;\n\n  /**\n   * Glob patterns to include in `cdk watch`.\n   *\n   * @default []\n   */\n  readonly watchIncludes?: string[];\n\n  /**\n   * Glob patterns to exclude from `cdk watch`.\n   *\n   * @default []\n   */\n  readonly watchExcludes?: string[];\n}\n\n/**\n * Options for `CdkJson`.\n */\nexport interface CdkConfigOptions extends CdkConfigCommonOptions {\n  /**\n   * The command line to execute in order to synthesize the CDK application\n   * (language specific).\n   */\n  readonly app: string;\n}\n\n/**\n * Represents cdk.json file.\n */\nexport class CdkConfig extends Component {\n  /**\n   * Represents the JSON file.\n   */\n  public readonly json: JsonFile;\n\n  /**\n   * Name of the cdk.out directory.\n   */\n  public readonly cdkout: string;\n\n  /**\n   * List of glob patterns to be included by CDK.\n   */\n  private readonly _include: string[];\n\n  /**\n   * List of glob patterns to be excluded by CDK.\n   */\n  private readonly _exclude: string[];\n\n  /**\n   * The context to write to cdk.json.\n   */\n  private readonly _context: Record<string, unknown>;\n\n  constructor(project: Project, options: CdkConfigOptions) {\n    super(project);\n\n    this.cdkout = options.cdkout ?? \"cdk.out\";\n    this._include = options.watchIncludes ?? [];\n    this._exclude = options.watchExcludes ?? [];\n\n    const flags: Record<string, unknown> = options.featureFlags?.flags ?? {};\n    this._context = {\n      ...flags,\n      // Customer context should take precedence over the default feature flags\n      ...(options.context ?? {}),\n    };\n\n    this.json = new JsonFile(project, \"cdk.json\", {\n      omitEmpty: true,\n      obj: {\n        app: options.app,\n        context: this._context,\n        requireApproval: options.requireApproval,\n        output: this.cdkout,\n        build: options.buildCommand,\n        watch: {\n          include: () => this._include,\n          exclude: () => this._exclude,\n        },\n      },\n    });\n\n    project.gitignore.exclude(`/${this.cdkout}/`);\n    project.gitignore.exclude(\".cdk.staging/\");\n  }\n\n  /**\n   * Add includes to `cdk.json`.\n   * @param patterns The includes to add.\n   */\n  public addIncludes(...patterns: string[]) {\n    this._include.push(...patterns);\n  }\n\n  /**\n   * Add excludes to `cdk.json`.\n   * @param patterns The excludes to add.\n   */\n  public addExcludes(...patterns: string[]) {\n    this._exclude.push(...patterns);\n  }\n\n  /**\n   * List of glob patterns to be included by CDK.\n   */\n  public get include(): string[] {\n    return [...this._include];\n  }\n\n  /**\n   * List of glob patterns to be excluded by CDK.\n   */\n  public get exclude(): string[] {\n    return [...this._exclude];\n  }\n\n  /**\n   * The context to write to cdk.json.\n   */\n  public get context(): Record<string, unknown> {\n    return deepClone(this._context);\n  }\n}\n\n/**\n * Which approval is required when deploying CDK apps.\n */\nexport enum ApprovalLevel {\n  /**\n   * Approval is never required\n   */\n  NEVER = \"never\",\n  /**\n   * Requires approval on any IAM or security-group-related change\n   */\n  ANY_CHANGE = \"any-change\",\n  /**\n   * Requires approval when IAM statements or traffic rules are added; removals don't require approval\n   */\n  BROADENING = \"broadening\",\n}\n"]}