@nikovirtala/projen-constructs 0.1.5 → 0.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -204,5 +204,5 @@ class Vitest extends component_1.Component {
204
204
  }
205
205
  exports.Vitest = Vitest;
206
206
  _a = JSII_RTTI_SYMBOL_1;
207
- Vitest[_a] = { fqn: "@nikovirtala/projen-constructs.Vitest", version: "0.1.5" };
207
+ Vitest[_a] = { fqn: "@nikovirtala/projen-constructs.Vitest", version: "0.1.6" };
208
208
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vitest.js","sourceRoot":"","sources":["../../src/components/vitest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from \"node:path\";\nimport { Component } from \"projen/lib/component\";\nimport { DependencyType } from \"projen/lib/dependencies\";\nimport { Jest, type NodeProject } from \"projen/lib/javascript\";\nimport { TextFile } from \"projen/lib/textfile\";\n\nexport enum Environment {\n    EDGE_RUNTIME = \"edge-runtime\",\n    HAPPY_DOM = \"happy-dom\",\n    JSDOM = \"jsdom\",\n    NODE = \"node\",\n}\n\nexport enum Pool {\n    FORKS = \"forks\",\n    THREADS = \"threads\",\n    VMFORKS = \"vmforks\",\n    VMTHREADS = \"vmthreads\",\n}\n\nexport enum CoverageProvider {\n    ISTANBUL = \"istanbul\",\n    V8 = \"v8\",\n}\n\nexport enum CoverageReporter {\n    CLOVER = \"clover\",\n    HTML = \"html\",\n    JSON = \"json\",\n    LCOV = \"lcov\",\n    TEXT = \"text\",\n}\n\nexport interface VitestConfigOptions {\n    readonly include?: Array<string>;\n    readonly exclude?: Array<string>;\n    readonly environment?: Environment;\n    readonly isolate?: boolean;\n    readonly pool?: Pool;\n    readonly globals?: boolean;\n    readonly coverageEnabled?: boolean;\n    readonly coverageProvider?: CoverageProvider;\n    readonly coverageReporters?: Array<CoverageReporter>;\n    readonly coverageDirectory?: string;\n    readonly typecheckEnabled?: boolean;\n    readonly typecheckChecker?: string;\n    readonly typecheckTsconfig?: string;\n    readonly passWithNoTests?: boolean;\n    readonly bail?: number;\n    readonly updateSnapshots?: boolean;\n    readonly printConsoleTrace?: boolean;\n    readonly slowTestThreshold?: number;\n}\n\nexport interface VitestOptions {\n    readonly configFilePath?: string;\n    readonly config?: VitestConfigOptions;\n    readonly vitestVersion?: string;\n}\n\nexport class Vitest extends Component {\n    public static of(project: NodeProject): Vitest | undefined {\n        const isVitest = (c: Component): c is Vitest => c instanceof Vitest;\n        return project.components.find(isVitest);\n    }\n\n    private readonly configFilePath: string;\n    private readonly include: Set<string>;\n    private readonly exclude: Set<string>;\n    private readonly isolate: boolean;\n    private readonly pool: Pool;\n    private readonly coverageEnabled: boolean;\n    private readonly typecheckEnabled: boolean;\n    private readonly typecheckChecker: string;\n    private readonly typecheckTsconfig: string;\n    private readonly passWithNoTests: boolean;\n    private readonly bail: number;\n    private readonly updateSnapshots: boolean;\n    private environment: string;\n    private globals: boolean;\n    private coverageProvider: CoverageProvider;\n    private coverageReporters: Array<CoverageReporter>;\n    private coverageDirectory: string;\n    private version: string;\n    private readonly printConsoleTrace: boolean;\n    private readonly slowTestThreshold: number;\n\n    constructor(project: NodeProject, options: VitestOptions = {}) {\n        super(project);\n\n        this.configFilePath = options.configFilePath ?? \"vitest.config.ts\";\n        this.include = new Set(options.config?.include ?? [\"**/*.{test,spec}.?(c|m)[jt]s?(x)\"]);\n        this.exclude = new Set(\n            options.config?.exclude ?? [\n                \"**/node_modules/**\",\n                \"**/dist/**\",\n                \"**/cypress/**\",\n                \"**/.{idea,git,cache,output,temp}/**\",\n                \"**/{karma,rollup,webpack,vite,vitest,jest,ava,babel,nyc,cypress,tsup,build,eslint,prettier}.config.*\",\n            ],\n        );\n        this.isolate = options.config?.isolate ?? true;\n        this.pool = options.config?.pool ?? Pool.FORKS;\n        this.coverageEnabled = options.config?.coverageEnabled ?? true;\n        this.typecheckEnabled = options.config?.typecheckEnabled ?? this.isTypescriptProject();\n        this.typecheckChecker = options.config?.typecheckChecker ?? \"tsc --noEmit\";\n        this.typecheckTsconfig = options.config?.typecheckTsconfig ?? \"tsconfig.dev.json\";\n        this.passWithNoTests = options.config?.passWithNoTests ?? true;\n        this.bail = options.config?.bail ?? 0;\n        this.environment = options.config?.environment ?? Environment.NODE;\n        this.globals = options.config?.globals ?? false;\n        this.coverageProvider = options.config?.coverageProvider ?? CoverageProvider.V8;\n        this.coverageReporters = options.config?.coverageReporters ?? [CoverageReporter.TEXT, CoverageReporter.LCOV];\n        this.coverageDirectory = options.config?.coverageDirectory ?? \"coverage\";\n        this.version = options.vitestVersion ?? \"^4\";\n        this.updateSnapshots = options.config?.updateSnapshots ?? true;\n        this.printConsoleTrace = options.config?.printConsoleTrace ?? true;\n        this.slowTestThreshold = options.config?.slowTestThreshold ?? 300;\n\n        project.addDevDeps(`vitest@${this.version}`);\n        this.configureCoverageProvider(this.coverageProvider);\n\n        if (this.globals && this.isTypescriptProject() && this.project.tryFindObjectFile(this.typecheckTsconfig)) {\n            this.configureGlobals();\n        }\n\n        const coverageDirectoryPath = path.posix.join(\"/\", this.coverageDirectory, \"/\");\n        project.npmignore?.exclude(coverageDirectoryPath);\n        project.gitignore.exclude(coverageDirectoryPath);\n\n        this.addTestCommand();\n        this.synthesizeConfig();\n    }\n\n    public override preSynthesize() {\n        super.preSynthesize();\n\n        for (const component of this.project.components) {\n            if (component instanceof Jest) {\n                throw new Error(\"vitest cannot be used together with jest\");\n            }\n        }\n    }\n\n    public addInclude(pattern: string): void {\n        this.include.add(pattern);\n        this.synthesizeConfig();\n    }\n\n    public addExclude(pattern: string): void {\n        this.exclude.add(pattern);\n        this.synthesizeConfig();\n    }\n\n    public configureEnvironment(environment: Environment): void {\n        this.environment = environment;\n        this.synthesizeConfig();\n    }\n\n    public configureCoverageProvider(provider: CoverageProvider): void {\n        const providerPackages = {\n            [CoverageProvider.V8]: `@vitest/coverage-v8@${this.version}`,\n            [CoverageProvider.ISTANBUL]: `@vitest/coverage-istanbul@${this.version}`,\n        };\n\n        for (const providerPackage of Object.values(providerPackages)) {\n            try {\n                this.project.deps.removeDependency(providerPackage);\n            } catch {\n                // ignore\n            }\n        }\n\n        this.project.deps.addDependency(providerPackages[provider], DependencyType.DEVENV);\n        this.coverageProvider = provider;\n        this.synthesizeConfig();\n    }\n\n    public configureCoverageReporters(reporters: Array<CoverageReporter>): void {\n        this.coverageReporters = reporters;\n        this.synthesizeConfig();\n    }\n\n    public configureGlobals(): void {\n        this.updateTsConfig();\n        this.synthesizeConfig();\n    }\n\n    private updateTsConfig(): void {\n        const tsconfig = this.project.tryFindObjectFile(this.typecheckTsconfig);\n\n        if (!tsconfig) {\n            throw new Error(\"unable to find tsconfig\");\n        }\n\n        tsconfig.addToArray(\"compilerOptions.types\", \"vitest/globals\");\n    }\n\n    private isTypescriptProject(): boolean {\n        return this.project.deps.tryGetDependency(\"typescript\") !== undefined;\n    }\n\n    private addTestCommand(): void {\n        this.project.testTask.exec(\"vitest run\", {\n            receiveArgs: true,\n        });\n\n        const testWatch = this.project.tasks.tryFind(\"test:watch\");\n        if (!testWatch) {\n            this.project.addTask(\"test:watch\", {\n                exec: \"vitest watch\",\n                receiveArgs: true,\n            });\n        }\n\n        const testUpdateSnapshots = this.project.tasks.tryFind(\"test:update\");\n        if (!testUpdateSnapshots) {\n            this.project.addTask(\"test:update\", {\n                exec: \"vitest --update\",\n                receiveArgs: true,\n            });\n        }\n    }\n\n    private synthesizeConfig(): void {\n        this.project.tryRemoveFile(this.configFilePath);\n\n        new TextFile(this, this.configFilePath, {\n            lines: this.renderConfig(),\n        });\n    }\n\n    private renderConfig(): Array<string> {\n        const project = this.project as NodeProject;\n        const packageName = project.package.packageName;\n        const defineConfigImport =\n            packageName === \"@nikovirtala/projen-constructs\"\n                ? 'import { defineConfig } from \"./lib/vitest-define-config\";'\n                : 'import { defineConfig } from \"@nikovirtala/projen-constructs/lib/vitest-define-config\";';\n\n        return [\n            defineConfigImport,\n            \"\",\n            \"export default defineConfig({\",\n            \"  test: {\",\n            ...this.renderTestOptions(),\n            \"  },\",\n            \"});\",\n        ];\n    }\n\n    private renderTestOptions(): Array<string> {\n        const lines: Array<string> = [];\n\n        lines.push(`    bail: ${this.bail},`);\n        lines.push(\"    coverage: {\");\n        lines.push(`      enabled: ${this.coverageEnabled},`);\n        lines.push(`      provider: \"${this.coverageProvider}\",`);\n        lines.push(`      reporter: ${JSON.stringify(this.coverageReporters)},`);\n        lines.push(`      reportsDirectory: \"${this.coverageDirectory}\",`);\n        lines.push(\"    },\");\n        lines.push(`    environment: \"${this.environment}\",`);\n        lines.push(`    exclude: ${JSON.stringify(Array.from(this.exclude))},`);\n        lines.push(`    globals: ${this.globals},`);\n        lines.push(`    include: ${JSON.stringify(Array.from(this.include))},`);\n        lines.push(`    isolate: ${this.isolate},`);\n        lines.push(`    passWithNoTests: ${this.passWithNoTests},`);\n        lines.push(`    printConsoleTrace: ${this.printConsoleTrace},`);\n        lines.push(`    pool: \"${this.pool}\",`);\n        lines.push(`    slowTestThreshold: ${this.slowTestThreshold},`);\n        lines.push(\"    typecheck: {\");\n        lines.push(`      enabled: ${this.typecheckEnabled},`);\n        lines.push(`      checker: \"${this.typecheckChecker}\",`);\n        lines.push(`      tsconfig: \"${this.typecheckTsconfig}\",`);\n        lines.push(\"    },\");\n        lines.push(`    update: ${this.updateSnapshots},`);\n\n        return lines;\n    }\n}\n"]}
package/lib/config.d.ts CHANGED
@@ -1,5 +1,4 @@
1
- import { awscdk, cdk, javascript, typescript } from "projen";
2
- import { type VitestOptions } from "./components/vitest";
1
+ import { awscdk, type Component, cdk, javascript, typescript } from "projen";
3
2
  export declare const defaults: {
4
3
  readonly jsiiVersion: string;
5
4
  readonly cdkVersion: string;
@@ -9,7 +8,12 @@ export declare const defaults: {
9
8
  readonly authorAddress: "niko.virtala@hey.com";
10
9
  readonly constructsVersion: "10.4.3";
11
10
  };
12
- export declare function applyDefaultConfig(project: awscdk.AwsCdkTypeScriptApp | awscdk.AwsCdkConstructLibrary | typescript.TypeScriptProject | cdk.JsiiProject, vitest?: boolean, vitestOptions?: VitestOptions, mise?: boolean): void;
11
+ interface ComponentConfig {
12
+ component: new (project: never, options?: never) => Component;
13
+ enabled?: boolean;
14
+ options?: unknown;
15
+ }
16
+ export declare function applyDefaults(project: awscdk.AwsCdkTypeScriptApp | awscdk.AwsCdkConstructLibrary | typescript.TypeScriptProject | cdk.JsiiProject, components: ComponentConfig[]): void;
13
17
  export declare const projectDefaultOptions: {
14
18
  defaultReleaseBranch: string;
15
19
  minNodeVersion: string;
@@ -73,7 +77,16 @@ export declare const projectDefaultOptions: {
73
77
  };
74
78
  };
75
79
  };
