UNPKG

projen

Version:

CDK for software projects

229 lines • 37.7 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.AwsCdkDeps = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const semver = require("semver"); const component_1 = require("../component"); const dependencies_1 = require("../dependencies"); /** * Manages dependencies on the AWS CDK. */ class AwsCdkDeps extends component_1.Component { constructor(project, options) { super(project); this.cdkDependenciesAsDeps = options.cdkDependenciesAsDeps ?? true; this.dependencyType = options.dependencyType; this._packageNames = this.packageNames(); const framework = determineFrameworkVersion(options); this.cdkCliVersion = options.cdkCliVersion ?? "^2"; this.cdkVersion = framework.range; this.cdkMajorVersion = framework.major; this.cdkMinimumVersion = framework.minimum; this.addFrameworkDependency(options); // assert/assertions library this.addV1AssertionLibraryDependency(options); // constructs library this.addConstructsDependency(options.constructsVersion); // user-defined v1 dependencies (will only fail in CDK v2 if these have values) this.addV1Dependencies(...(options.cdkDependencies ?? [])); this.addV1DevDependencies(...(options.cdkTestDependencies ?? [])); } preSynthesize() { // Log a warning if any AWS CDK v1-only deps are found in the dependencies. const depNames = Array.from(new Set(this.project.deps.all.map((dep) => dep.name))); const v1Deps = depNames .filter((dep) => [PACKAGE_AWS_CDK_VERSION.V1].includes(cdkVersionOfPackage(dep))) .sort(); if (this.cdkMajorVersion === 2 && v1Deps.length > 0) { this.project.logger.warn(`WARNING: Found CDK v1 deps in your project, even though your "cdkVersion" is 2.x: [${v1Deps.join(", ")}]. Check out https://docs.aws.amazon.com/cdk/v2/guide/migrating-v2.html for more information about using CDK v2 dependencies.`); } } /** * Adds dependencies to AWS CDK modules. * * The type of dependency is determined by the `dependencyType` option. * * This method is not supported in CDK v2. Use `project.addPeerDeps()` or * `project.addDeps()` as appropriate. * * @param deps names of cdk modules (e.g. `@aws-cdk/aws-lambda`). */ addV1Dependencies(...deps) { if (deps.length > 0 && this.cdkMajorVersion !== 1) { throw new Error("addV1Dependencies() is not supported for CDK 2.x and above, use addDeps() or addPeerDeps() instead"); } // this will add dependencies based on the type requested by the user // for libraries, this will be "peer" and for apps it will be "runtime" this.addV1DependenciesByType(this.dependencyType, ...deps); // add deps as runtime deps if `cdkDepsAsDeps` is true if (this.cdkDependenciesAsDeps) { this.addV1DependenciesByType(dependencies_1.DependencyType.RUNTIME, ...deps); } } /** * Adds AWS CDK modules as dev dependencies. * * This method is not supported in CDK v2. Use `project.addPeerDeps()` or * `project.addDeps()` as appropriate. * * @param deps fully qualified names of cdk modules (e.g. `@aws-cdk/aws-lambda`). */ addV1DevDependencies(...deps) { if (deps.length > 0 && this.cdkMajorVersion !== 1) { throw new Error("addV1DevDependencies() is not supported for CDK 2.x and above, use addDevDeps()/addTestDeps() instead"); } this.addV1DependenciesByType(dependencies_1.DependencyType.BUILD, ...deps); } addConstructsDependency(requestedVersion) { if (requestedVersion && !semver.parse(requestedVersion)) { throw new Error(`"constructsVersion" cannot be parsed as a semver version: ${requestedVersion}`); } const defaultVersion = this.cdkMajorVersion === 1 ? "3.2.27" : "10.5.1"; const versionRequirement = `^${requestedVersion ?? defaultVersion}`; const constructsMajorVersion = semver.minVersion(versionRequirement)?.major; if (!constructsMajorVersion) { throw new Error(`Cannot determine major version of constructs version '${versionRequirement}'`); } switch (this.cdkMajorVersion) { case 1: if (constructsMajorVersion !== 3) { throw new Error("AWS CDK 1.x requires constructs 3.x"); } break; case 2: if (constructsMajorVersion !== 10) { throw new Error("AWS CDK 2.x requires constructs 10.x"); } break; } // First remove the version added by projen this.project.deps.removeDependency("constructs", dependencies_1.DependencyType.BUILD); // Add the version for CDK this.project.deps.addDependency(`${this._packageNames.constructs}@${versionRequirement}`, this.dependencyType); return versionRequirement; } /** * Adds a dependency on the AWS CDK framework (e.g. `@aws-cdk/core` for V1 or `aws-cdk-lib` for V1). */ addFrameworkDependency(options) { switch (this.cdkMajorVersion) { case 1: this.addV1Dependencies(this._packageNames.coreV1); break; case 2: if (options.cdkDependencies !== undefined) { throw new Error('cdkDependencies is not used for CDK 2.x. Use "peerDeps" or "deps" instead'); } if (options.cdkDependenciesAsDeps !== undefined) { throw new Error("cdkDependenciesAsDeps is not used for CDK 2.x"); } if (options.cdkTestDependencies !== undefined) { throw new Error('cdkTestDependencies is not used for CDK 2.x. Use "devDeps" or "testDeps" instead'); } this.project.deps.addDependency(`${this._packageNames.coreV2}@${this.cdkVersion}`, this.dependencyType); break; default: throw new Error(`Unsupported AWS CDK major version ${this.cdkMajorVersion}.x`); } } addV1AssertionLibraryDependency(options) { if (this.cdkMajorVersion !== 1) { if (options.cdkAssert !== undefined) { throw new Error("cdkAssert is not used for CDK 2.x. Use the assertions library that is provided in aws-cdk-lib"); } if (options.cdkAssertions !== undefined) { throw new Error("cdkAssertion is not used for CDK 2.x. Use the assertions library that is provided in aws-cdk-lib"); } return; } const testDeps = new Array(); if ((options.cdkAssert ?? true) && this._packageNames.assert) { testDeps.push(this._packageNames.assert); } // @aws-cdk/assertions is only available starting v1.111.0 if (semver.gte(this.cdkMinimumVersion, "1.111.0") && (options.cdkAssertions ?? true)) { testDeps.push(this._packageNames.assertions); } this.addV1DependenciesByType(dependencies_1.DependencyType.TEST, ...testDeps); } /** * Adds a set of dependencies with the user-specified dependency type. * @param deps The set of dependency specifications */ addV1DependenciesByType(type, ...modules) { for (const module of modules) { this.project.deps.addDependency(`${module}@${this.cdkVersion}`, type); } } } exports.AwsCdkDeps = AwsCdkDeps; _a = JSII_RTTI_SYMBOL_1; AwsCdkDeps[_a] = { fqn: "projen.awscdk.AwsCdkDeps", version: "0.99.34" }; /** * Which AWS CDK version a construct library package belongs to. */ var PACKAGE_AWS_CDK_VERSION; (function (PACKAGE_AWS_CDK_VERSION) { PACKAGE_AWS_CDK_VERSION["V1"] = "v1"; PACKAGE_AWS_CDK_VERSION["V2"] = "v2"; PACKAGE_AWS_CDK_VERSION["EITHER"] = "either"; PACKAGE_AWS_CDK_VERSION["UNKNOWN"] = "unknown"; })(PACKAGE_AWS_CDK_VERSION || (PACKAGE_AWS_CDK_VERSION = {})); function cdkVersionOfPackage(packageName) { if (packageName === "aws-cdk-lib") { return PACKAGE_AWS_CDK_VERSION.V2; } else if (packageName.startsWith("@aws-cdk/")) { if (packageName.endsWith("-alpha")) { return PACKAGE_AWS_CDK_VERSION.V2; } else if (AWS_CDK_V1_V2_SCOPED_PACKAGES.includes(packageName)) { return PACKAGE_AWS_CDK_VERSION.EITHER; } else { return PACKAGE_AWS_CDK_VERSION.V1; } } else { return PACKAGE_AWS_CDK_VERSION.UNKNOWN; } } /** * A list of all known packages in the "@aws-cdk/" scope that are published * both for v1 and v2. */ const AWS_CDK_V1_V2_SCOPED_PACKAGES = [ // aws/aws-cdk // @see https://github.com/aws/aws-cdk/tree/main/packages/%40aws-cdk "@aws-cdk/assert", // deprecated "@aws-cdk/cfn-property-mixins", "@aws-cdk/cfnspec", // deprecated "@aws-cdk/cx-api", "@aws-cdk/mixins-preview", "@aws-cdk/region-info", // aws/aws-cdk-cli // @see https://github.com/aws/aws-cdk-cli/tree/main/packages/%40aws-cdk "@aws-cdk/cdk-assets-lib", "@aws-cdk/cli-plugin-contract", "@aws-cdk/cloud-assembly-api", "@aws-cdk/cloud-assembly-schema", "@aws-cdk/cloudformation-diff", "@aws-cdk/integ-runner", "@aws-cdk/toolkit-lib", ]; function determineFrameworkVersion(options) { const ver = semver.parse(options.cdkVersion); if (!ver) { throw new Error(`"cdkVersion" cannot be parsed as a semver version: ${options.cdkVersion}`); } return { minimum: ver.format(), range: options.cdkVersionPinning ? options.cdkVersion : `^${options.cdkVersion}`, major: ver.major, }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"awscdk-deps.js","sourceRoot":"","sources":["../../src/awscdk/awscdk-deps.ts"],"names":[],"mappings":"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","sourcesContent":["import * as semver from \"semver\";\nimport { Component } from \"../component\";\nimport { DependencyType } from \"../dependencies\";\nimport { Project } from \"../project\";\n\n/**\n * Options for `AwsCdkDeps`\n */\nexport interface AwsCdkDepsCommonOptions {\n  /**\n   * Minimum version of the AWS CDK to depend on.\n   *\n   * @default \"2.189.1\"\n   */\n  readonly cdkVersion: string;\n\n  /**\n   * Version range of the AWS CDK CLI to depend on.\n   *\n   * Can be either a specific version, or an NPM version range.\n   *\n   * By default, the latest 2.x version will be installed; you can use this\n   * option to restrict it to a specific version or version range.\n   *\n   * @default \"^2\"\n   */\n  readonly cdkCliVersion?: string;\n\n  /**\n   * Minimum version of the `constructs` library to depend on.\n   *\n   * @default - for CDK 1.x the default is \"3.2.27\", for CDK 2.x the default is\n   * \"10.5.1\".\n   */\n  readonly constructsVersion?: string;\n\n  /**\n   * Use pinned version instead of caret version for CDK.\n   *\n   * You can use this to prevent mixed versions for your CDK dependencies and to prevent auto-updates.\n   * If you use experimental features this will let you define the moment you include breaking changes.\n   */\n  readonly cdkVersionPinning?: boolean;\n\n  /**\n   * Which AWS CDKv1 modules this project requires\n   *\n   * @deprecated For CDK 2.x use \"deps\" instead. (or \"peerDeps\" if you're building a library)\n   */\n  readonly cdkDependencies?: string[];\n\n  /**\n   * If this is enabled (default), all modules declared in `cdkDependencies` will be also added as\n   * normal `dependencies` (as well as `peerDependencies`).\n   *\n   * This is to ensure that downstream consumers actually have your CDK dependencies installed\n   * when using npm < 7 or yarn, where peer dependencies are not automatically installed.\n   * If this is disabled, `cdkDependencies` will be added to `devDependencies` to ensure\n   * they are present during development.\n   *\n   * Note: this setting only applies to construct library projects\n   *\n   * @default true\n   * @deprecated Not supported in CDK v2.\n   */\n  readonly cdkDependenciesAsDeps?: boolean;\n\n  /**\n   * Warning: NodeJS only.\n   * Install the @aws-cdk/assert library?\n   *\n   * @default - will be included by default for AWS CDK >= 1.0.0 < 2.0.0\n   * @deprecated The @aws-cdk/assert library is deprecated in favor of\n   * @aws-cdk/assertions (in V1) and included in `aws-cdk-lib` for V2.\n   */\n  readonly cdkAssert?: boolean;\n\n  /**\n   * Install the assertions library?\n   *\n   * Only needed for CDK 1.x. If using CDK 2.x then\n   * assertions is already included in 'aws-cdk-lib'\n   *\n   * @default - will be included by default for AWS CDK >= 1.111.0 < 2.0.0\n   */\n  readonly cdkAssertions?: boolean;\n\n  /**\n   * AWS CDK modules required for testing.\n   *\n   * @deprecated For CDK 2.x use 'devDeps' (in node.js projects) or 'testDeps' (in java projects) instead\n   */\n  readonly cdkTestDependencies?: string[];\n}\n\nexport interface AwsCdkDepsOptions extends AwsCdkDepsCommonOptions {\n  /**\n   * The type of dependency to use for runtime AWS CDK and `constructs` modules.\n   *\n   * For libraries, use peer dependencies and for apps use runtime dependencies.\n   */\n  readonly dependencyType: DependencyType;\n}\n\n/**\n * Language-specific AWS CDK package names.\n */\nexport interface AwsCdkPackageNames {\n  /**\n   * Fully qualified name of the core framework package for CDKv1\n   */\n  readonly coreV1: string;\n  /**\n   * Fully qualified name of the core framework package for CDKv2\n   */\n  readonly coreV2: string;\n  /**\n   * Fully qualified name of the constructs library package\n   */\n  readonly constructs: string;\n  /**\n   * Fully qualified name of the assertions library package\n   */\n  readonly assertions: string;\n  /**\n   * Fully qualified name of the assert library package\n   * Can be empty as it's only really available for javascript projects\n   */\n  readonly assert?: string;\n}\n\n/**\n * Manages dependencies on the AWS CDK.\n */\nexport abstract class AwsCdkDeps extends Component {\n  /**\n   * The dependency requirement for AWS CDK (e.g. `^2.0.0`).\n   */\n  public readonly cdkVersion: string;\n\n  /**\n   * The dependency requirement for the CDK CLI (e.g. '^2.3.4').\n   *\n   * Will return `^2` if the version was unspecified by the user.\n   */\n  public readonly cdkCliVersion: string;\n\n  /**\n   * The minimum version of the AWS CDK (e.g. `2.0.0`).\n   */\n  public readonly cdkMinimumVersion: string;\n\n  /**\n   * Whether CDK dependencies are added as normal dependencies (and peer dependencies).\n   * @deprecated Not used for CDK 2.x\n   */\n  public readonly cdkDependenciesAsDeps: boolean;\n\n  /**\n   * The major version of the AWS CDK (e.g. 1, 2, ...)\n   */\n  public readonly cdkMajorVersion: number;\n\n  private readonly dependencyType: DependencyType;\n\n  private readonly _packageNames: AwsCdkPackageNames;\n\n  constructor(project: Project, options: AwsCdkDepsOptions) {\n    super(project);\n\n    this.cdkDependenciesAsDeps = options.cdkDependenciesAsDeps ?? true;\n\n    this.dependencyType = options.dependencyType;\n    this._packageNames = this.packageNames();\n\n    const framework = determineFrameworkVersion(options);\n\n    this.cdkCliVersion = options.cdkCliVersion ?? \"^2\";\n    this.cdkVersion = framework.range;\n    this.cdkMajorVersion = framework.major;\n    this.cdkMinimumVersion = framework.minimum;\n\n    this.addFrameworkDependency(options);\n\n    // assert/assertions library\n    this.addV1AssertionLibraryDependency(options);\n\n    // constructs library\n    this.addConstructsDependency(options.constructsVersion);\n\n    // user-defined v1 dependencies (will only fail in CDK v2 if these have values)\n    this.addV1Dependencies(...(options.cdkDependencies ?? []));\n    this.addV1DevDependencies(...(options.cdkTestDependencies ?? []));\n  }\n\n  public preSynthesize(): void {\n    // Log a warning if any AWS CDK v1-only deps are found in the dependencies.\n    const depNames = Array.from(\n      new Set(this.project.deps.all.map((dep) => dep.name)),\n    );\n    const v1Deps = depNames\n      .filter((dep) =>\n        [PACKAGE_AWS_CDK_VERSION.V1].includes(cdkVersionOfPackage(dep)),\n      )\n      .sort();\n    if (this.cdkMajorVersion === 2 && v1Deps.length > 0) {\n      this.project.logger.warn(\n        `WARNING: Found CDK v1 deps in your project, even though your \"cdkVersion\" is 2.x: [${v1Deps.join(\n          \", \",\n        )}]. Check out https://docs.aws.amazon.com/cdk/v2/guide/migrating-v2.html for more information about using CDK v2 dependencies.`,\n      );\n    }\n  }\n\n  /**\n   * Adds dependencies to AWS CDK modules.\n   *\n   * The type of dependency is determined by the `dependencyType` option.\n   *\n   * This method is not supported in CDK v2. Use `project.addPeerDeps()` or\n   * `project.addDeps()` as appropriate.\n   *\n   * @param deps names of cdk modules (e.g. `@aws-cdk/aws-lambda`).\n   */\n  public addV1Dependencies(...deps: string[]) {\n    if (deps.length > 0 && this.cdkMajorVersion !== 1) {\n      throw new Error(\n        \"addV1Dependencies() is not supported for CDK 2.x and above, use addDeps() or addPeerDeps() instead\",\n      );\n    }\n\n    // this will add dependencies based on the type requested by the user\n    // for libraries, this will be \"peer\" and for apps it will be \"runtime\"\n    this.addV1DependenciesByType(this.dependencyType, ...deps);\n\n    // add deps as runtime deps if `cdkDepsAsDeps` is true\n    if (this.cdkDependenciesAsDeps) {\n      this.addV1DependenciesByType(DependencyType.RUNTIME, ...deps);\n    }\n  }\n\n  /**\n   * Adds AWS CDK modules as dev dependencies.\n   *\n   * This method is not supported in CDK v2. Use `project.addPeerDeps()` or\n   * `project.addDeps()` as appropriate.\n   *\n   * @param deps fully qualified names of cdk modules (e.g. `@aws-cdk/aws-lambda`).\n   */\n  public addV1DevDependencies(...deps: string[]) {\n    if (deps.length > 0 && this.cdkMajorVersion !== 1) {\n      throw new Error(\n        \"addV1DevDependencies() is not supported for CDK 2.x and above, use addDevDeps()/addTestDeps() instead\",\n      );\n    }\n\n    this.addV1DependenciesByType(DependencyType.BUILD, ...deps);\n  }\n\n  private addConstructsDependency(requestedVersion: string | undefined) {\n    if (requestedVersion && !semver.parse(requestedVersion)) {\n      throw new Error(\n        `\"constructsVersion\" cannot be parsed as a semver version: ${requestedVersion}`,\n      );\n    }\n\n    const defaultVersion = this.cdkMajorVersion === 1 ? \"3.2.27\" : \"10.5.1\";\n    const versionRequirement = `^${requestedVersion ?? defaultVersion}`;\n\n    const constructsMajorVersion = semver.minVersion(versionRequirement)?.major;\n    if (!constructsMajorVersion) {\n      throw new Error(\n        `Cannot determine major version of constructs version '${versionRequirement}'`,\n      );\n    }\n\n    switch (this.cdkMajorVersion) {\n      case 1:\n        if (constructsMajorVersion !== 3) {\n          throw new Error(\"AWS CDK 1.x requires constructs 3.x\");\n        }\n        break;\n\n      case 2:\n        if (constructsMajorVersion !== 10) {\n          throw new Error(\"AWS CDK 2.x requires constructs 10.x\");\n        }\n        break;\n    }\n\n    // First remove the version added by projen\n    this.project.deps.removeDependency(\"constructs\", DependencyType.BUILD);\n\n    // Add the version for CDK\n    this.project.deps.addDependency(\n      `${this._packageNames.constructs}@${versionRequirement}`,\n      this.dependencyType,\n    );\n\n    return versionRequirement;\n  }\n\n  /**\n   * Adds a dependency on the AWS CDK framework (e.g. `@aws-cdk/core` for V1 or `aws-cdk-lib` for V1).\n   */\n  private addFrameworkDependency(options: AwsCdkDepsOptions) {\n    switch (this.cdkMajorVersion) {\n      case 1:\n        this.addV1Dependencies(this._packageNames.coreV1);\n        break;\n\n      case 2:\n        if (options.cdkDependencies !== undefined) {\n          throw new Error(\n            'cdkDependencies is not used for CDK 2.x. Use \"peerDeps\" or \"deps\" instead',\n          );\n        }\n        if (options.cdkDependenciesAsDeps !== undefined) {\n          throw new Error(\"cdkDependenciesAsDeps is not used for CDK 2.x\");\n        }\n        if (options.cdkTestDependencies !== undefined) {\n          throw new Error(\n            'cdkTestDependencies is not used for CDK 2.x. Use \"devDeps\" or \"testDeps\" instead',\n          );\n        }\n\n        this.project.deps.addDependency(\n          `${this._packageNames.coreV2}@${this.cdkVersion}`,\n          this.dependencyType,\n        );\n        break;\n\n      default:\n        throw new Error(\n          `Unsupported AWS CDK major version ${this.cdkMajorVersion}.x`,\n        );\n    }\n  }\n\n  private addV1AssertionLibraryDependency(options: AwsCdkDepsOptions) {\n    if (this.cdkMajorVersion !== 1) {\n      if (options.cdkAssert !== undefined) {\n        throw new Error(\n          \"cdkAssert is not used for CDK 2.x. Use the assertions library that is provided in aws-cdk-lib\",\n        );\n      }\n      if (options.cdkAssertions !== undefined) {\n        throw new Error(\n          \"cdkAssertion is not used for CDK 2.x. Use the assertions library that is provided in aws-cdk-lib\",\n        );\n      }\n\n      return;\n    }\n\n    const testDeps = new Array<string>();\n\n    if ((options.cdkAssert ?? true) && this._packageNames.assert) {\n      testDeps.push(this._packageNames.assert);\n    }\n\n    // @aws-cdk/assertions is only available starting v1.111.0\n    if (\n      semver.gte(this.cdkMinimumVersion, \"1.111.0\") &&\n      (options.cdkAssertions ?? true)\n    ) {\n      testDeps.push(this._packageNames.assertions);\n    }\n\n    this.addV1DependenciesByType(DependencyType.TEST, ...testDeps);\n  }\n\n  /**\n   * Adds a set of dependencies with the user-specified dependency type.\n   * @param deps The set of dependency specifications\n   */\n  private addV1DependenciesByType(type: DependencyType, ...modules: string[]) {\n    for (const module of modules) {\n      this.project.deps.addDependency(`${module}@${this.cdkVersion}`, type);\n    }\n  }\n\n  /**\n   * Return a configuration object with information about package naming in various languages\n   */\n  protected abstract packageNames(): AwsCdkPackageNames;\n}\n\n/**\n * Which AWS CDK version a construct library package belongs to.\n */\nenum PACKAGE_AWS_CDK_VERSION {\n  V1 = \"v1\",\n  V2 = \"v2\",\n  EITHER = \"either\", // This package has been published both for v1 and v2.\n  UNKNOWN = \"unknown\",\n}\n\nfunction cdkVersionOfPackage(packageName: string) {\n  if (packageName === \"aws-cdk-lib\") {\n    return PACKAGE_AWS_CDK_VERSION.V2;\n  } else if (packageName.startsWith(\"@aws-cdk/\")) {\n    if (packageName.endsWith(\"-alpha\")) {\n      return PACKAGE_AWS_CDK_VERSION.V2;\n    } else if (AWS_CDK_V1_V2_SCOPED_PACKAGES.includes(packageName)) {\n      return PACKAGE_AWS_CDK_VERSION.EITHER;\n    } else {\n      return PACKAGE_AWS_CDK_VERSION.V1;\n    }\n  } else {\n    return PACKAGE_AWS_CDK_VERSION.UNKNOWN;\n  }\n}\n\n/**\n * A list of all known packages in the \"@aws-cdk/\" scope that are published\n * both for v1 and v2.\n */\nconst AWS_CDK_V1_V2_SCOPED_PACKAGES = [\n  // aws/aws-cdk\n  // @see https://github.com/aws/aws-cdk/tree/main/packages/%40aws-cdk\n  \"@aws-cdk/assert\", // deprecated\n  \"@aws-cdk/cfn-property-mixins\",\n  \"@aws-cdk/cfnspec\", // deprecated\n  \"@aws-cdk/cx-api\",\n  \"@aws-cdk/mixins-preview\",\n  \"@aws-cdk/region-info\",\n\n  // aws/aws-cdk-cli\n  // @see https://github.com/aws/aws-cdk-cli/tree/main/packages/%40aws-cdk\n  \"@aws-cdk/cdk-assets-lib\",\n  \"@aws-cdk/cli-plugin-contract\",\n  \"@aws-cdk/cloud-assembly-api\",\n  \"@aws-cdk/cloud-assembly-schema\",\n  \"@aws-cdk/cloudformation-diff\",\n  \"@aws-cdk/integ-runner\",\n  \"@aws-cdk/toolkit-lib\",\n];\n\nfunction determineFrameworkVersion(options: AwsCdkDepsOptions) {\n  const ver = semver.parse(options.cdkVersion);\n  if (!ver) {\n    throw new Error(\n      `\"cdkVersion\" cannot be parsed as a semver version: ${options.cdkVersion}`,\n    );\n  }\n\n  return {\n    minimum: ver.format(),\n    range: options.cdkVersionPinning\n      ? options.cdkVersion\n      : `^${options.cdkVersion}`,\n    major: ver.major,\n  };\n}\n"]}