aws-cdk 2.1033.0 → 2.1034.0

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.
Files changed (37) hide show
  1. package/THIRD_PARTY_LICENSES +515 -130
  2. package/build-info.json +2 -2
  3. package/db.json.gz +0 -0
  4. package/lib/api/bootstrap/bootstrap-template.yaml +3 -2
  5. package/lib/cli/cdk-toolkit.d.ts +1 -1
  6. package/lib/cli/cdk-toolkit.js +4 -9
  7. package/lib/cli/cli-config.js +3 -1
  8. package/lib/cli/cli-type-registry.json +10 -0
  9. package/lib/cli/cli.js +3 -2
  10. package/lib/cli/convert-to-user-input.js +3 -1
  11. package/lib/cli/io-host/cli-io-host.d.ts +1 -1
  12. package/lib/cli/io-host/cli-io-host.js +35 -17
  13. package/lib/cli/parse-command-line-arguments.js +14 -2
  14. package/lib/cli/telemetry/collect-telemetry.js +3 -2
  15. package/lib/cli/telemetry/sink/endpoint-sink.js +8 -5
  16. package/lib/cli/user-input.d.ts +6 -0
  17. package/lib/cli/user-input.js +1 -1
  18. package/lib/commands/flags/flags.js +2 -2
  19. package/lib/commands/flags/operations.d.ts +21 -2
  20. package/lib/commands/flags/operations.js +57 -13
  21. package/lib/commands/init/init.d.ts +6 -0
  22. package/lib/commands/init/init.js +20 -11
  23. package/lib/commands/init/package-manager.d.ts +2 -0
  24. package/lib/commands/init/package-manager.js +5 -0
  25. package/lib/index.js +139816 -202487
  26. package/lib/init-templates/.init-version.json +1 -1
  27. package/lib/init-templates/.recommended-feature-flags.json +3 -1
  28. package/lib/init-templates/app/javascript/jest.config.js +2 -1
  29. package/lib/init-templates/app/typescript/jest.config.js +2 -1
  30. package/lib/init-templates/lib/typescript/jest.config.js +2 -1
  31. package/lib/init-templates/sample-app/javascript/jest.config.js +2 -1
  32. package/lib/init-templates/sample-app/typescript/jest.config.js +2 -1
  33. package/package.json +21 -21
  34. package/lib/commands/flag-operations.d.ts +0 -23
  35. package/lib/commands/flag-operations.js +0 -416
  36. /package/lib/{obsolete-flags.d.ts → commands/flags/obsolete-flags.d.ts} +0 -0
  37. /package/lib/{obsolete-flags.js → commands/flags/obsolete-flags.js} +0 -0
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.FlagOperations = void 0;
4
+ exports.isEffectiveValueEqualToRecommended = isEffectiveValueEqualToRecommended;
4
5
  const os = require("os");
5
6
  const path = require("path");
6
7
  const cloudformation_diff_1 = require("@aws-cdk/cloudformation-diff");
@@ -8,8 +9,33 @@ const toolkit_lib_1 = require("@aws-cdk/toolkit-lib");
8
9
  const chalk = require("chalk");
9
10
  const fs = require("fs-extra");
10
11
  const p_queue_1 = require("p-queue");
12
+ const obsolete_flags_1 = require("./obsolete-flags");
11
13
  const api_1 = require("../../api");
12
14
  class FlagOperations {
15
+ /**
16
+ * Returns only those feature flags that need configuration
17
+ *
18
+ * That is those flags:
19
+ * - That are unconfigured
20
+ * - That are not obsolete
21
+ * - Whose default value is different from the recommended value
22
+ *
23
+ * The default value being equal to the recommended value sounds odd, but
24
+ * crops up in a number of situtations:
25
+ *
26
+ * - Security-related fixes that we want to force on people, but want to
27
+ * give them a flag to back out of the changes if they really need to.
28
+ * - Flags that changed their default value in the most recent major
29
+ * version.
30
+ * - Flags that we've introduced at some point in the past, but have gone
31
+ * back on.
32
+ */
33
+ static filterNeedsAttention(flags) {
34
+ return flags
35
+ .filter(flag => !obsolete_flags_1.OBSOLETE_FLAGS.includes(flag.name))
36
+ .filter(flag => flag.userValue === undefined)
37
+ .filter(flag => defaultValue(flag) !== flag.recommendedValue);
38
+ }
13
39
  constructor(flags, toolkit, ioHelper) {
14
40
  this.flags = flags;
15
41
  this.toolkit = toolkit;
@@ -71,7 +97,7 @@ class FlagOperations {
71
97
  }
72
98
  else if (params.all) {
73
99
  return this.flags
74
- .filter(flag => flag.userValue === undefined || !this.isUserValueEqualToRecommended(flag))
100
+ .filter(flag => flag.userValue === undefined || !isEffectiveValueEqualToRecommended(flag))
75
101
  .filter(flag => this.isBooleanFlag(flag))
76
102
  .map(flag => flag.name);
77
103
  }
@@ -269,7 +295,7 @@ class FlagOperations {
269
295
  }
270
296
  const newValue = params.recommended
271
297
  ? flag.recommendedValue
272
- : String(flag.unconfiguredBehavesLike?.v2) === 'true';
298
+ : String(defaultValue(flag)) === 'true';
273
299
  updateObj[flagName] = newValue;
274
300
  }
275
301
  }
@@ -319,7 +345,7 @@ class FlagOperations {
319
345
  const flag = this.flags.find(f => f.name === flagName);
320
346
  const newValue = params.recommended || params.safe
321
347
  ? flag.recommendedValue
322
- : String(flag.unconfiguredBehavesLike?.v2) === 'true';
348
+ : String(defaultValue(flag)) === 'true';
323
349
  cdkJson.context[flagName] = newValue;
324
350
  }
325
351
  }
@@ -332,7 +358,10 @@ class FlagOperations {
332
358
  await this.displaySpecificFlags(FLAGNAME);
333
359
  return;
334
360
  }
335
- const flagsToDisplay = all ? this.flags : this.flags.filter(flag => flag.userValue === undefined || !this.isUserValueEqualToRecommended(flag));
361
+ const [flagsToDisplay, header] = all
362
+ ? [this.flags, 'All feature flags']
363
+ : [FlagOperations.filterNeedsAttention(this.flags), 'Unconfigured feature flags'];
364
+ await this.ioHelper.defaults.info(header);
336
365
  await this.displayFlagTable(flagsToDisplay);
337
366
  // Add helpful message after empty table when not using --all