76
- export declare const typescriptProjectDefaultOptions: Partial<typescript.TypeScriptProjectOptions>;
77
- export declare const jsiiProjectDefaultOptions: Partial<cdk.JsiiProjectOptions>;
78
- export declare const cdkAppDefaultOptions: Partial<awscdk.AwsCdkTypeScriptAppOptions>;
79
- export declare const cdkConstructDefaultOptions: Partial<awscdk.AwsCdkConstructLibraryOptions>;
80
+ export declare const defaultOptions: {
81
+ typescript: {
82
+ TypeScriptProject: Partial<typescript.TypeScriptProjectOptions>;
83
+ };
84
+ cdk: {
85
+ JsiiProject: Partial<cdk.JsiiProjectOptions>;
86
+ };
87
+ awscdk: {
88
+ AwsCdkTypeScriptApp: Partial<awscdk.AwsCdkTypeScriptAppOptions>;
89
+ AwsCdkConstructLibrary: Partial<awscdk.AwsCdkConstructLibraryOptions>;
90
+ };
91
+ };
92
+ export {};
package/lib/config.js CHANGED
@@ -1,10 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.cdkConstructDefaultOptions = exports.cdkAppDefaultOptions = exports.jsiiProjectDefaultOptions = exports.typescriptProjectDefaultOptions = exports.projectDefaultOptions = exports.defaults = void 0;
4
- exports.applyDefaultConfig = applyDefaultConfig;
3
+ exports.defaultOptions = exports.projectDefaultOptions = exports.defaults = void 0;
4
+ exports.applyDefaults = applyDefaults;
5
5
  const projen_1 = require("projen");
6
- const mise_1 = require("./components/mise");
7
- const vitest_1 = require("./components/vitest");
8
6
  const utils_1 = require("./utils");
9
7
  const versions = require("./versions.json");
10
8
  exports.defaults = {
@@ -16,8 +14,7 @@ exports.defaults = {
16
14
  return `~${this.typescriptVersion}`;
17
15
  },
18
16
  };
