UNPKG

@aws/pdk

Version:

All documentation is located at: https://aws.github.io/aws-pdk

83 lines 13.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.GeneratedTypescriptRuntimeBaseProject = void 0; /*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved. SPDX-License-Identifier: Apache-2.0 */ const monorepo_1 = require("../../../../monorepo"); const projen_1 = require("projen"); const javascript_1 = require("projen/lib/javascript"); const typescript_1 = require("projen/lib/typescript"); const type_safe_api_command_environment_1 = require("../components/type-safe-api-command-environment"); const utils_1 = require("../components/utils"); /** * Typescript project containing types generated using OpenAPI Generator CLI */ class GeneratedTypescriptRuntimeBaseProject extends typescript_1.TypeScriptProject { constructor(options) { super({ ...options, sampleCode: false, tsconfig: { ...options.tsconfig, compilerOptions: { lib: ["dom", "es2019"], // Generated code isn't very strict! strict: false, alwaysStrict: false, noImplicitAny: false, noImplicitReturns: false, noImplicitThis: false, noUnusedLocals: false, noUnusedParameters: false, strictNullChecks: false, strictPropertyInitialization: false, skipLibCheck: true, ...options?.tsconfig?.compilerOptions, }, }, eslint: false, // Disable tests unless explicitly enabled jest: options.jest ?? false, npmignoreEnabled: false, }); this.buildGenerateCommandArgs = () => { return (0, utils_1.buildCodegenCommandArgs)(this.buildCodegenOptions()); }; type_safe_api_command_environment_1.TypeSafeApiCommandEnvironment.ensure(this); this.options = options; // Disable strict peer dependencies for pnpm as the default typescript project dependencies have type mismatches // (ts-jest@27 and @types/jest@28) if (this.package.packageManager === javascript_1.NodePackageManager.PNPM) { this.npmrc.addConfig("strict-peer-dependencies", "false"); } // For event and context types this.addDeps("@types/aws-lambda", "@aws-lambda-powertools/tracer", "@aws-lambda-powertools/logger", "@aws-lambda-powertools/metrics"); // Minimal .npmignore to avoid impacting OpenAPI Generator const npmignore = new projen_1.IgnoreFile(this, ".npmignore"); npmignore.addPatterns("/.projen/", `/${this.srcdir}`, "/dist"); this.generateTask = this.addTask("generate"); this.generateTask.exec((0, utils_1.buildTypeSafeApiExecCommand)(utils_1.TypeSafeApiScript.GENERATE, this.buildGenerateCommandArgs())); this.preCompileTask.spawn(this.generateTask); if (!options.commitGeneratedCode) { // Ignore all the generated code this.gitignore.addPatterns(this.srcdir, ".npmignore", "README.md"); } this.gitignore.addPatterns(".openapi-generator", ".tsapi-manifest"); // If we're not in a monorepo, we need to link the generated client such that any local dependency on it can be // resolved if (!options.isWithinMonorepo) { switch (this.package.packageManager) { case javascript_1.NodePackageManager.PNPM: // Nothing to do for pnpm, since the pnpm link command handles both the dependant and dependee break; default: this.tasks .tryFind("install") ?.exec(monorepo_1.NodePackageUtils.command.cmd(this.package.packageManager, "link")); break; } } } } exports.GeneratedTypescriptRuntimeBaseProject = GeneratedTypescriptRuntimeBaseProject; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generated-typescript-runtime-base-project.js","sourceRoot":"","sources":["generated-typescript-runtime-base-project.ts"],"names":[],"mappings":"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","sourcesContent":["/*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved.\nSPDX-License-Identifier: Apache-2.0 */\nimport { NodePackageUtils } from \"@aws/monorepo\";\nimport { IgnoreFile, Task } from \"projen\";\nimport { NodePackageManager } from \"projen/lib/javascript\";\nimport {\n  TypeScriptProject,\n  TypeScriptProjectOptions,\n} from \"projen/lib/typescript\";\nimport {\n  CodeGenerationSourceOptions,\n  GeneratedProjectOptions,\n} from \"../../types\";\nimport { TypeSafeApiCommandEnvironment } from \"../components/type-safe-api-command-environment\";\nimport {\n  buildCodegenCommandArgs,\n  buildTypeSafeApiExecCommand,\n  CodegenOptions,\n  TypeSafeApiScript,\n} from \"../components/utils\";\n\n/**\n * Configuration for the generated typescript client project\n */\nexport interface GeneratedTypescriptRuntimeBaseProjectOptions\n  extends TypeScriptProjectOptions,\n    GeneratedProjectOptions,\n    CodeGenerationSourceOptions {\n  /**\n   * Whether this project is parented by an monorepo or not\n   */\n  readonly isWithinMonorepo?: boolean;\n}\n\n/**\n * Typescript project containing types generated using OpenAPI Generator CLI\n */\nexport abstract class GeneratedTypescriptRuntimeBaseProject extends TypeScriptProject {\n  /**\n   * Options configured for the project\n   */\n  protected readonly options: GeneratedTypescriptRuntimeBaseProjectOptions;\n\n  protected readonly generateTask: Task;\n\n  constructor(options: GeneratedTypescriptRuntimeBaseProjectOptions) {\n    super({\n      ...options,\n      sampleCode: false,\n      tsconfig: {\n        ...options.tsconfig,\n        compilerOptions: {\n          lib: [\"dom\", \"es2019\"],\n          // Generated code isn't very strict!\n          strict: false,\n          alwaysStrict: false,\n          noImplicitAny: false,\n          noImplicitReturns: false,\n          noImplicitThis: false,\n          noUnusedLocals: false,\n          noUnusedParameters: false,\n          strictNullChecks: false,\n          strictPropertyInitialization: false,\n          skipLibCheck: true,\n          ...options?.tsconfig?.compilerOptions,\n        },\n      },\n      eslint: false,\n      // Disable tests unless explicitly enabled\n      jest: options.jest ?? false,\n      npmignoreEnabled: false,\n    });\n    TypeSafeApiCommandEnvironment.ensure(this);\n    this.options = options;\n\n    // Disable strict peer dependencies for pnpm as the default typescript project dependencies have type mismatches\n    // (ts-jest@27 and @types/jest@28)\n    if (this.package.packageManager === NodePackageManager.PNPM) {\n      this.npmrc.addConfig(\"strict-peer-dependencies\", \"false\");\n    }\n\n    // For event and context types\n    this.addDeps(\n      \"@types/aws-lambda\",\n      \"@aws-lambda-powertools/tracer\",\n      \"@aws-lambda-powertools/logger\",\n      \"@aws-lambda-powertools/metrics\"\n    );\n\n    // Minimal .npmignore to avoid impacting OpenAPI Generator\n    const npmignore = new IgnoreFile(this, \".npmignore\");\n    npmignore.addPatterns(\"/.projen/\", `/${this.srcdir}`, \"/dist\");\n\n    this.generateTask = this.addTask(\"generate\");\n    this.generateTask.exec(\n      buildTypeSafeApiExecCommand(\n        TypeSafeApiScript.GENERATE,\n        this.buildGenerateCommandArgs()\n      )\n    );\n\n    this.preCompileTask.spawn(this.generateTask);\n\n    if (!options.commitGeneratedCode) {\n      // Ignore all the generated code\n      this.gitignore.addPatterns(this.srcdir, \".npmignore\", \"README.md\");\n    }\n\n    this.gitignore.addPatterns(\".openapi-generator\", \".tsapi-manifest\");\n\n    // If we're not in a monorepo, we need to link the generated client such that any local dependency on it can be\n    // resolved\n    if (!options.isWithinMonorepo) {\n      switch (this.package.packageManager) {\n        case NodePackageManager.PNPM:\n          // Nothing to do for pnpm, since the pnpm link command handles both the dependant and dependee\n          break;\n        default:\n          this.tasks\n            .tryFind(\"install\")\n            ?.exec(\n              NodePackageUtils.command.cmd(this.package.packageManager, \"link\")\n            );\n          break;\n      }\n    }\n  }\n\n  public buildGenerateCommandArgs = () => {\n    return buildCodegenCommandArgs(this.buildCodegenOptions());\n  };\n\n  protected abstract buildCodegenOptions(): CodegenOptions;\n}\n"]}