UNPKG

projen

Version:

CDK for software projects

96 lines 13.2 kB
"use strict"; var _a, _b; Object.defineProperty(exports, "__esModule", { value: true }); exports.ConstructLibraryAws = exports.AwsCdkConstructLibrary = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const semver = require("semver"); const auto_discover_1 = require("./auto-discover"); const awscdk_deps_js_1 = require("./awscdk-deps-js"); const integ_runner_1 = require("./integ-runner"); const cdk_1 = require("../cdk"); const dependencies_1 = require("../dependencies"); /** * AWS CDK construct library project * * A multi-language (jsii) construct library which vends constructs designed to * use within the AWS CDK with a friendly workflow and automatic publishing to * the construct catalog. * * @pjid awscdk-construct */ class AwsCdkConstructLibrary extends cdk_1.ConstructLibrary { constructor(options) { const cdkMajorVersion = semver.parse(options.cdkVersion)?.major; super({ peerDependencyOptions: cdkMajorVersion === 1 ? { pinnedDevDependency: false, } : undefined, workflowNodeVersion: options.minNodeVersion ?? "lts/*", ...options, }); this.cdkDeps = new awscdk_deps_js_1.AwsCdkDepsJs(this, { // since this we are a library, dependencies should be added a peers dependencyType: dependencies_1.DependencyType.PEER, ...options, }); new auto_discover_1.AutoDiscover(this, { srcdir: this.srcdir, testdir: this.testdir, lambdaOptions: options.lambdaOptions, tsconfigPath: this.tsconfigDev.fileName, cdkDeps: this.cdkDeps, lambdaAutoDiscover: options.lambdaAutoDiscover ?? true, edgeLambdaAutoDiscover: options.edgeLambdaAutoDiscover ?? true, singletonLambdaAutoDiscover: options.singletonLambdaAutoDiscover ?? true, lambdaExtensionAutoDiscover: options.lambdaExtensionAutoDiscover ?? true, integrationTestAutoDiscover: options.integrationTestAutoDiscover ?? true, }); if (options.experimentalIntegRunner) { new integ_runner_1.IntegRunner(this); } } /** * The target CDK version for this library. */ get cdkVersion() { return this.cdkDeps.cdkVersion; } /** * @deprecated use `cdkVersion` */ get version() { return this.cdkVersion; } /** * Adds dependencies to AWS CDK modules. * * Since this is a library project, dependencies will be added as peer dependencies. * * @param deps names of cdk modules (e.g. `@aws-cdk/aws-lambda`). * @deprecated Not supported in v2. For v1, use `project.cdkDeps.addV1Dependencies()` */ addCdkDependencies(...deps) { return this.cdkDeps.addV1Dependencies(...deps); } /** * Adds AWS CDK modules as dev dependencies. * * @param deps names of cdk modules (e.g. `@aws-cdk/aws-lambda`). * @deprecated Not supported in v2. For v1, use `project.cdkDeps.addV1DevDependencies()` */ addCdkTestDependencies(...deps) { return this.cdkDeps.addV1DevDependencies(...deps); } } exports.AwsCdkConstructLibrary = AwsCdkConstructLibrary; _a = JSII_RTTI_SYMBOL_1; AwsCdkConstructLibrary[_a] = { fqn: "projen.awscdk.AwsCdkConstructLibrary", version: "0.99.51" }; /** @deprecated use `AwsCdkConstructLibrary` */ class ConstructLibraryAws extends AwsCdkConstructLibrary { } exports.ConstructLibraryAws = ConstructLibraryAws; _b = JSII_RTTI_SYMBOL_1; ConstructLibraryAws[_b] = { fqn: "projen.awscdk.ConstructLibraryAws", version: "0.99.51" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"awscdk-construct.js","sourceRoot":"","sources":["../../src/awscdk/awscdk-construct.ts"],"names":[],"mappings":";;;;;AAAA,iCAAiC;AACjC,mDAA+C;AAE/C,qDAAgD;AAChD,iDAA6C;AAG7C,gCAA0C;AAC1C,kDAAiD;AAoEjD;;;;;;;;GAQG;AACH,MAAa,sBAAuB,SAAQ,sBAAgB;IAG1D,YAAY,OAAsC;QAChD,MAAM,eAAe,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,KAAK,CAAC;QAEhE,KAAK,CAAC;YACJ,qBAAqB,EACnB,eAAe,KAAK,CAAC;gBACnB,CAAC,CAAC;oBACE,mBAAmB,EAAE,KAAK;iBAC3B;gBACH,CAAC,CAAC,SAAS;YACf,mBAAmB,EAAE,OAAO,CAAC,cAAc,IAAI,OAAO;YACtD,GAAG,OAAO;SACX,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,IAAI,6BAAY,CAAC,IAAI,EAAE;YACpC,oEAAoE;YACpE,cAAc,EAAE,6BAAc,CAAC,IAAI;YACnC,GAAG,OAAO;SACX,CAAC,CAAC;QAEH,IAAI,4BAAY,CAAC,IAAI,EAAE;YACrB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ;YACvC,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,kBAAkB,EAAE,OAAO,CAAC,kBAAkB,IAAI,IAAI;YACtD,sBAAsB,EAAE,OAAO,CAAC,sBAAsB,IAAI,IAAI;YAC9D,2BAA2B,EAAE,OAAO,CAAC,2BAA2B,IAAI,IAAI;YACxE,2BAA2B,EAAE,OAAO,CAAC,2BAA2B,IAAI,IAAI;YACxE,2BAA2B,EAAE,OAAO,CAAC,2BAA2B,IAAI,IAAI;SACzE,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,uBAAuB,EAAE,CAAC;YACpC,IAAI,0BAAW,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACI,kBAAkB,CAAC,GAAG,IAAc;QACzC,OAAO,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,CAAC;IACjD,CAAC;IAED;;;;;OAKG;IACI,sBAAsB,CAAC,GAAG,IAAc;QAC7C,OAAO,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,GAAG,IAAI,CAAC,CAAC;IACpD,CAAC;;AA3EH,wDA4EC;;;AAKD,+CAA+C;AAC/C,MAAa,mBAAoB,SAAQ,sBAAsB;;AAA/D,kDAAkE","sourcesContent":["import * as semver from \"semver\";\nimport { AutoDiscover } from \"./auto-discover\";\nimport type { AwsCdkDeps, AwsCdkDepsCommonOptions } from \"./awscdk-deps\";\nimport { AwsCdkDepsJs } from \"./awscdk-deps-js\";\nimport { IntegRunner } from \"./integ-runner\";\nimport type { LambdaFunctionCommonOptions } from \"./lambda-function\";\nimport type { ConstructLibraryOptions } from \"../cdk\";\nimport { ConstructLibrary } from \"../cdk\";\nimport { DependencyType } from \"../dependencies\";\n\n/**\n * Options for `AwsCdkConstructLibrary`.\n */\nexport interface AwsCdkConstructLibraryOptions\n  extends ConstructLibraryOptions, AwsCdkDepsCommonOptions {\n  /**\n   * Automatically adds an `aws_lambda.Function` for each `.lambda.ts` handler\n   * in your source tree. If this is disabled, you either need to explicitly\n   * call `aws_lambda.Function.autoDiscover()` or define a `new\n   * aws_lambda.Function()` for each handler.\n   *\n   * @default true\n   */\n  readonly lambdaAutoDiscover?: boolean;\n\n  /**\n   * Automatically adds an `cloudfront.experimental.EdgeFunction` for each\n   * `.edge-lambda.ts` handler in your source tree. If this is disabled, you can\n   * manually add an `awscdk.AutoDiscover` component to your project.\n   *\n   * @default true\n   */\n  readonly edgeLambdaAutoDiscover?: boolean;\n\n  /**\n   * Automatically adds an `awscdk.SingletonFunction` for each\n   * `.singleton-lambda.ts` handler in your source tree. If this is disabled, you can\n   * manually add an `awscdk.AutoDiscover` component to your project.\n   *\n   * @default true\n   */\n  readonly singletonLambdaAutoDiscover?: boolean;\n\n  /**\n   * Automatically adds an `awscdk.LambdaExtension` for each `.lambda-extension.ts`\n   * entrypoint in your source tree. If this is disabled, you can manually add an\n   * `awscdk.AutoDiscover` component to your project\n   *\n   * @default true\n   */\n  readonly lambdaExtensionAutoDiscover?: boolean;\n\n  /**\n   * Automatically discovers and creates integration tests for each `.integ.ts`\n   * file under your test directory.\n   *\n   * @default true\n   */\n  readonly integrationTestAutoDiscover?: boolean;\n\n  /**\n   * Enable experimental support for the AWS CDK integ-runner.\n   *\n   * @default false\n   * @experimental\n   */\n  readonly experimentalIntegRunner?: boolean;\n\n  /**\n   * Common options for all AWS Lambda functions.\n   *\n   * @default - default options\n   */\n  readonly lambdaOptions?: LambdaFunctionCommonOptions;\n}\n\n/**\n * AWS CDK construct library project\n *\n * A multi-language (jsii) construct library which vends constructs designed to\n * use within the AWS CDK with a friendly workflow and automatic publishing to\n * the construct catalog.\n *\n * @pjid awscdk-construct\n */\nexport class AwsCdkConstructLibrary extends ConstructLibrary {\n  public readonly cdkDeps: AwsCdkDeps;\n\n  constructor(options: AwsCdkConstructLibraryOptions) {\n    const cdkMajorVersion = semver.parse(options.cdkVersion)?.major;\n\n    super({\n      peerDependencyOptions:\n        cdkMajorVersion === 1\n          ? {\n              pinnedDevDependency: false,\n            }\n          : undefined,\n      workflowNodeVersion: options.minNodeVersion ?? \"lts/*\",\n      ...options,\n    });\n\n    this.cdkDeps = new AwsCdkDepsJs(this, {\n      // since this we are a library, dependencies should be added a peers\n      dependencyType: DependencyType.PEER,\n      ...options,\n    });\n\n    new AutoDiscover(this, {\n      srcdir: this.srcdir,\n      testdir: this.testdir,\n      lambdaOptions: options.lambdaOptions,\n      tsconfigPath: this.tsconfigDev.fileName,\n      cdkDeps: this.cdkDeps,\n      lambdaAutoDiscover: options.lambdaAutoDiscover ?? true,\n      edgeLambdaAutoDiscover: options.edgeLambdaAutoDiscover ?? true,\n      singletonLambdaAutoDiscover: options.singletonLambdaAutoDiscover ?? true,\n      lambdaExtensionAutoDiscover: options.lambdaExtensionAutoDiscover ?? true,\n      integrationTestAutoDiscover: options.integrationTestAutoDiscover ?? true,\n    });\n\n    if (options.experimentalIntegRunner) {\n      new IntegRunner(this);\n    }\n  }\n\n  /**\n   * The target CDK version for this library.\n   */\n  public get cdkVersion() {\n    return this.cdkDeps.cdkVersion;\n  }\n\n  /**\n   * @deprecated use `cdkVersion`\n   */\n  public get version() {\n    return this.cdkVersion;\n  }\n\n  /**\n   * Adds dependencies to AWS CDK modules.\n   *\n   * Since this is a library project, dependencies will be added as peer dependencies.\n   *\n   * @param deps names of cdk modules (e.g. `@aws-cdk/aws-lambda`).\n   * @deprecated Not supported in v2. For v1, use `project.cdkDeps.addV1Dependencies()`\n   */\n  public addCdkDependencies(...deps: string[]) {\n    return this.cdkDeps.addV1Dependencies(...deps);\n  }\n\n  /**\n   * Adds AWS CDK modules as dev dependencies.\n   *\n   * @param deps names of cdk modules (e.g. `@aws-cdk/aws-lambda`).\n   * @deprecated Not supported in v2. For v1, use `project.cdkDeps.addV1DevDependencies()`\n   */\n  public addCdkTestDependencies(...deps: string[]) {\n    return this.cdkDeps.addV1DevDependencies(...deps);\n  }\n}\n\n/** @deprecated use `AwsCdkConstructLibraryOptions` */\nexport interface ConstructLibraryAwsOptions extends AwsCdkConstructLibraryOptions {}\n\n/** @deprecated use `AwsCdkConstructLibrary` */\nexport class ConstructLibraryAws extends AwsCdkConstructLibrary {}\n"]}