19
- function applyDefaultConfig(project, vitest = true, vitestOptions, mise = true) {
20
- const nodeVersion = project.minNodeVersion ?? exports.defaults.minNodeVersion;
17
+ function configureProject(project) {
21
18
  if ((project instanceof projen_1.awscdk.AwsCdkTypeScriptApp || project instanceof projen_1.typescript.TypeScriptProject) &&
22
19
  !(project instanceof projen_1.cdk.JsiiProject) &&
23
20
  !(project instanceof projen_1.awscdk.AwsCdkConstructLibrary)) {
@@ -37,9 +34,6 @@ function applyDefaultConfig(project, vitest = true, vitestOptions, mise = true)
37
34
  "editor.formatOnSave": true,
38
35
  "editor.tabSize": 4,
39
36
  });
40
- if (mise ?? true) {
41
- new mise_1.Mise(project, { nodeVersion });
42
- }
43
37
  if (project instanceof projen_1.cdk.JsiiProject || project instanceof projen_1.awscdk.AwsCdkConstructLibrary) {
44
38
  // use node.js 24.x to get new enough npm to satisfy: trusted publishing requires npm CLI version 11.5.1 or later.
45
39
  project.github
@@ -49,10 +43,18 @@ function applyDefaultConfig(project, vitest = true, vitestOptions, mise = true)
49
43
  }
50
44
  // remove once configured correctly to biome, mise and vitest components
51
45
  project.npmignore?.addPatterns("biome.jsonc", "mise.toml", "vitest.config.ts");
52
- if (vitest ?? true) {
53
- new vitest_1.Vitest(project, vitestOptions);
46
+ }
47
+ function injectComponents(project, components) {
48
+ for (const { component, enabled, options } of components) {
49
+ if (enabled ?? true) {
50
+ new component(project, options);
51
+ }
54
52
  }
55
53
  }
54
+ function applyDefaults(project, components) {
55
+ configureProject(project);
56
+ injectComponents(project, components);
57
+ }
56
58
  exports.projectDefaultOptions = {
57
59
  defaultReleaseBranch: "main",
58
60
  minNodeVersion: exports.defaults.minNodeVersion,
@@ -136,8 +138,18 @@ const cdkDefaultVersionOptions = {
136
138
  cdkVersion: exports.defaults.cdkVersion,
137
139
  constructsVersion: exports.defaults.constructsVersion,
138
140
  };
139
- exports.typescriptProjectDefaultOptions = (0, utils_1.mergeAll)(exports.projectDefaultOptions, esModuleTsconfigOptions);
140
- exports.jsiiProjectDefaultOptions = (0, utils_1.mergeAll)(exports.projectDefaultOptions, publishableProjectDefaultOptions, { jsiiVersion: exports.defaults.jsiiVersion });
141
- exports.cdkAppDefaultOptions = (0, utils_1.mergeAll)(exports.projectDefaultOptions, esModuleTsconfigOptions, cdkDefaultVersionOptions);
142
- exports.cdkConstructDefaultOptions = (0, utils_1.mergeAll)(exports.projectDefaultOptions, publishableProjectDefaultOptions, cdkDefaultVersionOptions);
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk, cdk, JsonPatch, javascript, typescript } from \"projen\";\nimport type { TypeScriptProjectOptions } from \"projen/lib/typescript\";\nimport { Mise } from \"./components/mise\";\nimport { Vitest, type VitestOptions } from \"./components/vitest\";\nimport { mergeAll } from \"./utils\";\nimport * as versions from \"./versions.json\";\n\nexport const defaults = {\n    author: \"Niko Virtala\",\n    authorAddress: \"niko.virtala@hey.com\",\n    constructsVersion: \"10.4.3\",\n    ...versions,\n    get jsiiVersion() {\n        return `~${this.typescriptVersion}`;\n    },\n} as const;\n\nexport function applyDefaultConfig(\n    project:\n        | awscdk.AwsCdkTypeScriptApp\n        | awscdk.AwsCdkConstructLibrary\n        | typescript.TypeScriptProject\n        | cdk.JsiiProject,\n    vitest: boolean = true,\n    vitestOptions?: VitestOptions,\n    mise: boolean = true,\n) {\n    const nodeVersion = project.minNodeVersion ?? defaults.minNodeVersion;\n\n    if (\n        (project instanceof awscdk.AwsCdkTypeScriptApp || project instanceof typescript.TypeScriptProject) &&\n        !(project instanceof cdk.JsiiProject) &&\n        !(project instanceof awscdk.AwsCdkConstructLibrary)\n    ) {\n        project.package.addField(\"type\", \"module\");\n    }\n\n    project.deps.removeDependency(\"ts-node\");\n    project.addDevDeps(\"tsx\");\n    project.defaultTask?.reset();\n    project.defaultTask?.exec(`tsx --tsconfig ${project.tsconfigDev.file.path} .projenrc.ts`);\n\n    project.npmrc.addConfig(\"node-linker\", \"hoisted\");\n\n    project.vscode?.extensions.addRecommendations(\"biomejs.biome\");\n    project.vscode?.settings.addSettings({\n        \"editor.codeActionsOnSave\": {\n            \"source.organizeImports.biome\": \"always\",\n        },\n        \"editor.defaultFormatter\": \"biomejs.biome\",\n        \"editor.formatOnSave\": true,\n        \"editor.tabSize\": 4,\n    });\n\n    if (mise ?? true) {\n        new Mise(project, { nodeVersion });\n    }\n\n    if (project instanceof cdk.JsiiProject || project instanceof awscdk.AwsCdkConstructLibrary) {\n        // use node.js 24.x to get new enough npm to satisfy: trusted publishing requires npm CLI version 11.5.1 or later.\n        project.github\n            ?.tryFindWorkflow(\"release\")\n            ?.file?.patch(JsonPatch.replace(\"/jobs/release_npm/steps/0/with/node-version\", \"24.x\"));\n\n        project.package.addField(\"publishConfig\", { access: \"public\" });\n    }\n\n    // remove once configured correctly to biome, mise and vitest components\n    project.npmignore?.addPatterns(\"biome.jsonc\", \"mise.toml\", \"vitest.config.ts\");\n\n    if (vitest ?? true) {\n        new Vitest(project, vitestOptions);\n    }\n}\n\nexport const projectDefaultOptions = {\n    defaultReleaseBranch: \"main\",\n    minNodeVersion: defaults.minNodeVersion,\n    autoApproveOptions: {\n        secret: \"GITHUB_TOKEN\",\n        allowedUsernames: [\"nikovirtala\"],\n    },\n    dependabot: false,\n    depsUpgradeOptions: {\n        workflowOptions: {\n            labels: [\"auto-approve\", \"auto-merge\"],\n        },\n    },\n    github: true,\n    mergify: true,\n    autoMerge: true,\n    jest: false,\n    eslint: false,\n    prettier: false,\n    biome: true,\n    biomeOptions: {\n        biomeConfig: {\n            formatter: {\n                indentStyle: javascript.biome_config.IndentStyle.SPACE,\n                indentWidth: 4,\n                lineWidth: 120,\n                useEditorconfig: false,\n            },\n        },\n        formatter: true,\n        linter: true,\n    },\n    packageManager: javascript.NodePackageManager.PNPM,\n    pnpmVersion: \"10\",\n    projenrcTs: true,\n    typescriptVersion: defaults.typescriptVersion,\n    tsconfig: {\n        compilerOptions: {\n            allowSyntheticDefaultImports: true,\n            alwaysStrict: true,\n            declaration: true,\n            esModuleInterop: true,\n            experimentalDecorators: true,\n            inlineSourceMap: true,\n            inlineSources: true,\n            isolatedModules: true,\n            noEmit: true,\n            noEmitOnError: false,\n            noFallthroughCasesInSwitch: true,\n            noImplicitAny: true,\n            noImplicitOverride: true,\n            noImplicitReturns: true,\n            noImplicitThis: true,\n            noUnusedLocals: true,\n            noUnusedParameters: true,\n            resolveJsonModule: true,\n            strict: true,\n            strictNullChecks: true,\n            strictPropertyInitialization: true,\n            stripInternal: true,\n        },\n    },\n} satisfies Partial<TypeScriptProjectOptions>;\n\nconst esModuleTsconfigOptions = {\n    tsconfig: {\n        compilerOptions: {\n            allowImportingTsExtensions: true,\n            lib: [\"esnext\"],\n            module: \"nodenext\",\n            moduleResolution: javascript.TypeScriptModuleResolution.NODE_NEXT,\n            target: \"esnext\",\n        },\n    },\n} satisfies Partial<TypeScriptProjectOptions>;\n\nconst publishableProjectDefaultOptions = {\n    author: defaults.author,\n    authorAddress: defaults.authorAddress,\n    npmTrustedPublishing: true,\n} satisfies Partial<cdk.JsiiProjectOptions>;\n\nconst cdkDefaultVersionOptions = {\n    cdkVersion: defaults.cdkVersion,\n    constructsVersion: defaults.constructsVersion,\n} satisfies Partial<awscdk.AwsCdkConstructLibraryOptions>;\n\nexport const typescriptProjectDefaultOptions = mergeAll<typescript.TypeScriptProjectOptions>(\n    projectDefaultOptions,\n    esModuleTsconfigOptions,\n);\n\nexport const jsiiProjectDefaultOptions = mergeAll<cdk.JsiiProjectOptions>(\n    projectDefaultOptions,\n    publishableProjectDefaultOptions,\n    { jsiiVersion: defaults.jsiiVersion },\n);\n\nexport const cdkAppDefaultOptions = mergeAll<awscdk.AwsCdkTypeScriptAppOptions>(\n    projectDefaultOptions,\n    esModuleTsconfigOptions,\n    cdkDefaultVersionOptions,\n);\n\nexport const cdkConstructDefaultOptions = mergeAll<awscdk.AwsCdkConstructLibraryOptions>(\n    projectDefaultOptions,\n    publishableProjectDefaultOptions,\n    cdkDefaultVersionOptions,\n);\n"]}
141
+ exports.defaultOptions = {
142
+ typescript: {
143
+ TypeScriptProject: (0, utils_1.mergeAll)(exports.projectDefaultOptions, esModuleTsconfigOptions),
144
+ },
145
+ cdk: {
146
+ JsiiProject: (0, utils_1.mergeAll)(exports.projectDefaultOptions, publishableProjectDefaultOptions, {
147
+ jsiiVersion: exports.defaults.jsiiVersion,
148
+ }),
149
+ },
150
+ awscdk: {
151
+ AwsCdkTypeScriptApp: (0, utils_1.mergeAll)(exports.projectDefaultOptions, esModuleTsconfigOptions, cdkDefaultVersionOptions),
152
+ AwsCdkConstructLibrary: (0, utils_1.mergeAll)(exports.projectDefaultOptions, publishableProjectDefaultOptions, cdkDefaultVersionOptions),
153
+ },
154
+ };
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk, type Component, cdk, JsonPatch, javascript, typescript } from \"projen\";\nimport type { TypeScriptProjectOptions } from \"projen/lib/typescript\";\nimport { mergeAll } from \"./utils\";\nimport * as versions from \"./versions.json\";\n\nexport const defaults = {\n    author: \"Niko Virtala\",\n    authorAddress: \"niko.virtala@hey.com\",\n    constructsVersion: \"10.4.3\",\n    ...versions,\n    get jsiiVersion() {\n        return `~${this.typescriptVersion}`;\n    },\n} as const;\n\ninterface ComponentConfig {\n    component: new (project: never, options?: never) => Component;\n    enabled?: boolean;\n    options?: unknown;\n}\n\nfunction configureProject(\n    project:\n        | awscdk.AwsCdkTypeScriptApp\n        | awscdk.AwsCdkConstructLibrary\n        | typescript.TypeScriptProject\n        | cdk.JsiiProject,\n) {\n    if (\n        (project instanceof awscdk.AwsCdkTypeScriptApp || project instanceof typescript.TypeScriptProject) &&\n        !(project instanceof cdk.JsiiProject) &&\n        !(project instanceof awscdk.AwsCdkConstructLibrary)\n    ) {\n        project.package.addField(\"type\", \"module\");\n    }\n\n    project.deps.removeDependency(\"ts-node\");\n    project.addDevDeps(\"tsx\");\n    project.defaultTask?.reset();\n    project.defaultTask?.exec(`tsx --tsconfig ${project.tsconfigDev.file.path} .projenrc.ts`);\n\n    project.npmrc.addConfig(\"node-linker\", \"hoisted\");\n\n    project.vscode?.extensions.addRecommendations(\"biomejs.biome\");\n    project.vscode?.settings.addSettings({\n        \"editor.codeActionsOnSave\": {\n            \"source.organizeImports.biome\": \"always\",\n        },\n        \"editor.defaultFormatter\": \"biomejs.biome\",\n        \"editor.formatOnSave\": true,\n        \"editor.tabSize\": 4,\n    });\n\n    if (project instanceof cdk.JsiiProject || project instanceof awscdk.AwsCdkConstructLibrary) {\n        // use node.js 24.x to get new enough npm to satisfy: trusted publishing requires npm CLI version 11.5.1 or later.\n        project.github\n            ?.tryFindWorkflow(\"release\")\n            ?.file?.patch(JsonPatch.replace(\"/jobs/release_npm/steps/0/with/node-version\", \"24.x\"));\n\n        project.package.addField(\"publishConfig\", { access: \"public\" });\n    }\n\n    // remove once configured correctly to biome, mise and vitest components\n    project.npmignore?.addPatterns(\"biome.jsonc\", \"mise.toml\", \"vitest.config.ts\");\n}\n\nfunction injectComponents(\n    project:\n        | awscdk.AwsCdkTypeScriptApp\n        | awscdk.AwsCdkConstructLibrary\n        | typescript.TypeScriptProject\n        | cdk.JsiiProject,\n    components: ComponentConfig[],\n) {\n    for (const { component, enabled, options } of components) {\n        if (enabled ?? true) {\n            new component(project as never, options as never);\n        }\n    }\n}\n\nexport function applyDefaults(\n    project:\n        | awscdk.AwsCdkTypeScriptApp\n        | awscdk.AwsCdkConstructLibrary\n        | typescript.TypeScriptProject\n        | cdk.JsiiProject,\n    components: ComponentConfig[],\n) {\n    configureProject(project);\n    injectComponents(project, components);\n}\n\nexport const projectDefaultOptions = {\n    defaultReleaseBranch: \"main\",\n    minNodeVersion: defaults.minNodeVersion,\n    autoApproveOptions: {\n        secret: \"GITHUB_TOKEN\",\n        allowedUsernames: [\"nikovirtala\"],\n    },\n    dependabot: false,\n    depsUpgradeOptions: {\n        workflowOptions: {\n            labels: [\"auto-approve\", \"auto-merge\"],\n        },\n    },\n    github: true,\n    mergify: true,\n    autoMerge: true,\n    jest: false,\n    eslint: false,\n    prettier: false,\n    biome: true,\n    biomeOptions: {\n        biomeConfig: {\n            formatter: {\n                indentStyle: javascript.biome_config.IndentStyle.SPACE,\n                indentWidth: 4,\n                lineWidth: 120,\n                useEditorconfig: false,\n            },\n        },\n        formatter: true,\n        linter: true,\n    },\n    packageManager: javascript.NodePackageManager.PNPM,\n    pnpmVersion: \"10\",\n    projenrcTs: true,\n    typescriptVersion: defaults.typescriptVersion,\n    tsconfig: {\n        compilerOptions: {\n            allowSyntheticDefaultImports: true,\n            alwaysStrict: true,\n            declaration: true,\n            esModuleInterop: true,\n            experimentalDecorators: true,\n            inlineSourceMap: true,\n            inlineSources: true,\n            isolatedModules: true,\n            noEmit: true,\n            noEmitOnError: false,\n            noFallthroughCasesInSwitch: true,\n            noImplicitAny: true,\n            noImplicitOverride: true,\n            noImplicitReturns: true,\n            noImplicitThis: true,\n            noUnusedLocals: true,\n            noUnusedParameters: true,\n            resolveJsonModule: true,\n            strict: true,\n            strictNullChecks: true,\n            strictPropertyInitialization: true,\n            stripInternal: true,\n        },\n    },\n} satisfies Partial<TypeScriptProjectOptions>;\n\nconst esModuleTsconfigOptions = {\n    tsconfig: {\n        compilerOptions: {\n            allowImportingTsExtensions: true,\n            lib: [\"esnext\"],\n            module: \"nodenext\",\n            moduleResolution: javascript.TypeScriptModuleResolution.NODE_NEXT,\n            target: \"esnext\",\n        },\n    },\n} satisfies Partial<TypeScriptProjectOptions>;\n\nconst publishableProjectDefaultOptions = {\n    author: defaults.author,\n    authorAddress: defaults.authorAddress,\n    npmTrustedPublishing: true,\n} satisfies Partial<cdk.JsiiProjectOptions>;\n\nconst cdkDefaultVersionOptions = {\n    cdkVersion: defaults.cdkVersion,\n    constructsVersion: defaults.constructsVersion,\n} satisfies Partial<awscdk.AwsCdkConstructLibraryOptions>;\n\nexport const defaultOptions = {\n    typescript: {\n        TypeScriptProject: mergeAll<typescript.TypeScriptProjectOptions>(\n            projectDefaultOptions,\n            esModuleTsconfigOptions,\n        ),\n    },\n    cdk: {\n        JsiiProject: mergeAll<cdk.JsiiProjectOptions>(projectDefaultOptions, publishableProjectDefaultOptions, {\n            jsiiVersion: defaults.jsiiVersion,\n        }),\n    },\n    awscdk: {\n        AwsCdkTypeScriptApp: mergeAll<awscdk.AwsCdkTypeScriptAppOptions>(\n            projectDefaultOptions,\n            esModuleTsconfigOptions,\n            cdkDefaultVersionOptions,\n        ),\n        AwsCdkConstructLibrary: mergeAll<awscdk.AwsCdkConstructLibraryOptions>(\n            projectDefaultOptions,\n            publishableProjectDefaultOptions,\n            cdkDefaultVersionOptions,\n        ),\n    },\n};\n"]}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * Error thrown when attempting to decrease indent level below zero in CodeBuffer
3
+ */
4
+ export declare class InvalidIndentLevelError extends Error {
5
+ constructor();
6
+ }
7
+ /**
8
+ * Error thrown when base class format is invalid
9
+ */
10
+ export declare class InvalidBaseClassFormatError extends Error {
11
+ readonly baseClass: string;
12
+ constructor(baseClass: string);
13
+ }
14
+ /**
15
+ * Error thrown when file path is invalid or missing directory separator
16
+ */
17
+ export declare class InvalidFilePathError extends Error {
18
+ readonly filePath: string;
19
+ constructor(filePath: string);
20
+ }
package/lib/errors.js ADDED
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InvalidFilePathError = exports.InvalidBaseClassFormatError = exports.InvalidIndentLevelError = void 0;
4
+ /**
5
+ * Error thrown when attempting to decrease indent level below zero in CodeBuffer
6
+ */
7
+ class InvalidIndentLevelError extends Error {
8
+ constructor() {
9
+ super("Cannot decrease indent level below zero");
10
+ this.name = "InvalidIndentLevelError";
11
+ }
12
+ }
13
+ exports.InvalidIndentLevelError = InvalidIndentLevelError;
14
+ /**
15
+ * Error thrown when base class format is invalid
16
+ */
17
+ class InvalidBaseClassFormatError extends Error {
18
+ constructor(baseClass) {
19
+ super(`Base class must be in format "module.ClassName", got: ${baseClass}`);
20
+ this.baseClass = baseClass;
21
+ this.name = "InvalidBaseClassFormatError";
22
+ }
23
+ }
24
+ exports.InvalidBaseClassFormatError = InvalidBaseClassFormatError;
25
+ /**
26
+ * Error thrown when file path is invalid or missing directory separator
27
+ */
28
+ class InvalidFilePathError extends Error {
29
+ constructor(filePath) {
30
+ super(`File path must contain directory separator, got: ${filePath}`);
31
+ this.filePath = filePath;
32
+ this.name = "InvalidFilePathError";
33
+ }
34
+ }
35
+ exports.InvalidFilePathError = InvalidFilePathError;
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7R0FFRztBQUNILE1BQWEsdUJBQXdCLFNBQVEsS0FBSztJQUM5QztRQUNJLEtBQUssQ0FBQyx5Q0FBeUMsQ0FBQyxDQUFDO1FBQ2pELElBQUksQ0FBQyxJQUFJLEdBQUcseUJBQXlCLENBQUM7SUFDMUMsQ0FBQztDQUNKO0FBTEQsMERBS0M7QUFFRDs7R0FFRztBQUNILE1BQWEsMkJBQTRCLFNBQVEsS0FBSztJQUNsRCxZQUE0QixTQUFpQjtRQUN6QyxLQUFLLENBQUMseURBQXlELFNBQVMsRUFBRSxDQUFDLENBQUM7UUFEcEQsY0FBUyxHQUFULFNBQVMsQ0FBUTtRQUV6QyxJQUFJLENBQUMsSUFBSSxHQUFHLDZCQUE2QixDQUFDO0lBQzlDLENBQUM7Q0FDSjtBQUxELGtFQUtDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLG9CQUFxQixTQUFRLEtBQUs7SUFDM0MsWUFBNEIsUUFBZ0I7UUFDeEMsS0FBSyxDQUFDLG9EQUFvRCxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBRDlDLGFBQVEsR0FBUixRQUFRLENBQVE7UUFFeEMsSUFBSSxDQUFDLElBQUksR0FBRyxzQkFBc0IsQ0FBQztJQUN2QyxDQUFDO0NBQ0o7QUFMRCxvREFLQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXJyb3IgdGhyb3duIHdoZW4gYXR0ZW1wdGluZyB0byBkZWNyZWFzZSBpbmRlbnQgbGV2ZWwgYmVsb3cgemVybyBpbiBDb2RlQnVmZmVyXG4gKi9cbmV4cG9ydCBjbGFzcyBJbnZhbGlkSW5kZW50TGV2ZWxFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoXCJDYW5ub3QgZGVjcmVhc2UgaW5kZW50IGxldmVsIGJlbG93IHplcm9cIik7XG4gICAgICAgIHRoaXMubmFtZSA9IFwiSW52YWxpZEluZGVudExldmVsRXJyb3JcIjtcbiAgICB9XG59XG5cbi8qKlxuICogRXJyb3IgdGhyb3duIHdoZW4gYmFzZSBjbGFzcyBmb3JtYXQgaXMgaW52YWxpZFxuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZEJhc2VDbGFzc0Zvcm1hdEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBiYXNlQ2xhc3M6IHN0cmluZykge1xuICAgICAgICBzdXBlcihgQmFzZSBjbGFzcyBtdXN0IGJlIGluIGZvcm1hdCBcIm1vZHVsZS5DbGFzc05hbWVcIiwgZ290OiAke2Jhc2VDbGFzc31gKTtcbiAgICAgICAgdGhpcy5uYW1lID0gXCJJbnZhbGlkQmFzZUNsYXNzRm9ybWF0RXJyb3JcIjtcbiAgICB9XG59XG5cbi8qKlxuICogRXJyb3IgdGhyb3duIHdoZW4gZmlsZSBwYXRoIGlzIGludmFsaWQgb3IgbWlzc2luZyBkaXJlY3Rvcnkgc2VwYXJhdG9yXG4gKi9cbmV4cG9ydCBjbGFzcyBJbnZhbGlkRmlsZVBhdGhFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVhZG9ubHkgZmlsZVBhdGg6IHN0cmluZykge1xuICAgICAgICBzdXBlcihgRmlsZSBwYXRoIG11c3QgY29udGFpbiBkaXJlY3Rvcnkgc2VwYXJhdG9yLCBnb3Q6ICR7ZmlsZVBhdGh9YCk7XG4gICAgICAgIHRoaXMubmFtZSA9IFwiSW52YWxpZEZpbGVQYXRoRXJyb3JcIjtcbiAgICB9XG59XG4iXX0=
@@ -1132,18 +1132,18 @@ export interface AwsCdkConstructLibraryProjectOptions {
1132
1132
  */
1133
1133
  readonly name: string;
1134
1134
  /**
1135
- * The Vitest configuration (when enabled).
1136
- * @default - default Vitest configuration
1135
+ * Enable Mise component
1136
+ * @default true
1137
1137
  */
1138
- readonly vitestOptions?: VitestOptions;
1138
+ readonly mise?: boolean;
1139
1139
  /**
1140
- * Enable testing with Vitest.
1140
+ * Enable Vitest component
1141
1141
  * @default true
1142
1142
  */
1143
1143
  readonly vitest?: boolean;
1144
1144
  /**
1145
- * Create mise.toml with project Node.js version
1146
- * @default true
1145
+ * Vitest configuration
1146
+ * @default - default Vitest configuration
1147
1147
  */
1148
- readonly mise?: boolean;
1148
+ readonly vitestOptions?: VitestOptions;
1149
1149
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"awscdk-construct-library-options.generated.js","sourceRoot":"","sources":["../../src/projects/awscdk-construct-library-options.generated.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".\nimport type { awscdk, cdk, github, GitOptions, GroupRunnerOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjenrcJsonOptions, ReleasableCommits, release, RenovatebotOptions, SampleReadmeProps, typescript } from 'projen';\nimport type { VitestOptions } from '../';\n\n/**\n * AwsCdkConstructLibraryProjectOptions\n */\nexport interface AwsCdkConstructLibraryProjectOptions {\n  /**\n   * Common options for all AWS Lambda functions.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly lambdaOptions?: awscdk.LambdaFunctionCommonOptions;\n  /**\n   * Automatically adds an `awscdk.LambdaExtension` for each `.lambda-extension.ts` entrypoint in your source tree. If this is disabled, you can manually add an `awscdk.AutoDiscover` component to your project.\n   * @default true\n   * @stability experimental\n   */\n  readonly lambdaExtensionAutoDiscover?: boolean;\n  /**\n   * Automatically adds an `aws_lambda.Function` for each `.lambda.ts` handler in your source tree. If this is disabled, you either need to explicitly call `aws_lambda.Function.autoDiscover()` or define a `new aws_lambda.Function()` for each handler.\n   * @default true\n   * @stability experimental\n   */\n  readonly lambdaAutoDiscover?: boolean;\n  /**\n   * Automatically discovers and creates integration tests for each `.integ.ts` file under your test directory.\n   * @default true\n   * @stability experimental\n   */\n  readonly integrationTestAutoDiscover?: boolean;\n  /**\n   * Enable experimental support for the AWS CDK integ-runner.\n   * @default false\n   * @stability experimental\n   */\n  readonly experimentalIntegRunner?: boolean;\n  /**\n   * Automatically adds an `cloudfront.experimental.EdgeFunction` for each `.edge-lambda.ts` handler in your source tree. If this is disabled, you can manually add an `awscdk.AutoDiscover` component to your project.\n   * @default true\n   * @stability experimental\n   */\n  readonly edgeLambdaAutoDiscover?: boolean;\n  /**\n   * Minimum version of the `constructs` library to depend on.\n   * @default - for CDK 1.x the default is \"3.2.27\", for CDK 2.x the default is\n\"10.0.5\".\n   * @stability experimental\n   */\n  readonly constructsVersion?: string;\n  /**\n   * Use pinned version instead of caret version for CDK.\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   * @stability experimental\n   */\n  readonly cdkVersionPinning?: boolean;\n  /**\n   * Version range of the AWS CDK CLI to depend on.\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   * @default \"^2\"\n   * @stability experimental\n   */\n  readonly cdkCliVersion?: string;\n  /**\n   * Install the assertions library?\n   * Only needed for CDK 1.x. If using CDK 2.x then\n   * assertions is already included in 'aws-cdk-lib'\n   * @default - will be included by default for AWS CDK >= 1.111.0 < 2.0.0\n   * @stability experimental\n   */\n  readonly cdkAssertions?: boolean;\n  /**\n   * Minimum version of the AWS CDK to depend on.\n   * @default \"2.1.0\"\n   * @stability experimental\n   */\n  readonly cdkVersion: string;\n  /**\n   * Libraries will be picked up by the construct catalog when they are published to npm as jsii modules and will be published under:.\n   * https://awscdk.io/packages/[@SCOPE/]PACKAGE@VERSION\n   *\n   * The catalog will also post a tweet to https://twitter.com/awscdkio with the\n   * package name, description and the above link. You can disable these tweets\n   * through `{ announce: false }`.\n   *\n   * You can also add a Twitter handle through `{ twitter: 'xx' }` which will be\n   * mentioned in the tweet.\n   * @default - new version will be announced\n   * @stability experimental\n   */\n  readonly catalog?: cdk.Catalog;\n  /**\n   * @default \".\"\n   * @stability experimental\n   */\n  readonly rootdir?: string;\n  /**\n   * Publish to pypi.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToPypi?: cdk.JsiiPythonTarget;\n  /**\n   * Publish to NuGet.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToNuget?: cdk.JsiiDotNetTarget;\n  /**\n   * Publish to maven.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToMaven?: cdk.JsiiJavaTarget;\n  /**\n   * Publish Go bindings to a git repository.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToGo?: cdk.JsiiGoTarget;\n  /**\n   * Version of the jsii compiler to use.\n   * Set to \"*\" if you want to manually manage the version of jsii in your\n   * project by managing updates to `package.json` on your own.\n   *\n   * NOTE: The jsii compiler releases since 5.0.0 are not semantically versioned\n   * and should remain on the same minor, so we recommend using a `~` dependency\n   * (e.g. `~5.0.0`).\n   * @default \"~5.8.0\"\n   * @stability experimental\n   * @pjnew \"~5.9.0\"\n   */\n  readonly jsiiVersion?: string;\n  /**\n   * Accepts a list of glob patterns.\n   * Files matching any of those patterns will be excluded from the TypeScript compiler input.\n   *\n   * By default, jsii will include all *.ts files (except .d.ts files) in the TypeScript compiler input.\n   * This can be problematic for example when the package's build or test procedure generates .ts files\n   * that cannot be compiled with jsii's compiler settings.\n   * @stability experimental\n   */\n  readonly excludeTypescript?: Array<string>;\n  /**\n   * File path for generated docs.\n   * @default \"API.md\"\n   * @stability experimental\n   */\n  readonly docgenFilePath?: string;\n  /**\n   * Emit a compressed version of the assembly.\n   * @default false\n   * @stability experimental\n   */\n  readonly compressAssembly?: boolean;\n  /**\n   * Name of the ignore file for API compatibility tests.\n   * @default \".compatignore\"\n   * @stability experimental\n   */\n  readonly compatIgnore?: string;\n  /**\n   * Automatically run API compatibility test against the latest version published to npm after compilation.\n   * - You can manually run compatibility tests using `yarn compat` if this feature is disabled.\n   * - You can ignore compatibility failures by adding lines to a \".compatignore\" file.\n   * @default false\n   * @stability experimental\n   */\n  readonly compat?: boolean;\n  /**\n   * Git repository URL.\n   * @default $GIT_REMOTE\n   * @stability experimental\n   */\n  readonly repositoryUrl: string;\n  /**\n   * Email or URL of the library author.\n   * @default $GIT_USER_EMAIL\n   * @stability experimental\n   */\n  readonly authorAddress: string;\n  /**\n   * The name of the library author.\n   * @default $GIT_USER_NAME\n   * @stability experimental\n   */\n  readonly author: string;\n  /**\n   * TypeScript version to use.\n   * NOTE: Typescript is not semantically versioned and should remain on the\n   * same minor, so we recommend using a `~` dependency (e.g. `~1.2.3`).\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly typescriptVersion?: string;\n  /**\n   * The name of the development tsconfig.json file.\n   * @default \"tsconfig.dev.json\"\n   * @stability experimental\n   */\n  readonly tsconfigDevFile?: string;\n  /**\n   * Custom tsconfig options for the development tsconfig.json file (used for testing).\n   * @default - use the production tsconfig options\n   * @stability experimental\n   */\n  readonly tsconfigDev?: javascript.TypescriptConfigOptions;\n  /**\n   * Custom TSConfig.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly tsconfig?: javascript.TypescriptConfigOptions;\n  /**\n   * Jest tests directory. Tests files should be named `xxx.test.ts`.\n   * If this directory is under `srcdir` (e.g. `src/test`, `src/__tests__`),\n   * then tests are going to be compiled into `lib/` and executed as javascript.\n   * If the test directory is outside of `src`, then we configure jest to\n   * compile the code in-memory.\n   * @default \"test\"\n   * @stability experimental\n   */\n  readonly testdir?: string;\n  /**\n   * Typescript sources directory.\n   * @default \"src\"\n   * @stability experimental\n   */\n  readonly srcdir?: string;\n  /**\n   * Options for .projenrc.ts.\n   * @stability experimental\n   */\n  readonly projenrcTsOptions?: typescript.ProjenrcOptions;\n  /**\n   * Use TypeScript for your projenrc file (`.projenrc.ts`).\n   * @default false\n   * @stability experimental\n   * @pjnew true\n   */\n  readonly projenrcTs?: boolean;\n  /**\n   * Typescript  artifacts output directory.\n   * @default \"lib\"\n   * @stability experimental\n   */\n  readonly libdir?: string;\n  /**\n   * The .d.ts file that includes the type declarations for this module.\n   * @default - .d.ts file derived from the project's entrypoint (usually lib/index.d.ts)\n   * @stability experimental\n   */\n  readonly entrypointTypes?: string;\n  /**\n   * Docs directory.\n   * @default \"docs\"\n   * @stability experimental\n   */\n  readonly docsDirectory?: string;\n  /**\n   * Docgen by Typedoc.\n   * @default false\n   * @stability experimental\n   */\n  readonly docgen?: boolean;\n  /**\n   * Do not generate a `tsconfig.dev.json` file.\n   * @default false\n   * @stability experimental\n   */\n  readonly disableTsconfigDev?: boolean;\n  /**\n   * Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler).\n   * @default false\n   * @stability experimental\n   */\n  readonly disableTsconfig?: boolean;\n  /**\n   * Enable Node.js package cache in GitHub workflows.\n   * @default false\n   * @stability experimental\n   */\n  readonly workflowPackageCache?: boolean;\n  /**\n   * The node version used in GitHub Actions workflows.\n   * Always use this option if your GitHub Actions workflows require a specific to run.\n   * @default - `minNodeVersion` if set, otherwise `lts/*`.\n   * @stability experimental\n   */\n  readonly workflowNodeVersion?: string;\n  /**\n   * The git identity to use in workflows.\n   * @default - default GitHub Actions user\n   * @stability experimental\n   */\n  readonly workflowGitIdentity?: github.GitIdentity;\n  /**\n   * Workflow steps to use in order to bootstrap this repo.\n   * @default \"yarn install --frozen-lockfile && yarn projen\"\n   * @stability experimental\n   */\n  readonly workflowBootstrapSteps?: Array<github.workflows.JobStep>;\n  /**\n   * Automatically release to npm when new versions are introduced.\n   * @default false\n   * @stability experimental\n   */\n  readonly releaseToNpm?: boolean;\n  /**\n   * Add release management to this project.\n   * @default - true (false for subprojects)\n   * @stability experimental\n   */\n  readonly release?: boolean;\n  /**\n   * The contents of the pull request template.\n   * @default - default content\n   * @stability experimental\n   */\n  readonly pullRequestTemplateContents?: Array<string>;\n  /**\n   * Include a GitHub pull request template.\n   * @default true\n   * @stability experimental\n   */\n  readonly pullRequestTemplate?: boolean;\n  /**\n   * Version of projen to install.\n   * @default - Defaults to the latest version.\n   * @stability experimental\n   */\n  readonly projenVersion?: string;\n  /**\n   * Options for .projenrc.js.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsOptions?: javascript.ProjenrcOptions;\n  /**\n   * Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation.\n   * @default - true if projenrcJson is false\n   * @stability experimental\n   */\n  readonly projenrcJs?: boolean;\n  /**\n   * Indicates of \"projen\" should be installed as a devDependency.\n   * @default - true if not a subproject\n   * @stability experimental\n   */\n  readonly projenDevDependency?: boolean;\n  /**\n   * Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).\n   * @default true\n   * @stability experimental\n   */\n  readonly package?: boolean;\n  /**\n   * Configuration options for .npmignore file.\n   * @stability experimental\n   */\n  readonly npmIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs.\n   * @default true\n   * @stability experimental\n   */\n  readonly npmignoreEnabled?: boolean;\n  /**\n   * Additional entries to .gitignore.\n   * @stability experimental\n   */\n  readonly gitignore?: Array<string>;\n  /**\n   * Options for `UpgradeDependencies`.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly depsUpgradeOptions?: javascript.UpgradeDependenciesOptions;\n  /**\n   * Use tasks and github workflows to handle dependency upgrades.\n   * Cannot be used in conjunction with `dependabot`.\n   * @default true\n   * @stability experimental\n   */\n  readonly depsUpgrade?: boolean;\n  /**\n   * Options for dependabot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly dependabotOptions?: github.DependabotOptions;\n  /**\n   * Use dependabot to handle dependency upgrades.\n   * Cannot be used in conjunction with `depsUpgrade`.\n   * @default false\n   * @stability experimental\n   */\n  readonly dependabot?: boolean;\n  /**\n   * The copyright years to put in the LICENSE file.\n   * @default - current year\n   * @stability experimental\n   */\n  readonly copyrightPeriod?: string;\n  /**\n   * License copyright owner.\n   * @default - defaults to the value of authorName or \"\" if `authorName` is undefined.\n   * @stability experimental\n   */\n  readonly copyrightOwner?: string;\n  /**\n   * Define the secret name for a specified https://codecov.io/ token.\n   * @default - OIDC auth is used\n   * @stability experimental\n   */\n  readonly codeCovTokenSecret?: string;\n  /**\n   * Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v5 By default, OIDC auth is used. Alternatively a token can be provided via `codeCovTokenSecret`.\n   * @default false\n   * @stability experimental\n   */\n  readonly codeCov?: boolean;\n  /**\n   * Configure which licenses should be deemed acceptable for use by dependencies.\n   * This setting will cause the build to fail, if any prohibited or not allowed licenses ares encountered.\n   * @default - no license checks are run during the build and all licenses will be accepted\n   * @stability experimental\n   */\n  readonly checkLicenses?: javascript.LicenseCheckerOptions;\n  /**\n   * Options for `Bundler`.\n   * @stability experimental\n   */\n  readonly bundlerOptions?: javascript.BundlerOptions;\n  /**\n   * Options for PR build workflow.\n   * @stability experimental\n   */\n  readonly buildWorkflowOptions?: javascript.BuildWorkflowOptions;\n  /**\n   * Define a GitHub workflow for building PRs.\n   * @default - true if not a subproject\n   * @stability experimental\n   */\n  readonly buildWorkflow?: boolean;\n  /**\n   * Biome options.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly biomeOptions?: javascript.BiomeOptions;\n  /**\n   * Setup Biome.\n   * @default false\n   * @stability experimental\n   */\n  readonly biome?: boolean;\n  /**\n   * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).\n   * Throw if set to true but `autoApproveOptions` are not defined.\n   * @default - true\n   * @stability experimental\n   */\n  readonly autoApproveUpgrades?: boolean;\n  /**\n   * Security audit options.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly auditDepsOptions?: javascript.AuditOptions;\n  /**\n   * Run security audit on dependencies.\n   * When enabled, creates an \"audit\" task that checks for known security vulnerabilities\n   * in dependencies. By default, runs during every build and checks for \"high\" severity\n   * vulnerabilities or above in all dependencies (including dev dependencies).\n   * @default false\n   * @stability experimental\n   */\n  readonly auditDeps?: boolean;\n  /**\n   * A directory which will contain build artifacts.\n   * @default \"dist\"\n   * @stability experimental\n   */\n  readonly artifactsDirectory?: string;\n  /**\n   * The name of the main release branch.\n   * @default \"main\"\n   * @stability experimental\n   */\n  readonly defaultReleaseBranch: string;\n  /**\n   * Github Runner Group selection options.\n   * @stability experimental\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOnGroup?: GroupRunnerOptions;\n  /**\n   * Github Runner selection labels.\n   * @default [\"ubuntu-latest\"]\n   * @stability experimental\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOn?: Array<string>;\n  /**\n   * Container image to use for GitHub workflows.\n   * @default - default image\n   * @stability experimental\n   */\n  readonly workflowContainerImage?: string;\n  /**\n   * Custom configuration used when creating changelog with commit-and-tag-version package.\n   * Given values either append to default configuration or overwrite values in it.\n   * @default - standard configuration applicable for GitHub repositories\n   * @stability experimental\n   */\n  readonly versionrcOptions?: Record<string, any>;\n  /**\n   * A set of workflow steps to execute in order to setup the workflow container.\n   * @stability experimental\n   */\n  readonly releaseWorkflowSetupSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The name of the default release workflow.\n   * @default \"release\"\n   * @stability experimental\n   */\n  readonly releaseWorkflowName?: string;\n  /**\n   * Build environment variables for release workflows.\n   * @default {}\n   * @stability experimental\n   */\n  readonly releaseWorkflowEnv?: Record<string, string>;\n  /**\n   * The release trigger to use.\n   * @default - Continuous releases (`ReleaseTrigger.continuous()`)\n   * @stability experimental\n   */\n  readonly releaseTrigger?: release.ReleaseTrigger;\n  /**\n   * Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.\n   * Note: this prefix is used to detect the latest tagged version\n   * when bumping, so if you change this on a project with an existing version\n   * history, you may need to manually tag your latest release\n   * with the new prefix.\n   * @default \"v\"\n   * @stability experimental\n   */\n  readonly releaseTagPrefix?: string;\n  /**\n   * The label to apply to issues indicating publish failures.\n   * Only applies if `releaseFailureIssue` is true.\n   * @default \"failed-release\"\n   * @stability experimental\n   */\n  readonly releaseFailureIssueLabel?: string;\n  /**\n   * Create a github issue on every failed publishing task.\n   * @default false\n   * @stability experimental\n   */\n  readonly releaseFailureIssue?: boolean;\n  /**\n   * The GitHub Actions environment used for the release.\n   * This can be used to add an explicit approval step to the release\n   * or limit who can initiate a release through environment protection rules.\n   *\n   * When multiple artifacts are released, the environment can be overwritten\n   * on a per artifact basis.\n   * @default - no environment used, unless set at the artifact level\n   * @stability experimental\n   */\n  readonly releaseEnvironment?: string;\n  /**\n   * Defines additional release branches.\n   * A workflow will be created for each\n   * release branch which will publish releases from commits in this branch.\n   * Each release branch _must_ be assigned a major version number which is used\n   * to enforce that versions published from that branch always use that major\n   * version. If multiple branches are used, the `majorVersion` field must also\n   * be provided for the default branch.\n   * @default - no additional branches are used for release. you can use\n`addBranch()` to add additional branches.\n   * @stability experimental\n   */\n  readonly releaseBranches?: Record<string, release.BranchOptions>;\n  /**\n   * Find commits that should be considered releasable Used to decide if a release is required.\n   * @default ReleasableCommits.everyCommit()\n   * @stability experimental\n   */\n  readonly releasableCommits?: ReleasableCommits;\n  /**\n   * Define publishing tasks that can be executed manually as well as workflows.\n   * Normally, publishing only happens within automated workflows. Enable this\n   * in order to create a publishing task for each publishing activity.\n   * @default false\n   * @stability experimental\n   */\n  readonly publishTasks?: boolean;\n  /**\n   * Instead of actually publishing to package managers, just print the publishing command.\n   * @default false\n   * @stability experimental\n   */\n  readonly publishDryRun?: boolean;\n  /**\n   * Bump versions from the default branch as pre-releases (e.g. \"beta\", \"alpha\", \"pre\").\n   * @default - normal semantic versions\n   * @stability experimental\n   */\n  readonly prerelease?: string;\n  /**\n   * Steps to execute after build as part of the release workflow.\n   * @default []\n   * @stability experimental\n   */\n  readonly postBuildSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The npmDistTag to use when publishing from the default branch.\n   * To set the npm dist-tag for release branches, set the `npmDistTag` property\n   * for each branch.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly npmDistTag?: string;\n  /**\n   * A shell command to control the next version to release.\n   * If present, this shell command will be run before the bump is executed, and\n   * it determines what version to release. It will be executed in the following\n   * environment:\n   *\n   * - Working directory: the project directory.\n   * - `$VERSION`: the current version. Looks like `1.2.3`.\n   * - `$LATEST_TAG`: the most recent tag. Looks like `prefix-v1.2.3`, or may be unset.\n   * - `$SUGGESTED_BUMP`: the suggested bump action based on commits. One of `major|minor|patch|none`.\n   *\n   * The command should print one of the following to `stdout`:\n   *\n   * - Nothing: the next version number will be determined based on commit history.\n   * - `x.y.z`: the next version number will be `x.y.z`.\n   * - `major|minor|patch`: the next version number will be the current version number\n   *   with the indicated component bumped.\n   *\n   * This setting cannot be specified together with `minMajorVersion`; the invoked\n   * script can be used to achieve the effects of `minMajorVersion`.\n   * @default - The next version will be determined based on the commit history and project settings.\n   * @stability experimental\n   */\n  readonly nextVersionCommand?: string;\n  /**\n   * Minimal Major version to release.\n   * This can be useful to set to 1, as breaking changes before the 1.x major\n   * release are not incrementing the major version number.\n   *\n   * Can not be set together with `majorVersion`.\n   * @default - No minimum version is being enforced\n   * @stability experimental\n   */\n  readonly minMajorVersion?: number;\n  /**\n   * Major version to release from the default branch.\n   * If this is specified, we bump the latest version of this major version line.\n   * If not specified, we bump the global latest version.\n   * @default - Major version is not enforced.\n   * @stability experimental\n   */\n  readonly majorVersion?: number;\n  /**\n   * Version requirement of `publib` which is used to publish modules to npm.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly jsiiReleaseVersion?: string;\n  /**\n   * The `commit-and-tag-version` compatible package used to bump the package version, as a dependency string.\n   * This can be any compatible package version, including the deprecated `standard-version@9`.\n   * @default - A recent version of \"commit-and-tag-version\"\n   * @stability experimental\n   */\n  readonly bumpPackage?: string;\n  /**\n   * Options for Yarn Berry.\n   * @default - Yarn Berry v4 with all default options\n   * @stability experimental\n   */\n  readonly yarnBerryOptions?: javascript.YarnBerryOptions;\n  /**\n   * Package's Stability.\n   * @stability experimental\n   */\n  readonly stability?: string;\n  /**\n   * Options for privately hosted scoped packages.\n   * @default - fetch all scoped packages from the public npm registry\n   * @stability experimental\n   */\n  readonly scopedPackagesOptions?: Array<javascript.ScopedPackagesOptions>;\n  /**\n   * If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives.\n   * @stability experimental\n   */\n  readonly repositoryDirectory?: string;\n  /**\n   * The repository is the location where the actual code for your package lives.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-repository\n   * @stability experimental\n   */\n  readonly repository?: string;\n  /**\n   * The version of PNPM to use if using PNPM as a package manager.\n   * @default \"9\"\n   * @stability experimental\n   */\n  readonly pnpmVersion?: string;\n  /**\n   * Peer dependencies for this module.\n   * Dependencies listed here are required to\n   * be installed (and satisfied) by the _consumer_ of this library. Using peer\n   * dependencies allows you to ensure that only a single module of a certain\n   * library exists in the `node_modules` tree of your consumers.\n   *\n   * Note that prior to npm@7, peer dependencies are _not_ automatically\n   * installed, which means that adding peer dependencies to a library will be a\n   * breaking change for your customers.\n   *\n   * Unless `peerDependencyOptions.pinnedDevDependency` is disabled (it is\n   * enabled by default), projen will automatically add a dev dependency with a\n   * pinned version for each peer dependency. This will ensure that you build &\n   * test your module against the lowest peer version required.\n   * @default []\n   * @stability experimental\n   */\n  readonly peerDeps?: Array<string>;\n  /**\n   * Options for `peerDeps`.\n   * @stability experimental\n   */\n  readonly peerDependencyOptions?: javascript.PeerDependencyOptions;\n  /**\n   * The \"name\" in package.json.\n   * @default - defaults to project name\n   * @stability experimental\n   * @featured true\n   */\n  readonly packageName?: string;\n  /**\n   * The Node Package Manager used to execute scripts.\n   * @default NodePackageManager.YARN_CLASSIC\n   * @stability experimental\n   */\n  readonly packageManager?: javascript.NodePackageManager;\n  /**\n   * Use trusted publishing for publishing to npmjs.com Needs to be pre-configured on npm.js to work.\n   * @default - false\n   * @stability experimental\n   */\n  readonly npmTrustedPublishing?: boolean;\n  /**\n   * GitHub secret which contains the NPM token to use when publishing packages.\n   * @default \"NPM_TOKEN\"\n   * @stability experimental\n   */\n  readonly npmTokenSecret?: string;\n  /**\n   * The base URL of the npm package registry.\n   * Must be a URL (e.g. start with \"https://\" or \"http://\")\n   * @default \"https://registry.npmjs.org\"\n   * @stability experimental\n   */\n  readonly npmRegistryUrl?: string;\n  /**\n   * Should provenance statements be generated when the package is published.\n   * A supported package manager is required to publish a package with npm provenance statements and\n   * you will need to use a supported CI/CD provider.\n   *\n   * Note that the projen `Release` and `Publisher` components are using `publib` to publish packages,\n   * which is using npm internally and supports provenance statements independently of the package manager used.\n   * @default - true for public packages, false otherwise\n   * @stability experimental\n   */\n  readonly npmProvenance?: boolean;\n  /**\n   * Access level of the npm package.\n   * @default - for scoped packages (e.g. `foo@bar`), the default is\n`NpmAccess.RESTRICTED`, for non-scoped packages, the default is\n`NpmAccess.PUBLIC`.\n   * @stability experimental\n   */\n  readonly npmAccess?: javascript.NpmAccess;\n  /**\n   * The minimum node version required by this package to function. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any older versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option, even if your package is incompatible with EOL versions of node.\n   * Consider this option only if your package depends on a specific feature, that is not available in other LTS versions.\n   * Setting this option has very high impact on the consumers of your package,\n   * as package managers will actively prevent usage with node versions you have marked as incompatible.\n   *\n   * To change the node version of your CI/CD workflows, use `workflowNodeVersion`.\n   * @default - no minimum version is enforced\n   * @stability experimental\n   */\n  readonly minNodeVersion?: string;\n  /**\n   * The maximum node version supported by this package. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any newer versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option.\n   * Consider this option only if your package is known to not function with newer versions of node.\n   * @default - no maximum version is enforced\n   * @stability experimental\n   */\n  readonly maxNodeVersion?: string;\n  /**\n   * Indicates if a license should be added.\n   * @default true\n   * @stability experimental\n   */\n  readonly licensed?: boolean;\n  /**\n   * License's SPDX identifier.\n   * See https://github.com/projen/projen/tree/main/license-text for a list of supported licenses.\n   * Use the `licensed` option if you want to no license to be specified.\n   * @default \"Apache-2.0\"\n   * @stability experimental\n   */\n  readonly license?: string;\n  /**\n   * Keywords to include in `package.json`.\n   * @stability experimental\n   */\n  readonly keywords?: Array<string>;\n  /**\n   * Package's Homepage / Website.\n   * @stability experimental\n   */\n  readonly homepage?: string;\n  /**\n   * Module entrypoint (`main` in `package.json`).\n   * Set to an empty string to not include `main` in your package.json\n   * @default \"lib/index.js\"\n   * @stability experimental\n   */\n  readonly entrypoint?: string;\n  /**\n   * Build dependencies for this module.\n   * These dependencies will only be\n   * available in your build environment but will not be fetched when this\n   * module is consumed.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly devDeps?: Array<string>;\n  /**\n   * The description is just a string that helps people understand the purpose of the package.\n   * It can be used when searching for packages in a package manager as well.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-description\n   * @stability experimental\n   * @featured true\n   */\n  readonly description?: string;\n  /**\n   * Runtime dependencies of this module.\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly deps?: Array<string>;\n  /**\n   * Options for npm packages using AWS CodeArtifact.\n   * This is required if publishing packages to, or installing scoped packages from AWS CodeArtifact\n   * @default - undefined\n   * @stability experimental\n   */\n  readonly codeArtifactOptions?: javascript.CodeArtifactOptions;\n  /**\n   * The version of Bun to use if using Bun as a package manager.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly bunVersion?: string;\n  /**\n   * List of dependencies to bundle into this module.\n   * These modules will be\n   * added both to the `dependencies` section and `bundledDependencies` section of\n   * your `package.json`.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @stability experimental\n   */\n  readonly bundledDeps?: Array<string>;\n  /**\n   * The url to your project's issue tracker.\n   * @stability experimental\n   */\n  readonly bugsUrl?: string;\n  /**\n   * The email address to which issues should be reported.\n   * @stability experimental\n   */\n  readonly bugsEmail?: string;\n  /**\n   * Binary programs vended with your module.\n   * You can use this option to add/customize how binaries are represented in\n   * your `package.json`, but unless `autoDetectBin` is `false`, every\n   * executable file under `bin` will automatically be added to this section.\n   * @stability experimental\n   */\n  readonly bin?: Record<string, string>;\n  /**\n   * Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoDetectBin?: boolean;\n  /**\n   * Author's URL / Website.\n   * @stability experimental\n   */\n  readonly authorUrl?: string;\n  /**\n   * Is the author an organization.\n   * @stability experimental\n   */\n  readonly authorOrganization?: boolean;\n  /**\n   * Author's name.\n   * @stability experimental\n   */\n  readonly authorName?: string;\n  /**\n   * Author's e-mail.\n   * @stability experimental\n   */\n  readonly authorEmail?: string;\n  /**\n   * Allow the project to include `peerDependencies` and `bundledDependencies`.\n   * This is normally only allowed for libraries. For apps, there's no meaning\n   * for specifying these.\n   * @default true\n   * @stability experimental\n   */\n  readonly allowLibraryDependencies?: boolean;\n  /**\n   * Enable VSCode integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly vscode?: boolean;\n  /**\n   * Auto-close stale issues and pull requests.\n   * To disable set `stale` to `false`.\n   * @default - see defaults in `StaleOptions`\n   * @stability experimental\n   */\n  readonly staleOptions?: github.StaleOptions;\n  /**\n   * Auto-close of stale issues and pull request.\n   * See `staleOptions` for options.\n   * @default false\n   * @stability experimental\n   */\n  readonly stale?: boolean;\n  /**\n   * The README setup.\n   * @default - { filename: 'README.md', contents: '# replace this' }\n   * @stability experimental\n   */\n  readonly readme?: SampleReadmeProps;\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   * @stability experimental\n   */\n  readonly projenCredentials?: github.GithubCredentials;\n  /**\n   * Add a Gitpod development environment.\n   * @default false\n   * @stability experimental\n   */\n  readonly gitpod?: boolean;\n  /**\n   * Options for GitHub integration.\n   * @default - see GitHubOptions\n   * @stability experimental\n   */\n  readonly githubOptions?: github.GitHubOptions;\n  /**\n   * Enable GitHub integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly github?: boolean;\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces).\n   * @default false\n   * @stability experimental\n   */\n  readonly devContainer?: boolean;\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   * @stability experimental\n   */\n  readonly clobber?: boolean;\n  /**\n   * Configure options for automatic merging on GitHub.\n   * Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   * @default - see defaults in `AutoMergeOptions`\n   * @stability experimental\n   */\n  readonly autoMergeOptions?: github.AutoMergeOptions;\n  /**\n   * Enable automatic merging on GitHub.\n   * Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoMerge?: boolean;\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   * @stability experimental\n   */\n  readonly autoApproveOptions?: github.AutoApproveOptions;\n  /**\n   * Options for renovatebot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly renovatebotOptions?: RenovatebotOptions;\n  /**\n   * Use renovatebot to handle dependency upgrades.\n   * @default false\n   * @stability experimental\n   */\n  readonly renovatebot?: boolean;\n  /**\n   * Options for .projenrc.json.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsonOptions?: ProjenrcJsonOptions;\n  /**\n   * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.\n   * @default false\n   * @stability experimental\n   */\n  readonly projenrcJson?: boolean;\n  /**\n   * The shell command to use in order to run the projen CLI.\n   * Can be used to customize in special environments.\n   * @default \"npx projen\"\n   * @stability experimental\n   */\n  readonly projenCommand?: string;\n  /**\n   * The parent project, if this project is part of a bigger project.\n   * @stability experimental\n   */\n  readonly parent?: Project;\n  /**\n   * The root directory of the project.\n   * Relative to this directory, all files are synthesized.\n   *\n   * If this project has a parent, this directory is relative to the parent\n   * directory and it cannot be the same as the parent or any of it's other\n   * subprojects.\n   * @default \".\"\n   * @stability experimental\n   */\n  readonly outdir?: string;\n  /**\n   * Configure logging options such as verbosity.\n   * @default {}\n   * @stability experimental\n   */\n  readonly logging?: LoggerOptions;\n  /**\n   * Configuration options for git.\n   * @stability experimental\n   */\n  readonly gitOptions?: GitOptions;\n  /**\n   * Configuration options for .gitignore file.\n   * @stability experimental\n   */\n  readonly gitIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Whether to commit the managed files by default.\n   * @default true\n   * @stability experimental\n   */\n  readonly commitGenerated?: boolean;\n  /**\n   * This is the name of your project.\n   * @default $BASEDIR\n   * @stability experimental\n   * @featured true\n   */\n  readonly name: string;\n  /**\n   * The Vitest configuration (when enabled).\n   * @default - default Vitest configuration\n   */\n  readonly vitestOptions?: VitestOptions;\n  /**\n   * Enable testing with Vitest.\n   * @default true\n   */\n  readonly vitest?: boolean;\n  /**\n   * Create mise.toml with project Node.js version\n   * @default true\n   */\n  readonly mise?: boolean;\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"awscdk-construct-library-options.generated.js","sourceRoot":"","sources":["../../src/projects/awscdk-construct-library-options.generated.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".\nimport type { awscdk, cdk, github, GitOptions, GroupRunnerOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjenrcJsonOptions, ReleasableCommits, release, RenovatebotOptions, SampleReadmeProps, typescript } from 'projen';\nimport type { VitestOptions } from '../';\n\n/**\n * AwsCdkConstructLibraryProjectOptions\n */\nexport interface AwsCdkConstructLibraryProjectOptions {\n  /**\n   * Common options for all AWS Lambda functions.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly lambdaOptions?: awscdk.LambdaFunctionCommonOptions;\n  /**\n   * Automatically adds an `awscdk.LambdaExtension` for each `.lambda-extension.ts` entrypoint in your source tree. If this is disabled, you can manually add an `awscdk.AutoDiscover` component to your project.\n   * @default true\n   * @stability experimental\n   */\n  readonly lambdaExtensionAutoDiscover?: boolean;\n  /**\n   * Automatically adds an `aws_lambda.Function` for each `.lambda.ts` handler in your source tree. If this is disabled, you either need to explicitly call `aws_lambda.Function.autoDiscover()` or define a `new aws_lambda.Function()` for each handler.\n   * @default true\n   * @stability experimental\n   */\n  readonly lambdaAutoDiscover?: boolean;\n  /**\n   * Automatically discovers and creates integration tests for each `.integ.ts` file under your test directory.\n   * @default true\n   * @stability experimental\n   */\n  readonly integrationTestAutoDiscover?: boolean;\n  /**\n   * Enable experimental support for the AWS CDK integ-runner.\n   * @default false\n   * @stability experimental\n   */\n  readonly experimentalIntegRunner?: boolean;\n  /**\n   * Automatically adds an `cloudfront.experimental.EdgeFunction` for each `.edge-lambda.ts` handler in your source tree. If this is disabled, you can manually add an `awscdk.AutoDiscover` component to your project.\n   * @default true\n   * @stability experimental\n   */\n  readonly edgeLambdaAutoDiscover?: boolean;\n  /**\n   * Minimum version of the `constructs` library to depend on.\n   * @default - for CDK 1.x the default is \"3.2.27\", for CDK 2.x the default is\n\"10.0.5\".\n   * @stability experimental\n   */\n  readonly constructsVersion?: string;\n  /**\n   * Use pinned version instead of caret version for CDK.\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   * @stability experimental\n   */\n  readonly cdkVersionPinning?: boolean;\n  /**\n   * Version range of the AWS CDK CLI to depend on.\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   * @default \"^2\"\n   * @stability experimental\n   */\n  readonly cdkCliVersion?: string;\n  /**\n   * Install the assertions library?\n   * Only needed for CDK 1.x. If using CDK 2.x then\n   * assertions is already included in 'aws-cdk-lib'\n   * @default - will be included by default for AWS CDK >= 1.111.0 < 2.0.0\n   * @stability experimental\n   */\n  readonly cdkAssertions?: boolean;\n  /**\n   * Minimum version of the AWS CDK to depend on.\n   * @default \"2.1.0\"\n   * @stability experimental\n   */\n  readonly cdkVersion: string;\n  /**\n   * Libraries will be picked up by the construct catalog when they are published to npm as jsii modules and will be published under:.\n   * https://awscdk.io/packages/[@SCOPE/]PACKAGE@VERSION\n   *\n   * The catalog will also post a tweet to https://twitter.com/awscdkio with the\n   * package name, description and the above link. You can disable these tweets\n   * through `{ announce: false }`.\n   *\n   * You can also add a Twitter handle through `{ twitter: 'xx' }` which will be\n   * mentioned in the tweet.\n   * @default - new version will be announced\n   * @stability experimental\n   */\n  readonly catalog?: cdk.Catalog;\n  /**\n   * @default \".\"\n   * @stability experimental\n   */\n  readonly rootdir?: string;\n  /**\n   * Publish to pypi.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToPypi?: cdk.JsiiPythonTarget;\n  /**\n   * Publish to NuGet.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToNuget?: cdk.JsiiDotNetTarget;\n  /**\n   * Publish to maven.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToMaven?: cdk.JsiiJavaTarget;\n  /**\n   * Publish Go bindings to a git repository.\n   * @default - no publishing\n   * @stability experimental\n   */\n  readonly publishToGo?: cdk.JsiiGoTarget;\n  /**\n   * Version of the jsii compiler to use.\n   * Set to \"*\" if you want to manually manage the version of jsii in your\n   * project by managing updates to `package.json` on your own.\n   *\n   * NOTE: The jsii compiler releases since 5.0.0 are not semantically versioned\n   * and should remain on the same minor, so we recommend using a `~` dependency\n   * (e.g. `~5.0.0`).\n   * @default \"~5.8.0\"\n   * @stability experimental\n   * @pjnew \"~5.9.0\"\n   */\n  readonly jsiiVersion?: string;\n  /**\n   * Accepts a list of glob patterns.\n   * Files matching any of those patterns will be excluded from the TypeScript compiler input.\n   *\n   * By default, jsii will include all *.ts files (except .d.ts files) in the TypeScript compiler input.\n   * This can be problematic for example when the package's build or test procedure generates .ts files\n   * that cannot be compiled with jsii's compiler settings.\n   * @stability experimental\n   */\n  readonly excludeTypescript?: Array<string>;\n  /**\n   * File path for generated docs.\n   * @default \"API.md\"\n   * @stability experimental\n   */\n  readonly docgenFilePath?: string;\n  /**\n   * Emit a compressed version of the assembly.\n   * @default false\n   * @stability experimental\n   */\n  readonly compressAssembly?: boolean;\n  /**\n   * Name of the ignore file for API compatibility tests.\n   * @default \".compatignore\"\n   * @stability experimental\n   */\n  readonly compatIgnore?: string;\n  /**\n   * Automatically run API compatibility test against the latest version published to npm after compilation.\n   * - You can manually run compatibility tests using `yarn compat` if this feature is disabled.\n   * - You can ignore compatibility failures by adding lines to a \".compatignore\" file.\n   * @default false\n   * @stability experimental\n   */\n  readonly compat?: boolean;\n  /**\n   * Git repository URL.\n   * @default $GIT_REMOTE\n   * @stability experimental\n   */\n  readonly repositoryUrl: string;\n  /**\n   * Email or URL of the library author.\n   * @default $GIT_USER_EMAIL\n   * @stability experimental\n   */\n  readonly authorAddress: string;\n  /**\n   * The name of the library author.\n   * @default $GIT_USER_NAME\n   * @stability experimental\n   */\n  readonly author: string;\n  /**\n   * TypeScript version to use.\n   * NOTE: Typescript is not semantically versioned and should remain on the\n   * same minor, so we recommend using a `~` dependency (e.g. `~1.2.3`).\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly typescriptVersion?: string;\n  /**\n   * The name of the development tsconfig.json file.\n   * @default \"tsconfig.dev.json\"\n   * @stability experimental\n   */\n  readonly tsconfigDevFile?: string;\n  /**\n   * Custom tsconfig options for the development tsconfig.json file (used for testing).\n   * @default - use the production tsconfig options\n   * @stability experimental\n   */\n  readonly tsconfigDev?: javascript.TypescriptConfigOptions;\n  /**\n   * Custom TSConfig.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly tsconfig?: javascript.TypescriptConfigOptions;\n  /**\n   * Jest tests directory. Tests files should be named `xxx.test.ts`.\n   * If this directory is under `srcdir` (e.g. `src/test`, `src/__tests__`),\n   * then tests are going to be compiled into `lib/` and executed as javascript.\n   * If the test directory is outside of `src`, then we configure jest to\n   * compile the code in-memory.\n   * @default \"test\"\n   * @stability experimental\n   */\n  readonly testdir?: string;\n  /**\n   * Typescript sources directory.\n   * @default \"src\"\n   * @stability experimental\n   */\n  readonly srcdir?: string;\n  /**\n   * Options for .projenrc.ts.\n   * @stability experimental\n   */\n  readonly projenrcTsOptions?: typescript.ProjenrcOptions;\n  /**\n   * Use TypeScript for your projenrc file (`.projenrc.ts`).\n   * @default false\n   * @stability experimental\n   * @pjnew true\n   */\n  readonly projenrcTs?: boolean;\n  /**\n   * Typescript  artifacts output directory.\n   * @default \"lib\"\n   * @stability experimental\n   */\n  readonly libdir?: string;\n  /**\n   * The .d.ts file that includes the type declarations for this module.\n   * @default - .d.ts file derived from the project's entrypoint (usually lib/index.d.ts)\n   * @stability experimental\n   */\n  readonly entrypointTypes?: string;\n  /**\n   * Docs directory.\n   * @default \"docs\"\n   * @stability experimental\n   */\n  readonly docsDirectory?: string;\n  /**\n   * Docgen by Typedoc.\n   * @default false\n   * @stability experimental\n   */\n  readonly docgen?: boolean;\n  /**\n   * Do not generate a `tsconfig.dev.json` file.\n   * @default false\n   * @stability experimental\n   */\n  readonly disableTsconfigDev?: boolean;\n  /**\n   * Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler).\n   * @default false\n   * @stability experimental\n   */\n  readonly disableTsconfig?: boolean;\n  /**\n   * Enable Node.js package cache in GitHub workflows.\n   * @default false\n   * @stability experimental\n   */\n  readonly workflowPackageCache?: boolean;\n  /**\n   * The node version used in GitHub Actions workflows.\n   * Always use this option if your GitHub Actions workflows require a specific to run.\n   * @default - `minNodeVersion` if set, otherwise `lts/*`.\n   * @stability experimental\n   */\n  readonly workflowNodeVersion?: string;\n  /**\n   * The git identity to use in workflows.\n   * @default - default GitHub Actions user\n   * @stability experimental\n   */\n  readonly workflowGitIdentity?: github.GitIdentity;\n  /**\n   * Workflow steps to use in order to bootstrap this repo.\n   * @default \"yarn install --frozen-lockfile && yarn projen\"\n   * @stability experimental\n   */\n  readonly workflowBootstrapSteps?: Array<github.workflows.JobStep>;\n  /**\n   * Automatically release to npm when new versions are introduced.\n   * @default false\n   * @stability experimental\n   */\n  readonly releaseToNpm?: boolean;\n  /**\n   * Add release management to this project.\n   * @default - true (false for subprojects)\n   * @stability experimental\n   */\n  readonly release?: boolean;\n  /**\n   * The contents of the pull request template.\n   * @default - default content\n   * @stability experimental\n   */\n  readonly pullRequestTemplateContents?: Array<string>;\n  /**\n   * Include a GitHub pull request template.\n   * @default true\n   * @stability experimental\n   */\n  readonly pullRequestTemplate?: boolean;\n  /**\n   * Version of projen to install.\n   * @default - Defaults to the latest version.\n   * @stability experimental\n   */\n  readonly projenVersion?: string;\n  /**\n   * Options for .projenrc.js.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsOptions?: javascript.ProjenrcOptions;\n  /**\n   * Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation.\n   * @default - true if projenrcJson is false\n   * @stability experimental\n   */\n  readonly projenrcJs?: boolean;\n  /**\n   * Indicates of \"projen\" should be installed as a devDependency.\n   * @default - true if not a subproject\n   * @stability experimental\n   */\n  readonly projenDevDependency?: boolean;\n  /**\n   * Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).\n   * @default true\n   * @stability experimental\n   */\n  readonly package?: boolean;\n  /**\n   * Configuration options for .npmignore file.\n   * @stability experimental\n   */\n  readonly npmIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs.\n   * @default true\n   * @stability experimental\n   */\n  readonly npmignoreEnabled?: boolean;\n  /**\n   * Additional entries to .gitignore.\n   * @stability experimental\n   */\n  readonly gitignore?: Array<string>;\n  /**\n   * Options for `UpgradeDependencies`.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly depsUpgradeOptions?: javascript.UpgradeDependenciesOptions;\n  /**\n   * Use tasks and github workflows to handle dependency upgrades.\n   * Cannot be used in conjunction with `dependabot`.\n   * @default true\n   * @stability experimental\n   */\n  readonly depsUpgrade?: boolean;\n  /**\n   * Options for dependabot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly dependabotOptions?: github.DependabotOptions;\n  /**\n   * Use dependabot to handle dependency upgrades.\n   * Cannot be used in conjunction with `depsUpgrade`.\n   * @default false\n   * @stability experimental\n   */\n  readonly dependabot?: boolean;\n  /**\n   * The copyright years to put in the LICENSE file.\n   * @default - current year\n   * @stability experimental\n   */\n  readonly copyrightPeriod?: string;\n  /**\n   * License copyright owner.\n   * @default - defaults to the value of authorName or \"\" if `authorName` is undefined.\n   * @stability experimental\n   */\n  readonly copyrightOwner?: string;\n  /**\n   * Define the secret name for a specified https://codecov.io/ token.\n   * @default - OIDC auth is used\n   * @stability experimental\n   */\n  readonly codeCovTokenSecret?: string;\n  /**\n   * Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v5 By default, OIDC auth is used. Alternatively a token can be provided via `codeCovTokenSecret`.\n   * @default false\n   * @stability experimental\n   */\n  readonly codeCov?: boolean;\n  /**\n   * Configure which licenses should be deemed acceptable for use by dependencies.\n   * This setting will cause the build to fail, if any prohibited or not allowed licenses ares encountered.\n   * @default - no license checks are run during the build and all licenses will be accepted\n   * @stability experimental\n   */\n  readonly checkLicenses?: javascript.LicenseCheckerOptions;\n  /**\n   * Options for `Bundler`.\n   * @stability experimental\n   */\n  readonly bundlerOptions?: javascript.BundlerOptions;\n  /**\n   * Options for PR build workflow.\n   * @stability experimental\n   */\n  readonly buildWorkflowOptions?: javascript.BuildWorkflowOptions;\n  /**\n   * Define a GitHub workflow for building PRs.\n   * @default - true if not a subproject\n   * @stability experimental\n   */\n  readonly buildWorkflow?: boolean;\n  /**\n   * Biome options.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly biomeOptions?: javascript.BiomeOptions;\n  /**\n   * Setup Biome.\n   * @default false\n   * @stability experimental\n   */\n  readonly biome?: boolean;\n  /**\n   * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).\n   * Throw if set to true but `autoApproveOptions` are not defined.\n   * @default - true\n   * @stability experimental\n   */\n  readonly autoApproveUpgrades?: boolean;\n  /**\n   * Security audit options.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly auditDepsOptions?: javascript.AuditOptions;\n  /**\n   * Run security audit on dependencies.\n   * When enabled, creates an \"audit\" task that checks for known security vulnerabilities\n   * in dependencies. By default, runs during every build and checks for \"high\" severity\n   * vulnerabilities or above in all dependencies (including dev dependencies).\n   * @default false\n   * @stability experimental\n   */\n  readonly auditDeps?: boolean;\n  /**\n   * A directory which will contain build artifacts.\n   * @default \"dist\"\n   * @stability experimental\n   */\n  readonly artifactsDirectory?: string;\n  /**\n   * The name of the main release branch.\n   * @default \"main\"\n   * @stability experimental\n   */\n  readonly defaultReleaseBranch: string;\n  /**\n   * Github Runner Group selection options.\n   * @stability experimental\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOnGroup?: GroupRunnerOptions;\n  /**\n   * Github Runner selection labels.\n   * @default [\"ubuntu-latest\"]\n   * @stability experimental\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOn?: Array<string>;\n  /**\n   * Container image to use for GitHub workflows.\n   * @default - default image\n   * @stability experimental\n   */\n  readonly workflowContainerImage?: string;\n  /**\n   * Custom configuration used when creating changelog with commit-and-tag-version package.\n   * Given values either append to default configuration or overwrite values in it.\n   * @default - standard configuration applicable for GitHub repositories\n   * @stability experimental\n   */\n  readonly versionrcOptions?: Record<string, any>;\n  /**\n   * A set of workflow steps to execute in order to setup the workflow container.\n   * @stability experimental\n   */\n  readonly releaseWorkflowSetupSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The name of the default release workflow.\n   * @default \"release\"\n   * @stability experimental\n   */\n  readonly releaseWorkflowName?: string;\n  /**\n   * Build environment variables for release workflows.\n   * @default {}\n   * @stability experimental\n   */\n  readonly releaseWorkflowEnv?: Record<string, string>;\n  /**\n   * The release trigger to use.\n   * @default - Continuous releases (`ReleaseTrigger.continuous()`)\n   * @stability experimental\n   */\n  readonly releaseTrigger?: release.ReleaseTrigger;\n  /**\n   * Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.\n   * Note: this prefix is used to detect the latest tagged version\n   * when bumping, so if you change this on a project with an existing version\n   * history, you may need to manually tag your latest release\n   * with the new prefix.\n   * @default \"v\"\n   * @stability experimental\n   */\n  readonly releaseTagPrefix?: string;\n  /**\n   * The label to apply to issues indicating publish failures.\n   * Only applies if `releaseFailureIssue` is true.\n   * @default \"failed-release\"\n   * @stability experimental\n   */\n  readonly releaseFailureIssueLabel?: string;\n  /**\n   * Create a github issue on every failed publishing task.\n   * @default false\n   * @stability experimental\n   */\n  readonly releaseFailureIssue?: boolean;\n  /**\n   * The GitHub Actions environment used for the release.\n   * This can be used to add an explicit approval step to the release\n   * or limit who can initiate a release through environment protection rules.\n   *\n   * When multiple artifacts are released, the environment can be overwritten\n   * on a per artifact basis.\n   * @default - no environment used, unless set at the artifact level\n   * @stability experimental\n   */\n  readonly releaseEnvironment?: string;\n  /**\n   * Defines additional release branches.\n   * A workflow will be created for each\n   * release branch which will publish releases from commits in this branch.\n   * Each release branch _must_ be assigned a major version number which is used\n   * to enforce that versions published from that branch always use that major\n   * version. If multiple branches are used, the `majorVersion` field must also\n   * be provided for the default branch.\n   * @default - no additional branches are used for release. you can use\n`addBranch()` to add additional branches.\n   * @stability experimental\n   */\n  readonly releaseBranches?: Record<string, release.BranchOptions>;\n  /**\n   * Find commits that should be considered releasable Used to decide if a release is required.\n   * @default ReleasableCommits.everyCommit()\n   * @stability experimental\n   */\n  readonly releasableCommits?: ReleasableCommits;\n  /**\n   * Define publishing tasks that can be executed manually as well as workflows.\n   * Normally, publishing only happens within automated workflows. Enable this\n   * in order to create a publishing task for each publishing activity.\n   * @default false\n   * @stability experimental\n   */\n  readonly publishTasks?: boolean;\n  /**\n   * Instead of actually publishing to package managers, just print the publishing command.\n   * @default false\n   * @stability experimental\n   */\n  readonly publishDryRun?: boolean;\n  /**\n   * Bump versions from the default branch as pre-releases (e.g. \"beta\", \"alpha\", \"pre\").\n   * @default - normal semantic versions\n   * @stability experimental\n   */\n  readonly prerelease?: string;\n  /**\n   * Steps to execute after build as part of the release workflow.\n   * @default []\n   * @stability experimental\n   */\n  readonly postBuildSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The npmDistTag to use when publishing from the default branch.\n   * To set the npm dist-tag for release branches, set the `npmDistTag` property\n   * for each branch.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly npmDistTag?: string;\n  /**\n   * A shell command to control the next version to release.\n   * If present, this shell command will be run before the bump is executed, and\n   * it determines what version to release. It will be executed in the following\n   * environment:\n   *\n   * - Working directory: the project directory.\n   * - `$VERSION`: the current version. Looks like `1.2.3`.\n   * - `$LATEST_TAG`: the most recent tag. Looks like `prefix-v1.2.3`, or may be unset.\n   * - `$SUGGESTED_BUMP`: the suggested bump action based on commits. One of `major|minor|patch|none`.\n   *\n   * The command should print one of the following to `stdout`:\n   *\n   * - Nothing: the next version number will be determined based on commit history.\n   * - `x.y.z`: the next version number will be `x.y.z`.\n   * - `major|minor|patch`: the next version number will be the current version number\n   *   with the indicated component bumped.\n   *\n   * This setting cannot be specified together with `minMajorVersion`; the invoked\n   * script can be used to achieve the effects of `minMajorVersion`.\n   * @default - The next version will be determined based on the commit history and project settings.\n   * @stability experimental\n   */\n  readonly nextVersionCommand?: string;\n  /**\n   * Minimal Major version to release.\n   * This can be useful to set to 1, as breaking changes before the 1.x major\n   * release are not incrementing the major version number.\n   *\n   * Can not be set together with `majorVersion`.\n   * @default - No minimum version is being enforced\n   * @stability experimental\n   */\n  readonly minMajorVersion?: number;\n  /**\n   * Major version to release from the default branch.\n   * If this is specified, we bump the latest version of this major version line.\n   * If not specified, we bump the global latest version.\n   * @default - Major version is not enforced.\n   * @stability experimental\n   */\n  readonly majorVersion?: number;\n  /**\n   * Version requirement of `publib` which is used to publish modules to npm.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly jsiiReleaseVersion?: string;\n  /**\n   * The `commit-and-tag-version` compatible package used to bump the package version, as a dependency string.\n   * This can be any compatible package version, including the deprecated `standard-version@9`.\n   * @default - A recent version of \"commit-and-tag-version\"\n   * @stability experimental\n   */\n  readonly bumpPackage?: string;\n  /**\n   * Options for Yarn Berry.\n   * @default - Yarn Berry v4 with all default options\n   * @stability experimental\n   */\n  readonly yarnBerryOptions?: javascript.YarnBerryOptions;\n  /**\n   * Package's Stability.\n   * @stability experimental\n   */\n  readonly stability?: string;\n  /**\n   * Options for privately hosted scoped packages.\n   * @default - fetch all scoped packages from the public npm registry\n   * @stability experimental\n   */\n  readonly scopedPackagesOptions?: Array<javascript.ScopedPackagesOptions>;\n  /**\n   * If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives.\n   * @stability experimental\n   */\n  readonly repositoryDirectory?: string;\n  /**\n   * The repository is the location where the actual code for your package lives.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-repository\n   * @stability experimental\n   */\n  readonly repository?: string;\n  /**\n   * The version of PNPM to use if using PNPM as a package manager.\n   * @default \"9\"\n   * @stability experimental\n   */\n  readonly pnpmVersion?: string;\n  /**\n   * Peer dependencies for this module.\n   * Dependencies listed here are required to\n   * be installed (and satisfied) by the _consumer_ of this library. Using peer\n   * dependencies allows you to ensure that only a single module of a certain\n   * library exists in the `node_modules` tree of your consumers.\n   *\n   * Note that prior to npm@7, peer dependencies are _not_ automatically\n   * installed, which means that adding peer dependencies to a library will be a\n   * breaking change for your customers.\n   *\n   * Unless `peerDependencyOptions.pinnedDevDependency` is disabled (it is\n   * enabled by default), projen will automatically add a dev dependency with a\n   * pinned version for each peer dependency. This will ensure that you build &\n   * test your module against the lowest peer version required.\n   * @default []\n   * @stability experimental\n   */\n  readonly peerDeps?: Array<string>;\n  /**\n   * Options for `peerDeps`.\n   * @stability experimental\n   */\n  readonly peerDependencyOptions?: javascript.PeerDependencyOptions;\n  /**\n   * The \"name\" in package.json.\n   * @default - defaults to project name\n   * @stability experimental\n   * @featured true\n   */\n  readonly packageName?: string;\n  /**\n   * The Node Package Manager used to execute scripts.\n   * @default NodePackageManager.YARN_CLASSIC\n   * @stability experimental\n   */\n  readonly packageManager?: javascript.NodePackageManager;\n  /**\n   * Use trusted publishing for publishing to npmjs.com Needs to be pre-configured on npm.js to work.\n   * @default - false\n   * @stability experimental\n   */\n  readonly npmTrustedPublishing?: boolean;\n  /**\n   * GitHub secret which contains the NPM token to use when publishing packages.\n   * @default \"NPM_TOKEN\"\n   * @stability experimental\n   */\n  readonly npmTokenSecret?: string;\n  /**\n   * The base URL of the npm package registry.\n   * Must be a URL (e.g. start with \"https://\" or \"http://\")\n   * @default \"https://registry.npmjs.org\"\n   * @stability experimental\n   */\n  readonly npmRegistryUrl?: string;\n  /**\n   * Should provenance statements be generated when the package is published.\n   * A supported package manager is required to publish a package with npm provenance statements and\n   * you will need to use a supported CI/CD provider.\n   *\n   * Note that the projen `Release` and `Publisher` components are using `publib` to publish packages,\n   * which is using npm internally and supports provenance statements independently of the package manager used.\n   * @default - true for public packages, false otherwise\n   * @stability experimental\n   */\n  readonly npmProvenance?: boolean;\n  /**\n   * Access level of the npm package.\n   * @default - for scoped packages (e.g. `foo@bar`), the default is\n`NpmAccess.RESTRICTED`, for non-scoped packages, the default is\n`NpmAccess.PUBLIC`.\n   * @stability experimental\n   */\n  readonly npmAccess?: javascript.NpmAccess;\n  /**\n   * The minimum node version required by this package to function. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any older versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option, even if your package is incompatible with EOL versions of node.\n   * Consider this option only if your package depends on a specific feature, that is not available in other LTS versions.\n   * Setting this option has very high impact on the consumers of your package,\n   * as package managers will actively prevent usage with node versions you have marked as incompatible.\n   *\n   * To change the node version of your CI/CD workflows, use `workflowNodeVersion`.\n   * @default - no minimum version is enforced\n   * @stability experimental\n   */\n  readonly minNodeVersion?: string;\n  /**\n   * The maximum node version supported by this package. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any newer versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option.\n   * Consider this option only if your package is known to not function with newer versions of node.\n   * @default - no maximum version is enforced\n   * @stability experimental\n   */\n  readonly maxNodeVersion?: string;\n  /**\n   * Indicates if a license should be added.\n   * @default true\n   * @stability experimental\n   */\n  readonly licensed?: boolean;\n  /**\n   * License's SPDX identifier.\n   * See https://github.com/projen/projen/tree/main/license-text for a list of supported licenses.\n   * Use the `licensed` option if you want to no license to be specified.\n   * @default \"Apache-2.0\"\n   * @stability experimental\n   */\n  readonly license?: string;\n  /**\n   * Keywords to include in `package.json`.\n   * @stability experimental\n   */\n  readonly keywords?: Array<string>;\n  /**\n   * Package's Homepage / Website.\n   * @stability experimental\n   */\n  readonly homepage?: string;\n  /**\n   * Module entrypoint (`main` in `package.json`).\n   * Set to an empty string to not include `main` in your package.json\n   * @default \"lib/index.js\"\n   * @stability experimental\n   */\n  readonly entrypoint?: string;\n  /**\n   * Build dependencies for this module.\n   * These dependencies will only be\n   * available in your build environment but will not be fetched when this\n   * module is consumed.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly devDeps?: Array<string>;\n  /**\n   * The description is just a string that helps people understand the purpose of the package.\n   * It can be used when searching for packages in a package manager as well.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-description\n   * @stability experimental\n   * @featured true\n   */\n  readonly description?: string;\n  /**\n   * Runtime dependencies of this module.\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly deps?: Array<string>;\n  /**\n   * Options for npm packages using AWS CodeArtifact.\n   * This is required if publishing packages to, or installing scoped packages from AWS CodeArtifact\n   * @default - undefined\n   * @stability experimental\n   */\n  readonly codeArtifactOptions?: javascript.CodeArtifactOptions;\n  /**\n   * The version of Bun to use if using Bun as a package manager.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly bunVersion?: string;\n  /**\n   * List of dependencies to bundle into this module.\n   * These modules will be\n   * added both to the `dependencies` section and `bundledDependencies` section of\n   * your `package.json`.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @stability experimental\n   */\n  readonly bundledDeps?: Array<string>;\n  /**\n   * The url to your project's issue tracker.\n   * @stability experimental\n   */\n  readonly bugsUrl?: string;\n  /**\n   * The email address to which issues should be reported.\n   * @stability experimental\n   */\n  readonly bugsEmail?: string;\n  /**\n   * Binary programs vended with your module.\n   * You can use this option to add/customize how binaries are represented in\n   * your `package.json`, but unless `autoDetectBin` is `false`, every\n   * executable file under `bin` will automatically be added to this section.\n   * @stability experimental\n   */\n  readonly bin?: Record<string, string>;\n  /**\n   * Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoDetectBin?: boolean;\n  /**\n   * Author's URL / Website.\n   * @stability experimental\n   */\n  readonly authorUrl?: string;\n  /**\n   * Is the author an organization.\n   * @stability experimental\n   */\n  readonly authorOrganization?: boolean;\n  /**\n   * Author's name.\n   * @stability experimental\n   */\n  readonly authorName?: string;\n  /**\n   * Author's e-mail.\n   * @stability experimental\n   */\n  readonly authorEmail?: string;\n  /**\n   * Allow the project to include `peerDependencies` and `bundledDependencies`.\n   * This is normally only allowed for libraries. For apps, there's no meaning\n   * for specifying these.\n   * @default true\n   * @stability experimental\n   */\n  readonly allowLibraryDependencies?: boolean;\n  /**\n   * Enable VSCode integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly vscode?: boolean;\n  /**\n   * Auto-close stale issues and pull requests.\n   * To disable set `stale` to `false`.\n   * @default - see defaults in `StaleOptions`\n   * @stability experimental\n   */\n  readonly staleOptions?: github.StaleOptions;\n  /**\n   * Auto-close of stale issues and pull request.\n   * See `staleOptions` for options.\n   * @default false\n   * @stability experimental\n   */\n  readonly stale?: boolean;\n  /**\n   * The README setup.\n   * @default - { filename: 'README.md', contents: '# replace this' }\n   * @stability experimental\n   */\n  readonly readme?: SampleReadmeProps;\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   * @stability experimental\n   */\n  readonly projenCredentials?: github.GithubCredentials;\n  /**\n   * Add a Gitpod development environment.\n   * @default false\n   * @stability experimental\n   */\n  readonly gitpod?: boolean;\n  /**\n   * Options for GitHub integration.\n   * @default - see GitHubOptions\n   * @stability experimental\n   */\n  readonly githubOptions?: github.GitHubOptions;\n  /**\n   * Enable GitHub integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly github?: boolean;\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces).\n   * @default false\n   * @stability experimental\n   */\n  readonly devContainer?: boolean;\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   * @stability experimental\n   */\n  readonly clobber?: boolean;\n  /**\n   * Configure options for automatic merging on GitHub.\n   * Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   * @default - see defaults in `AutoMergeOptions`\n   * @stability experimental\n   */\n  readonly autoMergeOptions?: github.AutoMergeOptions;\n  /**\n   * Enable automatic merging on GitHub.\n   * Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoMerge?: boolean;\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   * @stability experimental\n   */\n  readonly autoApproveOptions?: github.AutoApproveOptions;\n  /**\n   * Options for renovatebot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly renovatebotOptions?: RenovatebotOptions;\n  /**\n   * Use renovatebot to handle dependency upgrades.\n   * @default false\n   * @stability experimental\n   */\n  readonly renovatebot?: boolean;\n  /**\n   * Options for .projenrc.json.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsonOptions?: ProjenrcJsonOptions;\n  /**\n   * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.\n   * @default false\n   * @stability experimental\n   */\n  readonly projenrcJson?: boolean;\n  /**\n   * The shell command to use in order to run the projen CLI.\n   * Can be used to customize in special environments.\n   * @default \"npx projen\"\n   * @stability experimental\n   */\n  readonly projenCommand?: string;\n  /**\n   * The parent project, if this project is part of a bigger project.\n   * @stability experimental\n   */\n  readonly parent?: Project;\n  /**\n   * The root directory of the project.\n   * Relative to this directory, all files are synthesized.\n   *\n   * If this project has a parent, this directory is relative to the parent\n   * directory and it cannot be the same as the parent or any of it's other\n   * subprojects.\n   * @default \".\"\n   * @stability experimental\n   */\n  readonly outdir?: string;\n  /**\n   * Configure logging options such as verbosity.\n   * @default {}\n   * @stability experimental\n   */\n  readonly logging?: LoggerOptions;\n  /**\n   * Configuration options for git.\n   * @stability experimental\n   */\n  readonly gitOptions?: GitOptions;\n  /**\n   * Configuration options for .gitignore file.\n   * @stability experimental\n   */\n  readonly gitIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Whether to commit the managed files by default.\n   * @default true\n   * @stability experimental\n   */\n  readonly commitGenerated?: boolean;\n  /**\n   * This is the name of your project.\n   * @default $BASEDIR\n   * @stability experimental\n   * @featured true\n   */\n  readonly name: string;\n  /**\n   * Enable Mise component\n   * @default true\n   */\n  readonly mise?: boolean;\n  /**\n   * Enable Vitest component\n   * @default true\n   */\n  readonly vitest?: boolean;\n  /**\n   * Vitest configuration\n   * @default - default Vitest configuration\n   */\n  readonly vitestOptions?: VitestOptions;\n}\n"]}
@@ -1,6 +1,14 @@
1
1
  import { awscdk } from "projen";
2
2
  import type { AwsCdkConstructLibraryProjectOptions } from "./awscdk-construct-library-options.generated";
3
3
  export { AwsCdkConstructLibraryProjectOptions } from "./awscdk-construct-library-options.generated";
4
+ /**
5
+ * AwsCdkConstructLibraryProject with standard configuration and component integration
6
+ *
7
+ * Extends Projen's base class with opinionated defaults and automatic component setup.
8
+ */
4
9
  export declare class AwsCdkConstructLibraryProject extends awscdk.AwsCdkConstructLibrary {
10
+ /**
11
+ * @param options - Project configuration
12
+ */
5
13
  constructor(options: AwsCdkConstructLibraryProjectOptions);
6
14
  }