338
367
  if (!all && flagsToDisplay.length === 0) {
@@ -353,17 +382,19 @@ class FlagOperations {
353
382
  await this.ioHelper.defaults.info(`Flag name: ${flag.name}`);
354
383
  await this.ioHelper.defaults.info(`Description: ${flag.explanation}`);
355
384
  await this.ioHelper.defaults.info(`Recommended value: ${flag.recommendedValue}`);
385
+ await this.ioHelper.defaults.info(`Default value: ${defaultValue(flag)}`);
356
386
  await this.ioHelper.defaults.info(`User value: ${flag.userValue}`);
387
+ await this.ioHelper.defaults.info(`Effective value: ${effectiveValue(flag)}`);
357
388
  return;
358
389
  }
359
- await this.ioHelper.defaults.info(`Found ${matchingFlags.length} flags matching "${flagNames.join(', ')}":`);
390
+ await this.ioHelper.defaults.info(`Found ${matchingFlags.length} flags matching "${flagNames.join(', ')}"`);
360
391
  await this.displayFlagTable(matchingFlags);
361
392
  }
362
393
  /** Returns sort order for flags */
363
394
  getFlagSortOrder(flag) {
364
395
  if (flag.userValue === undefined)
365
396
  return 3;
366
- if (this.isUserValueEqualToRecommended(flag))
397
+ if (isEffectiveValueEqualToRecommended(flag))
367
398
  return 1;
368
399
  return 2;
369
400
  }
@@ -378,17 +409,18 @@ class FlagOperations {
378
409
  return a.module.localeCompare(b.module);
379
410
  return a.name.localeCompare(b.name);
380
411
  });
381
- const rows = [['Feature Flag Name', 'Recommended Value', 'User Value']];
412
+ const rows = [['Feature Flag', 'Recommended', 'User', 'Effective']];
382
413
  let currentModule = '';
383
414
  sortedFlags.forEach((flag) => {
384
415
  if (flag.module !== currentModule) {
385
- rows.push([chalk.bold(`Module: ${flag.module}`), '', '']);
416
+ rows.push([chalk.bold(`Module: ${flag.module}`), '', '', '']);
386
417
  currentModule = flag.module;
387
418
  }
388
419
  rows.push([
389
420
  ` ${flag.name}`,
390
421
  String(flag.recommendedValue),
391
422
  flag.userValue === undefined ? '<unset>' : String(flag.userValue),
423
+ String(effectiveValue(flag)),
392
424
  ]);
393
425
  });
394
426
  const formattedTable = (0, cloudformation_diff_1.formatTable)(rows, undefined, true);
@@ -401,10 +433,6 @@ class FlagOperations {
401
433
  recommended === 'true' ||
402
434
  recommended === 'false';
403
435
  }
404
- /** Checks if the user's current value matches the recommended value */
405
- isUserValueEqualToRecommended(flag) {
406
- return String(flag.userValue) === String(flag.recommendedValue);
407
- }
408
436
  /** Shows helpful usage examples and available command options */
409
437
  async displayHelpMessage() {
410
438
  await this.ioHelper.defaults.info('\n' + chalk.bold('Available options:'));
@@ -418,4 +446,20 @@ class FlagOperations {
418
446
  }
419
447
  }
420
448
  exports.FlagOperations = FlagOperations;
