projen
Version:
CDK for software projects
96 lines • 13.2 kB
JavaScript
;
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"]}