421
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"operations.js","sourceRoot":"","sources":["operations.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport { formatTable } from '@aws-cdk/cloudformation-diff';\nimport type { CloudFormationStackArtifact } from '@aws-cdk/cx-api';\nimport type { FeatureFlag, Toolkit } from '@aws-cdk/toolkit-lib';\nimport { CdkAppMultiContext, MemoryContext, DiffMethod } from '@aws-cdk/toolkit-lib';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport PQueue from 'p-queue';\nimport type { FlagOperationsParams } from './types';\nimport { StackSelectionStrategy } from '../../api';\nimport type { IoHelper } from '../../api-private';\n\nexport class FlagOperations {\n  private app: string;\n  private baseContextValues: Record<string, any>;\n  private allStacks: CloudFormationStackArtifact[];\n  private queue: PQueue;\n  private baselineTempDir?: string;\n\n  constructor(\n    private readonly flags: FeatureFlag[],\n    private readonly toolkit: Toolkit,\n    private readonly ioHelper: IoHelper,\n  ) {\n    this.app = '';\n    this.baseContextValues = {};\n    this.allStacks = [];\n    this.queue = new PQueue({ concurrency: 4 });\n  }\n\n  /** Main entry point that routes to either flag setting or display operations */\n  async execute(params: FlagOperationsParams): Promise<void> {\n    if (params.set) {\n      if (params.FLAGNAME && params.value) {\n        await this.setFlag(params);\n      } else {\n        await this.setMultipleFlags(params);\n      }\n    } else {\n      await this.displayFlags(params);\n    }\n  }\n\n  /** Sets a single specific flag with validation and user confirmation */\n  async setFlag(params: FlagOperationsParams): Promise<void> {\n    const flagName = params.FLAGNAME![0];\n    const flag = this.flags.find(f => f.name === flagName);\n\n    if (!flag) {\n      await this.ioHelper.defaults.error('Flag not found.');\n      return;\n    }\n\n    if (!this.isBooleanFlag(flag)) {\n      await this.ioHelper.defaults.error(`Flag '${flagName}' is not a boolean flag. Only boolean flags are currently supported.`);\n      return;\n    }\n\n    const prototypeSuccess = await this.prototypeChanges([flagName], params);\n    if (prototypeSuccess) {\n      await this.handleUserResponse([flagName], params);\n    }\n  }\n\n  /** Sets multiple flags (all or unconfigured) with validation and user confirmation */\n  async setMultipleFlags(params: FlagOperationsParams): Promise<void> {\n    if (params.default && !this.flags.some(f => f.unconfiguredBehavesLike)) {\n      await this.ioHelper.defaults.error('The --default options are not compatible with the AWS CDK library used by your application. Please upgrade to 2.212.0 or above.');\n      return;\n    }\n\n    const flagsToSet = this.getFlagsToSet(params);\n    const prototypeSuccess = await this.prototypeChanges(flagsToSet, params);\n\n    if (prototypeSuccess) {\n      await this.handleUserResponse(flagsToSet, params);\n    }\n  }\n\n  /** Determines which flags should be set based on the provided parameters */\n  private getFlagsToSet(params: FlagOperationsParams): string[] {\n    if (params.all && params.default) {\n      return this.flags\n        .filter(flag => this.isBooleanFlag(flag))\n        .map(flag => flag.name);\n    } else if (params.all) {\n      return this.flags\n        .filter(flag => flag.userValue === undefined || !this.isUserValueEqualToRecommended(flag))\n        .filter(flag => this.isBooleanFlag(flag))\n        .map(flag => flag.name);\n    } else {\n      return this.flags\n        .filter(flag => flag.userValue === undefined)\n        .filter(flag => this.isBooleanFlag(flag))\n        .map(flag => flag.name);\n    }\n  }\n\n  /** Sets flags that don't cause template changes */\n  async setSafeFlags(params: FlagOperationsParams): Promise<void> {\n    const cdkJson = await JSON.parse(await fs.readFile(path.join(process.cwd(), 'cdk.json'), 'utf-8'));\n    this.app = params.app || cdkJson.app;\n\n    const isUsingTsNode = this.app.includes('ts-node');\n    if (isUsingTsNode && !this.app.includes('-T') && !this.app.includes('--transpileOnly')) {\n      await this.ioHelper.defaults.info('Repeated synths with ts-node will type-check the application on every synth. Add --transpileOnly to cdk.json\\'s \"app\" command to make this operation faster.');\n    }\n\n    const unconfiguredFlags = this.flags.filter(flag =>\n      flag.userValue === undefined && this.isBooleanFlag(flag));\n\n    if (unconfiguredFlags.length === 0) {\n      await this.ioHelper.defaults.info('All feature flags are configured.');\n      return;\n    }\n\n    await this.initializeSafetyCheck();\n    const safeFlags = await this.batchTestFlags(unconfiguredFlags);\n    await this.cleanupSafetyCheck();\n\n    if (safeFlags.length > 0) {\n      await this.ioHelper.defaults.info('Flags that can be set without template changes:');\n      for (const flag of safeFlags) {\n        await this.ioHelper.defaults.info(`- ${flag.name} -> ${flag.recommendedValue}`);\n      }\n      await this.handleUserResponse(safeFlags.map(flag => flag.name), { ...params, recommended: true });\n    } else {\n      await this.ioHelper.defaults.info('No more flags can be set without causing template changes.');\n    }\n  }\n\n  /** Initializes the safety check by reading context and synthesizing baseline templates */\n  private async initializeSafetyCheck(): Promise<void> {\n    const baseContext = new CdkAppMultiContext(process.cwd());\n    this.baseContextValues = await baseContext.read();\n\n    this.baselineTempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-baseline-'));\n    const baseSource = await this.toolkit.fromCdkApp(this.app, {\n      contextStore: baseContext,\n      outdir: this.baselineTempDir,\n    });\n\n    const baseCx = await this.toolkit.synth(baseSource);\n    const baseAssembly = baseCx.cloudAssembly;\n    this.allStacks = baseAssembly.stacksRecursively;\n    this.queue = new PQueue({ concurrency: 4 });\n  }\n\n  /** Cleans up temporary directories created during safety checks */\n  private async cleanupSafetyCheck(): Promise<void> {\n    if (this.baselineTempDir) {\n      await fs.remove(this.baselineTempDir);\n      this.baselineTempDir = undefined;\n    }\n  }\n\n  /** Tests multiple flags together and isolates unsafe ones using binary search */\n  private async batchTestFlags(flags: FeatureFlag[]): Promise<FeatureFlag[]> {\n    if (flags.length === 0) return [];\n\n    const allFlagsContext = { ...this.baseContextValues };\n    flags.forEach(flag => {\n      allFlagsContext[flag.name] = flag.recommendedValue;\n    });\n\n    const allSafe = await this.testBatch(allFlagsContext);\n    if (allSafe) return flags;\n\n    return this.isolateUnsafeFlags(flags);\n  }\n\n  /** Tests if a set of context values causes template changes by synthesizing and diffing */\n  private async testBatch(contextValues: Record<string, any>): Promise<boolean> {\n    const testContext = new MemoryContext(contextValues);\n    const tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-test-'));\n    const testSource = await this.toolkit.fromCdkApp(this.app, {\n      contextStore: testContext,\n      outdir: tempDir,\n    });\n\n    const testCx = await this.toolkit.synth(testSource);\n\n    try {\n      for (const stack of this.allStacks) {\n        const templatePath = stack.templateFullPath;\n        const diff = await this.toolkit.diff(testCx, {\n          method: DiffMethod.LocalFile(templatePath),\n          stacks: {\n            strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE,\n            patterns: [stack.hierarchicalId],\n          },\n        });\n\n        for (const stackDiff of Object.values(diff)) {\n          if (stackDiff.differenceCount > 0) {\n            return false;\n          }\n        }\n      }\n      return true;\n    } finally {\n      await fs.remove(tempDir);\n    }\n  }\n\n  /** Uses binary search to isolate which flags are safe to set without template changes */\n  private async isolateUnsafeFlags(flags: FeatureFlag[]): Promise<FeatureFlag[]> {\n    const safeFlags: FeatureFlag[] = [];\n\n    const processBatch = async (batch: FeatureFlag[], contextValues: Record<string, any>): Promise<void> => {\n      if (batch.length === 1) {\n        const isSafe = await this.testBatch(\n          { ...contextValues, [batch[0].name]: batch[0].recommendedValue },\n        );\n        if (isSafe) safeFlags.push(batch[0]);\n        return;\n      }\n\n      const batchContext = { ...contextValues };\n      batch.forEach(flag => {\n        batchContext[flag.name] = flag.recommendedValue;\n      });\n\n      const isSafeBatch = await this.testBatch(batchContext);\n      if (isSafeBatch) {\n        safeFlags.push(...batch);\n        return;\n      }\n\n      const mid = Math.floor(batch.length / 2);\n      const left = batch.slice(0, mid);\n      const right = batch.slice(mid);\n\n      void this.queue.add(() => processBatch(left, contextValues));\n      void this.queue.add(() => processBatch(right, contextValues));\n    };\n\n    void this.queue.add(() => processBatch(flags, this.baseContextValues));\n    await this.queue.onIdle();\n    return safeFlags;\n  }\n\n  /** Prototypes flag changes by synthesizing templates and showing diffs to the user */\n  private async prototypeChanges(flagNames: string[], params: FlagOperationsParams): Promise<boolean> {\n    const baseContext = new CdkAppMultiContext(process.cwd());\n    const baseContextValues = await baseContext.read();\n    const memoryContext = new MemoryContext(baseContextValues);\n\n    const cdkJson = await JSON.parse(await fs.readFile(path.join(process.cwd(), 'cdk.json'), 'utf-8'));\n    const app = cdkJson.app;\n\n    const source = await this.toolkit.fromCdkApp(app, {\n      contextStore: baseContext,\n      outdir: fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-original-')),\n    });\n\n    const updateObj = await this.buildUpdateObject(flagNames, params, baseContextValues);\n    if (!updateObj) return false;\n\n    await memoryContext.update(updateObj);\n    const cx = await this.toolkit.synth(source);\n    const assembly = cx.cloudAssembly;\n\n    const modifiedSource = await this.toolkit.fromCdkApp(app, {\n      contextStore: memoryContext,\n      outdir: fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-temp-')),\n    });\n\n    const modifiedCx = await this.toolkit.synth(modifiedSource);\n    const allStacks = assembly.stacksRecursively;\n\n    for (const stack of allStacks) {\n      const templatePath = stack.templateFullPath;\n      await this.toolkit.diff(modifiedCx, {\n        method: DiffMethod.LocalFile(templatePath),\n        stacks: {\n          strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE,\n          patterns: [stack.hierarchicalId],\n        },\n      });\n    }\n\n    await this.displayFlagChanges(updateObj, baseContextValues);\n    return true;\n  }\n\n  /** Displays a summary of flag changes showing old and new values */\n  private async displayFlagChanges(updateObj: Record<string, boolean>, baseContextValues: Record<string, any>): Promise<void> {\n    await this.ioHelper.defaults.info('\\nFlag changes:');\n    for (const [flagName, newValue] of Object.entries(updateObj)) {\n      const currentValue = baseContextValues[flagName];\n      const currentDisplay = currentValue === undefined ? '<unset>' : String(currentValue);\n      await this.ioHelper.defaults.info(`  ${flagName}: ${currentDisplay} → ${newValue}`);\n    }\n  }\n\n  /** Builds the update object with new flag values based on parameters and current context */\n  private async buildUpdateObject(flagNames: string[], params: FlagOperationsParams, baseContextValues: Record<string, any>)\n    : Promise<Record<string, boolean> | null> {\n    const updateObj: Record<string, boolean> = {};\n\n    if (flagNames.length === 1 && params.value !== undefined) {\n      const flagName = flagNames[0];\n      const boolValue = params.value === 'true';\n      if (baseContextValues[flagName] === boolValue) {\n        await this.ioHelper.defaults.info('Flag is already set to the specified value. No changes needed.');\n        return null;\n      }\n      updateObj[flagName] = boolValue;\n    } else {\n      for (const flagName of flagNames) {\n        const flag = this.flags.find(f => f.name === flagName);\n        if (!flag) {\n          await this.ioHelper.defaults.error(`Flag ${flagName} not found.`);\n          return null;\n        }\n        const newValue = params.recommended\n          ? flag.recommendedValue as boolean\n          : String(flag.unconfiguredBehavesLike?.v2) === 'true';\n        updateObj[flagName] = newValue;\n      }\n    }\n    return updateObj;\n  }\n\n  /** Prompts user for confirmation and applies changes if accepted */\n  private async handleUserResponse(flagNames: string[], params: FlagOperationsParams): Promise<void> {\n    const userAccepted = await this.ioHelper.requestResponse({\n      time: new Date(),\n      level: 'info',\n      code: 'CDK_TOOLKIT_I9300',\n      message: 'Do you want to accept these changes?',\n      data: {\n        flagNames,\n        responseDescription: 'Enter \"y\" to apply changes or \"n\" to cancel',\n      },\n      defaultResponse: false,\n    });\n\n    if (userAccepted) {\n      await this.modifyValues(flagNames, params);\n      await this.ioHelper.defaults.info('Flag value(s) updated successfully.');\n    } else {\n      await this.ioHelper.defaults.info('Operation cancelled');\n    }\n\n    await this.cleanupTempDirectories();\n  }\n\n  /** Removes temporary directories created during flag operations */\n  private async cleanupTempDirectories(): Promise<void> {\n    const originalDir = path.join(process.cwd(), 'original');\n    const tempDir = path.join(process.cwd(), 'temp');\n    await fs.remove(originalDir);\n    await fs.remove(tempDir);\n  }\n\n  /** Actually modifies the cdk.json file with the new flag values */\n  private async modifyValues(flagNames: string[], params: FlagOperationsParams): Promise<void> {\n    const cdkJsonPath = path.join(process.cwd(), 'cdk.json');\n    const cdkJsonContent = await fs.readFile(cdkJsonPath, 'utf-8');\n    const cdkJson = JSON.parse(cdkJsonContent);\n\n    if (flagNames.length === 1 && !params.safe) {\n      const boolValue = params.value === 'true';\n      cdkJson.context[String(flagNames[0])] = boolValue;\n      await this.ioHelper.defaults.info(`Setting flag '${flagNames}' to: ${boolValue}`);\n    } else {\n      for (const flagName of flagNames) {\n        const flag = this.flags.find(f => f.name === flagName);\n        const newValue = params.recommended || params.safe\n          ? flag!.recommendedValue as boolean\n          : String(flag!.unconfiguredBehavesLike?.v2) === 'true';\n        cdkJson.context[flagName] = newValue;\n      }\n    }\n    await fs.writeFile(cdkJsonPath, JSON.stringify(cdkJson, null, 2), 'utf-8');\n  }\n\n  /** Displays flags in a table format, either specific flags or filtered by criteria */\n  async displayFlags(params: FlagOperationsParams): Promise<void> {\n    const { FLAGNAME, all } = params;\n\n    if (FLAGNAME && FLAGNAME.length > 0) {\n      await this.displaySpecificFlags(FLAGNAME);\n      return;\n    }\n\n    const flagsToDisplay = all ? this.flags : this.flags.filter(flag =>\n      flag.userValue === undefined || !this.isUserValueEqualToRecommended(flag));\n\n    await this.displayFlagTable(flagsToDisplay);\n\n    // Add helpful message after empty table when not using --all\n    if (!all && flagsToDisplay.length === 0) {\n      await this.ioHelper.defaults.info('');\n      await this.ioHelper.defaults.info('✅ All feature flags are already set to their recommended values.');\n      await this.ioHelper.defaults.info('Use \\'cdk flags --all --unstable=flags\\' to see all flags and their current values.');\n    }\n  }\n\n  /** Displays detailed information for specific flags matching the given names */\n  private async displaySpecificFlags(flagNames: string[]): Promise<void> {\n    const matchingFlags = this.flags.filter(f =>\n      flagNames.some(searchTerm => f.name.toLowerCase().includes(searchTerm.toLowerCase())));\n\n    if (matchingFlags.length === 0) {\n      await this.ioHelper.defaults.error(`Flag matching \"${flagNames.join(', ')}\" not found.`);\n      return;\n    }\n\n    if (matchingFlags.length === 1) {\n      const flag = matchingFlags[0];\n      await this.ioHelper.defaults.info(`Flag name: ${flag.name}`);\n      await this.ioHelper.defaults.info(`Description: ${flag.explanation}`);\n      await this.ioHelper.defaults.info(`Recommended value: ${flag.recommendedValue}`);\n      await this.ioHelper.defaults.info(`User value: ${flag.userValue}`);\n      return;\n    }\n\n    await this.ioHelper.defaults.info(`Found ${matchingFlags.length} flags matching \"${flagNames.join(', ')}\":`);\n    await this.displayFlagTable(matchingFlags);\n  }\n\n  /** Returns sort order for flags */\n  private getFlagSortOrder(flag: FeatureFlag): number {\n    if (flag.userValue === undefined) return 3;\n    if (this.isUserValueEqualToRecommended(flag)) return 1;\n    return 2;\n  }\n\n  /** Displays flags in a formatted table grouped by module and sorted */\n  async displayFlagTable(flags: FeatureFlag[]): Promise<void> {\n    const sortedFlags = [...flags].sort((a, b) => {\n      const orderA = this.getFlagSortOrder(a);\n      const orderB = this.getFlagSortOrder(b);\n\n      if (orderA !== orderB) return orderA - orderB;\n      if (a.module !== b.module) return a.module.localeCompare(b.module);\n      return a.name.localeCompare(b.name);\n    });\n\n    const rows: string[][] = [['Feature Flag Name', 'Recommended Value', 'User Value']];\n    let currentModule = '';\n\n    sortedFlags.forEach((flag) => {\n      if (flag.module !== currentModule) {\n        rows.push([chalk.bold(`Module: ${flag.module}`), '', '']);\n        currentModule = flag.module;\n      }\n      rows.push([\n        `  ${flag.name}`,\n        String(flag.recommendedValue),\n        flag.userValue === undefined ? '<unset>' : String(flag.userValue),\n      ]);\n    });\n\n    const formattedTable = formatTable(rows, undefined, true);\n    await this.ioHelper.defaults.info(formattedTable);\n  }\n\n  /** Checks if a flag has a boolean recommended value */\n  isBooleanFlag(flag: FeatureFlag): boolean {\n    const recommended = flag.recommendedValue;\n    return typeof recommended === 'boolean' ||\n      recommended === 'true' ||\n      recommended === 'false';\n  }\n\n  /** Checks if the user's current value matches the recommended value */\n  private isUserValueEqualToRecommended(flag: FeatureFlag): boolean {\n    return String(flag.userValue) === String(flag.recommendedValue);\n  }\n\n  /** Shows helpful usage examples and available command options */\n  async displayHelpMessage(): Promise<void> {\n    await this.ioHelper.defaults.info('\\n' + chalk.bold('Available options:'));\n    await this.ioHelper.defaults.info('  cdk flags --interactive     # Interactive menu to manage flags');\n    await this.ioHelper.defaults.info('  cdk flags --all             # Show all flags (including configured ones)');\n    await this.ioHelper.defaults.info('  cdk flags --set --all --recommended    # Set all flags to recommended values');\n    await this.ioHelper.defaults.info('  cdk flags --set --all --default       # Set all flags to default values');\n    await this.ioHelper.defaults.info('  cdk flags --set --unconfigured --recommended  # Set unconfigured flags to recommended');\n    await this.ioHelper.defaults.info('  cdk flags --set <flag-name> --value <true|false>  # Set specific flag');\n    await this.ioHelper.defaults.info('  cdk flags --safe            # Safely set flags that don\\'t change templates');\n  }\n}\n"]}
449
+ /** Checks if the flags current effective value matches the recommended value */
450
+ function isEffectiveValueEqualToRecommended(flag) {
451
+ return String(effectiveValue(flag)) === String(flag.recommendedValue);
452
+ }
453
+ /**
454
+ * Return the effective value of a flag (user value or default)
455
+ */
456
+ function effectiveValue(flag) {
457
+ return flag.userValue ?? defaultValue(flag);
458
+ }
459
+ /**
460
+ * Return the default value for a flag, assume it's `false` if not given
461
+ */
462
+ function defaultValue(flag) {
463
+ return flag.unconfiguredBehavesLike?.v2 ?? false;
464
+ }
465
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"operations.js","sourceRoot":"","sources":["operations.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport { formatTable } from '@aws-cdk/cloudformation-diff';\nimport type { CloudFormationStackArtifact } from '@aws-cdk/cx-api';\nimport type { FeatureFlag, Toolkit } from '@aws-cdk/toolkit-lib';\nimport { CdkAppMultiContext, MemoryContext, DiffMethod } from '@aws-cdk/toolkit-lib';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport PQueue from 'p-queue';\nimport { OBSOLETE_FLAGS } from './obsolete-flags';\nimport type { FlagOperationsParams } from './types';\nimport { StackSelectionStrategy } from '../../api';\nimport type { IoHelper } from '../../api-private';\n\nexport class FlagOperations {\n  /**\n   * Returns only those feature flags that need configuration\n   *\n   * That is those flags:\n   * - That are unconfigured\n   * - That are not obsolete\n   * - Whose default value is different from the recommended value\n   *\n   * The default value being equal to the recommended value sounds odd, but\n   * crops up in a number of situtations:\n   *\n   * - Security-related fixes that we want to force on people, but want to\n   *   give them a flag to back out of the changes if they really need to.\n   * - Flags that changed their default value in the most recent major\n   *   version.\n   * - Flags that we've introduced at some point in the past, but have gone\n   *   back on.\n   */\n  public static filterNeedsAttention(flags: FeatureFlag[]): FeatureFlag[] {\n    return flags\n      .filter(flag => !OBSOLETE_FLAGS.includes(flag.name))\n      .filter(flag => flag.userValue === undefined)\n      .filter(flag => defaultValue(flag) !== flag.recommendedValue);\n  }\n\n  private app: string;\n  private baseContextValues: Record<string, any>;\n  private allStacks: CloudFormationStackArtifact[];\n  private queue: PQueue;\n  private baselineTempDir?: string;\n\n  constructor(\n    private readonly flags: FeatureFlag[],\n    private readonly toolkit: Toolkit,\n    private readonly ioHelper: IoHelper,\n  ) {\n    this.app = '';\n    this.baseContextValues = {};\n    this.allStacks = [];\n    this.queue = new PQueue({ concurrency: 4 });\n  }\n\n  /** Main entry point that routes to either flag setting or display operations */\n  async execute(params: FlagOperationsParams): Promise<void> {\n    if (params.set) {\n      if (params.FLAGNAME && params.value) {\n        await this.setFlag(params);\n      } else {\n        await this.setMultipleFlags(params);\n      }\n    } else {\n      await this.displayFlags(params);\n    }\n  }\n\n  /** Sets a single specific flag with validation and user confirmation */\n  async setFlag(params: FlagOperationsParams): Promise<void> {\n    const flagName = params.FLAGNAME![0];\n    const flag = this.flags.find(f => f.name === flagName);\n\n    if (!flag) {\n      await this.ioHelper.defaults.error('Flag not found.');\n      return;\n    }\n\n    if (!this.isBooleanFlag(flag)) {\n      await this.ioHelper.defaults.error(`Flag '${flagName}' is not a boolean flag. Only boolean flags are currently supported.`);\n      return;\n    }\n\n    const prototypeSuccess = await this.prototypeChanges([flagName], params);\n    if (prototypeSuccess) {\n      await this.handleUserResponse([flagName], params);\n    }\n  }\n\n  /** Sets multiple flags (all or unconfigured) with validation and user confirmation */\n  async setMultipleFlags(params: FlagOperationsParams): Promise<void> {\n    if (params.default && !this.flags.some(f => f.unconfiguredBehavesLike)) {\n      await this.ioHelper.defaults.error('The --default options are not compatible with the AWS CDK library used by your application. Please upgrade to 2.212.0 or above.');\n      return;\n    }\n\n    const flagsToSet = this.getFlagsToSet(params);\n    const prototypeSuccess = await this.prototypeChanges(flagsToSet, params);\n\n    if (prototypeSuccess) {\n      await this.handleUserResponse(flagsToSet, params);\n    }\n  }\n\n  /** Determines which flags should be set based on the provided parameters */\n  private getFlagsToSet(params: FlagOperationsParams): string[] {\n    if (params.all && params.default) {\n      return this.flags\n        .filter(flag => this.isBooleanFlag(flag))\n        .map(flag => flag.name);\n    } else if (params.all) {\n      return this.flags\n        .filter(flag => flag.userValue === undefined || !isEffectiveValueEqualToRecommended(flag))\n        .filter(flag => this.isBooleanFlag(flag))\n        .map(flag => flag.name);\n    } else {\n      return this.flags\n        .filter(flag => flag.userValue === undefined)\n        .filter(flag => this.isBooleanFlag(flag))\n        .map(flag => flag.name);\n    }\n  }\n\n  /** Sets flags that don't cause template changes */\n  async setSafeFlags(params: FlagOperationsParams): Promise<void> {\n    const cdkJson = await JSON.parse(await fs.readFile(path.join(process.cwd(), 'cdk.json'), 'utf-8'));\n    this.app = params.app || cdkJson.app;\n\n    const isUsingTsNode = this.app.includes('ts-node');\n    if (isUsingTsNode && !this.app.includes('-T') && !this.app.includes('--transpileOnly')) {\n      await this.ioHelper.defaults.info('Repeated synths with ts-node will type-check the application on every synth. Add --transpileOnly to cdk.json\\'s \"app\" command to make this operation faster.');\n    }\n\n    const unconfiguredFlags = this.flags.filter(flag =>\n      flag.userValue === undefined && this.isBooleanFlag(flag));\n\n    if (unconfiguredFlags.length === 0) {\n      await this.ioHelper.defaults.info('All feature flags are configured.');\n      return;\n    }\n\n    await this.initializeSafetyCheck();\n    const safeFlags = await this.batchTestFlags(unconfiguredFlags);\n    await this.cleanupSafetyCheck();\n\n    if (safeFlags.length > 0) {\n      await this.ioHelper.defaults.info('Flags that can be set without template changes:');\n      for (const flag of safeFlags) {\n        await this.ioHelper.defaults.info(`- ${flag.name} -> ${flag.recommendedValue}`);\n      }\n      await this.handleUserResponse(safeFlags.map(flag => flag.name), { ...params, recommended: true });\n    } else {\n      await this.ioHelper.defaults.info('No more flags can be set without causing template changes.');\n    }\n  }\n\n  /** Initializes the safety check by reading context and synthesizing baseline templates */\n  private async initializeSafetyCheck(): Promise<void> {\n    const baseContext = new CdkAppMultiContext(process.cwd());\n    this.baseContextValues = await baseContext.read();\n\n    this.baselineTempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-baseline-'));\n    const baseSource = await this.toolkit.fromCdkApp(this.app, {\n      contextStore: baseContext,\n      outdir: this.baselineTempDir,\n    });\n\n    const baseCx = await this.toolkit.synth(baseSource);\n    const baseAssembly = baseCx.cloudAssembly;\n    this.allStacks = baseAssembly.stacksRecursively;\n    this.queue = new PQueue({ concurrency: 4 });\n  }\n\n  /** Cleans up temporary directories created during safety checks */\n  private async cleanupSafetyCheck(): Promise<void> {\n    if (this.baselineTempDir) {\n      await fs.remove(this.baselineTempDir);\n      this.baselineTempDir = undefined;\n    }\n  }\n\n  /** Tests multiple flags together and isolates unsafe ones using binary search */\n  private async batchTestFlags(flags: FeatureFlag[]): Promise<FeatureFlag[]> {\n    if (flags.length === 0) return [];\n\n    const allFlagsContext = { ...this.baseContextValues };\n    flags.forEach(flag => {\n      allFlagsContext[flag.name] = flag.recommendedValue;\n    });\n\n    const allSafe = await this.testBatch(allFlagsContext);\n    if (allSafe) return flags;\n\n    return this.isolateUnsafeFlags(flags);\n  }\n\n  /** Tests if a set of context values causes template changes by synthesizing and diffing */\n  private async testBatch(contextValues: Record<string, any>): Promise<boolean> {\n    const testContext = new MemoryContext(contextValues);\n    const tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-test-'));\n    const testSource = await this.toolkit.fromCdkApp(this.app, {\n      contextStore: testContext,\n      outdir: tempDir,\n    });\n\n    const testCx = await this.toolkit.synth(testSource);\n\n    try {\n      for (const stack of this.allStacks) {\n        const templatePath = stack.templateFullPath;\n        const diff = await this.toolkit.diff(testCx, {\n          method: DiffMethod.LocalFile(templatePath),\n          stacks: {\n            strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE,\n            patterns: [stack.hierarchicalId],\n          },\n        });\n\n        for (const stackDiff of Object.values(diff)) {\n          if (stackDiff.differenceCount > 0) {\n            return false;\n          }\n        }\n      }\n      return true;\n    } finally {\n      await fs.remove(tempDir);\n    }\n  }\n\n  /** Uses binary search to isolate which flags are safe to set without template changes */\n  private async isolateUnsafeFlags(flags: FeatureFlag[]): Promise<FeatureFlag[]> {\n    const safeFlags: FeatureFlag[] = [];\n\n    const processBatch = async (batch: FeatureFlag[], contextValues: Record<string, any>): Promise<void> => {\n      if (batch.length === 1) {\n        const isSafe = await this.testBatch(\n          { ...contextValues, [batch[0].name]: batch[0].recommendedValue },\n        );\n        if (isSafe) safeFlags.push(batch[0]);\n        return;\n      }\n\n      const batchContext = { ...contextValues };\n      batch.forEach(flag => {\n        batchContext[flag.name] = flag.recommendedValue;\n      });\n\n      const isSafeBatch = await this.testBatch(batchContext);\n      if (isSafeBatch) {\n        safeFlags.push(...batch);\n        return;\n      }\n\n      const mid = Math.floor(batch.length / 2);\n      const left = batch.slice(0, mid);\n      const right = batch.slice(mid);\n\n      void this.queue.add(() => processBatch(left, contextValues));\n      void this.queue.add(() => processBatch(right, contextValues));\n    };\n\n    void this.queue.add(() => processBatch(flags, this.baseContextValues));\n    await this.queue.onIdle();\n    return safeFlags;\n  }\n\n  /** Prototypes flag changes by synthesizing templates and showing diffs to the user */\n  private async prototypeChanges(flagNames: string[], params: FlagOperationsParams): Promise<boolean> {\n    const baseContext = new CdkAppMultiContext(process.cwd());\n    const baseContextValues = await baseContext.read();\n    const memoryContext = new MemoryContext(baseContextValues);\n\n    const cdkJson = await JSON.parse(await fs.readFile(path.join(process.cwd(), 'cdk.json'), 'utf-8'));\n    const app = cdkJson.app;\n\n    const source = await this.toolkit.fromCdkApp(app, {\n      contextStore: baseContext,\n      outdir: fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-original-')),\n    });\n\n    const updateObj = await this.buildUpdateObject(flagNames, params, baseContextValues);\n    if (!updateObj) return false;\n\n    await memoryContext.update(updateObj);\n    const cx = await this.toolkit.synth(source);\n    const assembly = cx.cloudAssembly;\n\n    const modifiedSource = await this.toolkit.fromCdkApp(app, {\n      contextStore: memoryContext,\n      outdir: fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-temp-')),\n    });\n\n    const modifiedCx = await this.toolkit.synth(modifiedSource);\n    const allStacks = assembly.stacksRecursively;\n\n    for (const stack of allStacks) {\n      const templatePath = stack.templateFullPath;\n      await this.toolkit.diff(modifiedCx, {\n        method: DiffMethod.LocalFile(templatePath),\n        stacks: {\n          strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE,\n          patterns: [stack.hierarchicalId],\n        },\n      });\n    }\n\n    await this.displayFlagChanges(updateObj, baseContextValues);\n    return true;\n  }\n\n  /** Displays a summary of flag changes showing old and new values */\n  private async displayFlagChanges(updateObj: Record<string, boolean>, baseContextValues: Record<string, any>): Promise<void> {\n    await this.ioHelper.defaults.info('\\nFlag changes:');\n    for (const [flagName, newValue] of Object.entries(updateObj)) {\n      const currentValue = baseContextValues[flagName];\n      const currentDisplay = currentValue === undefined ? '<unset>' : String(currentValue);\n      await this.ioHelper.defaults.info(`  ${flagName}: ${currentDisplay} → ${newValue}`);\n    }\n  }\n\n  /** Builds the update object with new flag values based on parameters and current context */\n  private async buildUpdateObject(flagNames: string[], params: FlagOperationsParams, baseContextValues: Record<string, any>)\n    : Promise<Record<string, boolean> | null> {\n    const updateObj: Record<string, boolean> = {};\n\n    if (flagNames.length === 1 && params.value !== undefined) {\n      const flagName = flagNames[0];\n      const boolValue = params.value === 'true';\n      if (baseContextValues[flagName] === boolValue) {\n        await this.ioHelper.defaults.info('Flag is already set to the specified value. No changes needed.');\n        return null;\n      }\n      updateObj[flagName] = boolValue;\n    } else {\n      for (const flagName of flagNames) {\n        const flag = this.flags.find(f => f.name === flagName);\n        if (!flag) {\n          await this.ioHelper.defaults.error(`Flag ${flagName} not found.`);\n          return null;\n        }\n        const newValue = params.recommended\n          ? flag.recommendedValue as boolean\n          : String(defaultValue(flag)) === 'true';\n        updateObj[flagName] = newValue;\n      }\n    }\n    return updateObj;\n  }\n\n  /** Prompts user for confirmation and applies changes if accepted */\n  private async handleUserResponse(flagNames: string[], params: FlagOperationsParams): Promise<void> {\n    const userAccepted = await this.ioHelper.requestResponse({\n      time: new Date(),\n      level: 'info',\n      code: 'CDK_TOOLKIT_I9300',\n      message: 'Do you want to accept these changes?',\n      data: {\n        flagNames,\n        responseDescription: 'Enter \"y\" to apply changes or \"n\" to cancel',\n      },\n      defaultResponse: false,\n    });\n\n    if (userAccepted) {\n      await this.modifyValues(flagNames, params);\n      await this.ioHelper.defaults.info('Flag value(s) updated successfully.');\n    } else {\n      await this.ioHelper.defaults.info('Operation cancelled');\n    }\n\n    await this.cleanupTempDirectories();\n  }\n\n  /** Removes temporary directories created during flag operations */\n  private async cleanupTempDirectories(): Promise<void> {\n    const originalDir = path.join(process.cwd(), 'original');\n    const tempDir = path.join(process.cwd(), 'temp');\n    await fs.remove(originalDir);\n    await fs.remove(tempDir);\n  }\n\n  /** Actually modifies the cdk.json file with the new flag values */\n  private async modifyValues(flagNames: string[], params: FlagOperationsParams): Promise<void> {\n    const cdkJsonPath = path.join(process.cwd(), 'cdk.json');\n    const cdkJsonContent = await fs.readFile(cdkJsonPath, 'utf-8');\n    const cdkJson = JSON.parse(cdkJsonContent);\n\n    if (flagNames.length === 1 && !params.safe) {\n      const boolValue = params.value === 'true';\n      cdkJson.context[String(flagNames[0])] = boolValue;\n      await this.ioHelper.defaults.info(`Setting flag '${flagNames}' to: ${boolValue}`);\n    } else {\n      for (const flagName of flagNames) {\n        const flag = this.flags.find(f => f.name === flagName)!;\n        const newValue = params.recommended || params.safe\n          ? flag.recommendedValue as boolean\n          : String(defaultValue(flag)) === 'true';\n        cdkJson.context[flagName] = newValue;\n      }\n    }\n    await fs.writeFile(cdkJsonPath, JSON.stringify(cdkJson, null, 2), 'utf-8');\n  }\n\n  /** Displays flags in a table format, either specific flags or filtered by criteria */\n  async displayFlags(params: FlagOperationsParams): Promise<void> {\n    const { FLAGNAME, all } = params;\n\n    if (FLAGNAME && FLAGNAME.length > 0) {\n      await this.displaySpecificFlags(FLAGNAME);\n      return;\n    }\n\n    const [flagsToDisplay, header] = all\n      ? [this.flags, 'All feature flags']\n      : [FlagOperations.filterNeedsAttention(this.flags), 'Unconfigured feature flags'];\n\n    await this.ioHelper.defaults.info(header);\n    await this.displayFlagTable(flagsToDisplay);\n\n    // Add helpful message after empty table when not using --all\n    if (!all && flagsToDisplay.length === 0) {\n      await this.ioHelper.defaults.info('');\n      await this.ioHelper.defaults.info('✅ All feature flags are already set to their recommended values.');\n      await this.ioHelper.defaults.info('Use \\'cdk flags --all --unstable=flags\\' to see all flags and their current values.');\n    }\n  }\n\n  /** Displays detailed information for specific flags matching the given names */\n  private async displaySpecificFlags(flagNames: string[]): Promise<void> {\n    const matchingFlags = this.flags.filter(f =>\n      flagNames.some(searchTerm => f.name.toLowerCase().includes(searchTerm.toLowerCase())));\n\n    if (matchingFlags.length === 0) {\n      await this.ioHelper.defaults.error(`Flag matching \"${flagNames.join(', ')}\" not found.`);\n      return;\n    }\n\n    if (matchingFlags.length === 1) {\n      const flag = matchingFlags[0];\n      await this.ioHelper.defaults.info(`Flag name: ${flag.name}`);\n      await this.ioHelper.defaults.info(`Description: ${flag.explanation}`);\n      await this.ioHelper.defaults.info(`Recommended value: ${flag.recommendedValue}`);\n      await this.ioHelper.defaults.info(`Default value: ${defaultValue(flag)}`);\n      await this.ioHelper.defaults.info(`User value: ${flag.userValue}`);\n      await this.ioHelper.defaults.info(`Effective value: ${effectiveValue(flag)}`);\n      return;\n    }\n\n    await this.ioHelper.defaults.info(`Found ${matchingFlags.length} flags matching \"${flagNames.join(', ')}\"`);\n    await this.displayFlagTable(matchingFlags);\n  }\n\n  /** Returns sort order for flags */\n  private getFlagSortOrder(flag: FeatureFlag): number {\n    if (flag.userValue === undefined) return 3;\n    if (isEffectiveValueEqualToRecommended(flag)) return 1;\n    return 2;\n  }\n\n  /** Displays flags in a formatted table grouped by module and sorted */\n  async displayFlagTable(flags: FeatureFlag[]): Promise<void> {\n    const sortedFlags = [...flags].sort((a, b) => {\n      const orderA = this.getFlagSortOrder(a);\n      const orderB = this.getFlagSortOrder(b);\n\n      if (orderA !== orderB) return orderA - orderB;\n      if (a.module !== b.module) return a.module.localeCompare(b.module);\n      return a.name.localeCompare(b.name);\n    });\n\n    const rows: string[][] = [['Feature Flag', 'Recommended', 'User', 'Effective']];\n    let currentModule = '';\n\n    sortedFlags.forEach((flag) => {\n      if (flag.module !== currentModule) {\n        rows.push([chalk.bold(`Module: ${flag.module}`), '', '', '']);\n        currentModule = flag.module;\n      }\n      rows.push([\n        `  ${flag.name}`,\n        String(flag.recommendedValue),\n        flag.userValue === undefined ? '<unset>' : String(flag.userValue),\n        String(effectiveValue(flag)),\n      ]);\n    });\n\n    const formattedTable = formatTable(rows, undefined, true);\n    await this.ioHelper.defaults.info(formattedTable);\n  }\n\n  /** Checks if a flag has a boolean recommended value */\n  isBooleanFlag(flag: FeatureFlag): boolean {\n    const recommended = flag.recommendedValue;\n    return typeof recommended === 'boolean' ||\n      recommended === 'true' ||\n      recommended === 'false';\n  }\n\n  /** Shows helpful usage examples and available command options */\n  async displayHelpMessage(): Promise<void> {\n    await this.ioHelper.defaults.info('\\n' + chalk.bold('Available options:'));\n    await this.ioHelper.defaults.info('  cdk flags --interactive     # Interactive menu to manage flags');\n    await this.ioHelper.defaults.info('  cdk flags --all             # Show all flags (including configured ones)');\n    await this.ioHelper.defaults.info('  cdk flags --set --all --recommended    # Set all flags to recommended values');\n    await this.ioHelper.defaults.info('  cdk flags --set --all --default       # Set all flags to default values');\n    await this.ioHelper.defaults.info('  cdk flags --set --unconfigured --recommended  # Set unconfigured flags to recommended');\n    await this.ioHelper.defaults.info('  cdk flags --set <flag-name> --value <true|false>  # Set specific flag');\n    await this.ioHelper.defaults.info('  cdk flags --safe            # Safely set flags that don\\'t change templates');\n  }\n}\n\n/** Checks if the flags current effective value matches the recommended value */\nexport function isEffectiveValueEqualToRecommended(flag: FeatureFlag): boolean {\n  return String(effectiveValue(flag)) === String(flag.recommendedValue);\n}\n\n/**\n * Return the effective value of a flag (user value or default)\n */\nfunction effectiveValue(flag: FeatureFlag) {\n  return flag.userValue ?? defaultValue(flag);\n}\n\n/**\n * Return the default value for a flag, assume it's `false` if not given\n */\nfunction defaultValue(flag: FeatureFlag) {\n  return flag.unconfiguredBehavesLike?.v2 ?? false;\n}\n"]}
@@ -1,4 +1,5 @@
1
1
  import type { IoHelper } from '../../api-private';
2
+ import type { JsPackageManager } from './package-manager';
2
3
  export interface CliInitOptions {
3
4
  /**
4
5
  * Template name to initialize
@@ -46,6 +47,11 @@ export interface CliInitOptions {
46
47
  * @default undefined
47
48
  */
48
49
  readonly templatePath?: string;
50
+ /**
51
+ * The package manager to use for installing dependencies. Only applicable for TypeScript and JavaScript projects.
52
+ * @default - If specified language is 'typescript' or 'javascript', 'npm' is selected. Otherwise, no package manager is used.
53
+ */
54
+ readonly packageManager?: JsPackageManager;
49
55
  readonly ioHelper: IoHelper;
50
56
  }
51
57
  /**