aws-cdk 2.175.0 → 2.176.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 (91) hide show
  1. package/CONTRIBUTING.md +4 -4
  2. package/build-info.json +2 -2
  3. package/db.json.gz +0 -0
  4. package/lib/api/aws-auth/credential-plugins.js +5 -5
  5. package/lib/api/aws-auth/sdk-provider.js +3 -2
  6. package/lib/api/aws-auth/sdk.js +3 -2
  7. package/lib/api/cxapp/cloud-assembly.js +4 -4
  8. package/lib/api/deploy-stack.js +11 -10
  9. package/lib/api/deployments.js +4 -4
  10. package/lib/api/environment-access.js +3 -2
  11. package/lib/api/environment-resources.js +3 -2
  12. package/lib/api/garbage-collection/garbage-collector.js +9 -9
  13. package/lib/api/garbage-collection/progress-printer.js +3 -3
  14. package/lib/api/hotswap-deployments.js +11 -10
  15. package/lib/api/logs/find-cloudwatch-logs.js +3 -2
  16. package/lib/api/logs/logs-monitor.js +3 -3
  17. package/lib/api/nested-stack-helpers.js +3 -2
  18. package/lib/api/plugin/plugin.js +1 -1
  19. package/lib/api/util/cloudformation/stack-activity-monitor.d.ts +4 -4
  20. package/lib/api/util/cloudformation/stack-activity-monitor.js +9 -9
  21. package/lib/api/util/cloudformation/stack-event-poller.js +3 -2
  22. package/lib/api/util/cloudformation.js +3 -3
  23. package/lib/cdk-toolkit.d.ts +0 -1
  24. package/lib/cdk-toolkit.js +32 -76
  25. package/lib/cli.js +12 -7
  26. package/lib/commands/context.js +20 -20
  27. package/lib/commands/docs.js +2 -2
  28. package/lib/commands/doctor.js +9 -9
  29. package/lib/commands/migrate.js +16 -16
  30. package/lib/config.d.ts +6 -3
  31. package/lib/config.js +10 -7
  32. package/lib/context-providers/ami.js +2 -2
  33. package/lib/context-providers/index.js +3 -2
  34. package/lib/convert-to-user-input.d.ts +3 -0
  35. package/lib/convert-to-user-input.js +431 -0
  36. package/lib/diff.js +3 -3
  37. package/lib/import.js +6 -6
  38. package/lib/index.js +50 -35
  39. package/lib/init-hooks.js +3 -2
  40. package/lib/init-templates/.init-version.json +1 -1
  41. package/lib/init-templates/.recommended-feature-flags.json +2 -1
  42. package/lib/init-templates/app/csharp/src/%name.PascalCased%/%name.PascalCased%.template.csproj +1 -1
  43. package/lib/init-templates/app/fsharp/src/%name.PascalCased%/%name.PascalCased%.template.fsproj +1 -1
  44. package/lib/init-templates/sample-app/csharp/src/%name.PascalCased%/%name.PascalCased%.template.csproj +1 -1
  45. package/lib/init-templates/sample-app/fsharp/src/%name.PascalCased%/%name.PascalCased%.template.fsproj +1 -1
  46. package/lib/init.d.ts +1 -1
  47. package/lib/init.js +20 -19
  48. package/lib/logging.d.ts +112 -48
  49. package/lib/logging.js +176 -133
  50. package/lib/notices.js +13 -12
  51. package/lib/parse-command-line-arguments.js +2 -2
  52. package/lib/settings.d.ts +2 -0
  53. package/lib/settings.js +3 -1
  54. package/lib/toolkit/cli-io-host.d.ts +56 -25
  55. package/lib/toolkit/cli-io-host.js +49 -22
  56. package/lib/toolkit/error.js +2 -2
  57. package/lib/{cli-arguments.d.ts → user-input.d.ts} +8 -8
  58. package/lib/user-input.js +3 -0
  59. package/lib/util/archive.js +3 -2
  60. package/lib/util/asset-publishing.js +3 -3
  61. package/lib/util/error.d.ts +9 -0
  62. package/lib/util/error.js +22 -0
  63. package/lib/version.js +2 -2
  64. package/package.json +12 -11
  65. package/scripts/user-input-gen +2 -0
  66. package/scripts/user-input-gen.js +17 -0
  67. package/test/api/exec.test.js +3 -3
  68. package/test/api/fake-sts.js +3 -2
  69. package/test/api/logs/logging.test.js +269 -0
  70. package/test/api/sdk-provider.test.js +3 -3
  71. package/test/api/stack-activity-monitor.test.js +16 -16
  72. package/test/api/util/error.test.d.ts +1 -0
  73. package/test/api/util/error.test.js +26 -0
  74. package/test/cdk-toolkit.test.js +1 -46
  75. package/test/cli-arguments.test.js +126 -81
  76. package/test/cli.test.js +8 -8
  77. package/test/init.test.js +5 -5
  78. package/test/jest-bufferedconsole.d.ts +14 -0
  79. package/test/jest-bufferedconsole.js +72 -0
  80. package/test/notices.test.js +14 -14
  81. package/test/toolkit/cli-io-host.test.js +93 -188
  82. package/test/util/silent.js +2 -2
  83. package/test/version.test.js +5 -5
  84. package/lib/cli-arguments.js +0 -3
  85. package/lib/convert-to-cli-args.d.ts +0 -2
  86. package/lib/convert-to-cli-args.js +0 -234
  87. package/scripts/cli-args-gen +0 -2
  88. package/scripts/cli-args-gen.js +0 -16
  89. package/test/api/logs/cli-logging.test.js +0 -135
  90. /package/scripts/{cli-args-gen.d.ts → user-input-gen.d.ts} +0 -0
  91. /package/test/api/logs/{cli-logging.test.d.ts → logging.test.d.ts} +0 -0
package/lib/logging.js CHANGED
@@ -1,67 +1,29 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.highlight = exports.success = exports.trace = exports.debug = exports.data = exports.print = exports.info = exports.warning = exports.error = exports.LogLevel = void 0;
4
- exports.setLogLevel = setLogLevel;
3
+ exports.highlight = exports.success = exports.trace = exports.debug = exports.data = exports.info = exports.warning = exports.error = void 0;
4
+ exports.setIoMessageThreshold = setIoMessageThreshold;
5
5
  exports.setCI = setCI;
6
6
  exports.withCorkedLogging = withCorkedLogging;
7
- exports.log = log;
8
- exports.prefix = prefix;
9
7
  const util = require("util");
10
8
  const chalk = require("chalk");
11
- /**
12
- * Available log levels in order of increasing verbosity.
13
- */
14
- var LogLevel;
15
- (function (LogLevel) {
16
- LogLevel["ERROR"] = "error";
17
- LogLevel["WARN"] = "warn";
18
- LogLevel["INFO"] = "info";
19
- LogLevel["DEBUG"] = "debug";
20
- LogLevel["TRACE"] = "trace";
21
- })(LogLevel || (exports.LogLevel = LogLevel = {}));
22
- const { stdout, stderr } = process;
9
+ const cli_io_host_1 = require("./toolkit/cli-io-host");
23
10
  // Corking mechanism
24
11
  let CORK_COUNTER = 0;
25
12
  const logBuffer = [];
26
- // Style mappings
27
- const styleMap = {
28
- [LogLevel.ERROR]: chalk.red,
29
- [LogLevel.WARN]: chalk.yellow,
30
- [LogLevel.INFO]: chalk.white,
31
- [LogLevel.DEBUG]: chalk.gray,
32
- [LogLevel.TRACE]: chalk.gray,
33
- };
34
- // Stream selection
35
- let CI = false;
36
- /**
37
- * Determines which output stream to use based on log level and configuration.
38
- * @param level - The log level to determine stream for
39
- * @param forceStdout - Whether to force stdout regardless of level
40
- * @returns The appropriate Writable stream
41
- */
42
- const getStream = (level, forceStdout) => {
43
- // Special case - data() calls should always go to stdout
44
- if (forceStdout) {
45
- return stdout;
46
- }
47
- if (level === LogLevel.ERROR)
48
- return stderr;
49
- return CI ? stdout : stderr;
50
- };
51
13
  const levelPriority = {
52
- [LogLevel.ERROR]: 0,
53
- [LogLevel.WARN]: 1,
54
- [LogLevel.INFO]: 2,
55
- [LogLevel.DEBUG]: 3,
56
- [LogLevel.TRACE]: 4,
14
+ error: 0,
15
+ warn: 1,
16
+ info: 2,
17
+ debug: 3,
18
+ trace: 4,
57
19
  };
58
- let currentLogLevel = LogLevel.INFO;
20
+ let currentIoMessageThreshold = 'info';
59
21
  /**
60
- * Sets the current log level. Messages with a lower priority level will be filtered out.
61
- * @param level - The new log level to set
22
+ * Sets the current threshold. Messages with a lower priority level will be ignored.
23
+ * @param level The new log level threshold
62
24
  */
63
- function setLogLevel(level) {
64
- currentLogLevel = level;
25
+ function setIoMessageThreshold(level) {
26
+ currentIoMessageThreshold = level;
65
27
  }
66
28
  /**
67
29
  * Sets whether the logger is running in CI mode.
@@ -69,20 +31,11 @@ function setLogLevel(level) {
69
31
  * @param newCI - Whether CI mode should be enabled
70
32
  */
71
33
  function setCI(newCI) {
72
- CI = newCI;
73
- }
74
- /**
75
- * Formats a date object into a timestamp string (HH:MM:SS).
76
- * @param d - Date object to format
77
- * @returns Formatted time string
78
- */
79
- function formatTime(d) {
80
- const pad = (n) => n.toString().padStart(2, '0');
81
- return `${pad(d.getHours())}:${pad(d.getMinutes())}:${pad(d.getSeconds())}`;
34
+ cli_io_host_1.CliIoHost.ci = newCI;
82
35
  }
83
36
  /**
84
37
  * Executes a block of code with corked logging. All log messages during execution
85
- * are buffered and only written after the block completes.
38
+ * are buffered and only written when all nested cork blocks complete (when CORK_COUNTER reaches 0).
86
39
  * @param block - Async function to execute with corked logging
87
40
  * @returns Promise that resolves with the block's return value
88
41
  */
@@ -94,93 +47,183 @@ async function withCorkedLogging(block) {
94
47
  finally {
95
48
  CORK_COUNTER--;
96
49
  if (CORK_COUNTER === 0) {
97
- logBuffer.forEach(([stream, str]) => stream.write(str + '\n'));
50
+ // Process each buffered message through notify
51
+ for (const ioMessage of logBuffer) {
52
+ void cli_io_host_1.CliIoHost.getIoHost().notify(ioMessage);
53
+ }
98
54
  logBuffer.splice(0);
99
55
  }
100
56
  }
101
57
  }
102
- function log(levelOrEntry, fmt, ...args) {
103
- // Normalize input
104
- const entry = typeof levelOrEntry === 'string'
105
- ? { level: levelOrEntry, message: util.format(fmt, ...args) }
106
- : levelOrEntry;
107
- // Check if we should log this level
108
- if (levelPriority[entry.level] > levelPriority[currentLogLevel]) {
58
+ /**
59
+ * Internal core logging function that writes messages through the CLI IO host.
60
+ * @param options Configuration options for the log message. See {@link LogOptions}
61
+ */
62
+ function log(options) {
63
+ if (levelPriority[options.level] > levelPriority[currentIoMessageThreshold]) {
109
64
  return;
110
65
  }
111
- // Format the message
112
- let finalMessage = entry.message;
113
- // Add timestamp first if requested
114
- if (entry.timestamp) {
115
- finalMessage = `[${formatTime(new Date())}] ${finalMessage}`;
116
- }
117
- // Add prefix AFTER timestamp
118
- if (entry.prefix) {
119
- finalMessage = `${entry.prefix} ${finalMessage}`;
120
- }
121
- // Apply custom style if provided, otherwise use level-based style
122
- const style = entry.style || styleMap[entry.level];
123
- finalMessage = style(finalMessage);
124
- // Get appropriate stream - pass through forceStdout flag
125
- const stream = getStream(entry.level, entry.forceStdout);
126
- // Handle corking
66
+ const ioMessage = {
67
+ level: options.level,
68
+ message: options.message,
69
+ forceStdout: options.forceStdout,
70
+ time: new Date(),
71
+ action: cli_io_host_1.CliIoHost.currentAction ?? 'none',
72
+ code: options.code,
73
+ };
127
74
  if (CORK_COUNTER > 0) {
128
- logBuffer.push([stream, finalMessage]);
75
+ logBuffer.push(ioMessage);
129
76
  return;
130
77
  }
131
- // Write to stream
132
- stream.write(finalMessage + '\n');
78
+ void cli_io_host_1.CliIoHost.getIoHost().notify(ioMessage);
79
+ }
80
+ /**
81
+ * Internal helper that processes log inputs into a consistent format.
82
+ * Handles string interpolation, format strings, and object parameter styles.
83
+ * Applies optional styling and prepares the final message for logging.
84
+ */
85
+ function formatMessageAndLog(level, forceStdout, input, style, ...args) {
86
+ // Extract message and code from input, using new default code format
87
+ const { message, code = getDefaultCode(level) } = typeof input === 'object' ? input : { message: input };
88
+ // Format message if args are provided
89
+ const formattedMessage = args.length > 0
90
+ ? util.format(message, ...args)
91
+ : message;
92
+ // Apply style if provided
93
+ const finalMessage = style ? style(formattedMessage) : formattedMessage;
94
+ log({
95
+ level,
96
+ message: finalMessage,
97
+ code,
98
+ forceStdout,
99
+ });
100
+ }
101
+ function getDefaultCode(level, category = 'TOOLKIT') {
102
+ const levelIndicator = level === 'error' ? 'E' :
103
+ level === 'warn' ? 'W' :
104
+ 'I';
105
+ return `CDK_${category}_${levelIndicator}0000`;
133
106
  }
134
- // Convenience logging methods
135
- const error = (fmt, ...args) => log(LogLevel.ERROR, fmt, ...args);
107
+ // Exported logging functions. If any additional logging functionality is required, it should be added as
108
+ // a new logging function here.
109
+ /**
110
+ * Logs an error level message.
111
+ *
112
+ * Can be used in multiple ways:
113
+ * ```ts
114
+ * error(`operation failed: ${e}`) // infers default error code `CDK_TOOLKIT_E000`
115
+ * error('operation failed: %s', e) // infers default error code `CDK_TOOLKIT_E000`
116
+ * error({ message: 'operation failed', code: 'CDK_SDK_E001' }) // specifies error code `CDK_SDK_E001`
117
+ * error({ message: 'operation failed: %s', code: 'CDK_SDK_E001' }, e) // specifies error code `CDK_SDK_E001`
118
+ * ```
119
+ */
120
+ const error = (input, ...args) => {
121
+ return formatMessageAndLog('error', false, input, undefined, ...args);
122
+ };
136
123
  exports.error = error;
137
- const warning = (fmt, ...args) => log(LogLevel.WARN, fmt, ...args);
124
+ /**
125
+ * Logs an warning level message.
126
+ *
127
+ * Can be used in multiple ways:
128
+ * ```ts
129
+ * warning(`deprected feature: ${message}`) // infers default warning code `CDK_TOOLKIT_W000`
130
+ * warning('deprected feature: %s', message) // infers default warning code `CDK_TOOLKIT_W000`
131
+ * warning({ message: 'deprected feature', code: 'CDK_SDK_W001' }) // specifies warning code `CDK_SDK_W001`
132
+ * warning({ message: 'deprected feature: %s', code: 'CDK_SDK_W001' }, message) // specifies warning code `CDK_SDK_W001`
133
+ * ```
134
+ */
135
+ const warning = (input, ...args) => {
136
+ return formatMessageAndLog('warn', false, input, undefined, ...args);
137
+ };
138
138
  exports.warning = warning;
139
- const info = (fmt, ...args) => log(LogLevel.INFO, fmt, ...args);
139
+ /**
140
+ * Logs an info level message.
141
+ *
142
+ * Can be used in multiple ways:
143
+ * ```ts
144
+ * info(`processing: ${message}`) // infers default info code `CDK_TOOLKIT_I000`
145
+ * info('processing: %s', message) // infers default info code `CDK_TOOLKIT_I000`
146
+ * info({ message: 'processing', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`
147
+ * info({ message: 'processing: %s', code: 'CDK_TOOLKIT_I001' }, message) // specifies info code `CDK_TOOLKIT_I001`
148
+ * ```
149
+ */
150
+ const info = (input, ...args) => {
151
+ return formatMessageAndLog('info', false, input, undefined, ...args);
152
+ };
140
153
  exports.info = info;
141
- const print = (fmt, ...args) => log(LogLevel.INFO, fmt, ...args);
142
- exports.print = print;
143
- const data = (fmt, ...args) => log({
144
- level: LogLevel.INFO,
145
- message: util.format(fmt, ...args),
146
- forceStdout: true,
147
- });
154
+ /**
155
+ * Logs an info level message to stdout.
156
+ *
157
+ * Can be used in multiple ways:
158
+ * ```ts
159
+ * data(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`
160
+ * data('{"count": %d}', count) // infers default info code `CDK_TOOLKIT_I000`
161
+ * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`
162
+ * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`
163
+ * ```
164
+ */
165
+ const data = (input, ...args) => {
166
+ return formatMessageAndLog('info', true, input, undefined, ...args);
167
+ };
148
168
  exports.data = data;
149
- const debug = (fmt, ...args) => log({
150
- level: LogLevel.DEBUG,
151
- message: util.format(fmt, ...args),
152
- timestamp: true,
153
- });
169
+ /**
170
+ * Logs a debug level message.
171
+ *
172
+ * Can be used in multiple ways:
173
+ * ```ts
174
+ * debug(`state: ${JSON.stringify(state)}`) // infers default info code `CDK_TOOLKIT_I000`
175
+ * debug('cache hit ratio: %d%%', ratio) // infers default info code `CDK_TOOLKIT_I000`
176
+ * debug({ message: 'state update', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`
177
+ * debug({ message: 'ratio: %d%%', code: 'CDK_TOOLKIT_I001' }, ratio) // specifies info code `CDK_TOOLKIT_I001`
178
+ * ```
179
+ */
180
+ const debug = (input, ...args) => {
181
+ return formatMessageAndLog('debug', false, input, undefined, ...args);
182
+ };
154
183
  exports.debug = debug;
155
- const trace = (fmt, ...args) => log({
156
- level: LogLevel.TRACE,
157
- message: util.format(fmt, ...args),
158
- timestamp: true,
159
- });
184
+ /**
185
+ * Logs a trace level message.
186
+ *
187
+ * Can be used in multiple ways:
188
+ * ```ts
189
+ * trace(`entered ${name} with ${args}`) // infers default info code `CDK_TOOLKIT_I000`
190
+ * trace('method: %s, args: %j', name, args) // infers default info code `CDK_TOOLKIT_I000`
191
+ * trace({ message: 'entered', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`
192
+ * trace({ message: 'method: %s', code: 'CDK_TOOLKIT_I001' }, name) // specifies info code `CDK_TOOLKIT_I001`
193
+ * ```
194
+ */
195
+ const trace = (input, ...args) => {
196
+ return formatMessageAndLog('trace', false, input, undefined, ...args);
197
+ };
160
198
  exports.trace = trace;
161
- const success = (fmt, ...args) => log({
162
- level: LogLevel.INFO,
163
- message: util.format(fmt, ...args),
164
- style: chalk.green,
165
- });
199
+ /**
200
+ * Logs an info level success message in green text.
201
+ *
202
+ * Can be used in multiple ways:
203
+ * ```ts
204
+ * success(`deployment completed: ${name}`) // infers default info code `CDK_TOOLKIT_I000`
205
+ * success('processed %d items', count) // infers default info code `CDK_TOOLKIT_I000`
206
+ * success({ message: 'completed', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`
207
+ * success({ message: 'items: %d', code: 'CDK_TOOLKIT_I001' }, count) // specifies info code `CDK_TOOLKIT_I001`
208
+ * ```
209
+ */
210
+ const success = (input, ...args) => {
211
+ return formatMessageAndLog('info', false, input, chalk.green, ...args);
212
+ };
166
213
  exports.success = success;
167
- const highlight = (fmt, ...args) => log({
168
- level: LogLevel.INFO,
169
- message: util.format(fmt, ...args),
170
- style: chalk.bold,
171
- });
172
- exports.highlight = highlight;
173
214
  /**
174
- * Creates a logging function that prepends a prefix to all messages.
175
- * @param prefixString - String to prepend to all messages
176
- * @param level - Log level to use (defaults to INFO)
177
- * @returns Logging function that accepts format string and arguments
215
+ * Logs an info level message in bold text.
216
+ *
217
+ * Can be used in multiple ways:
218
+ * ```ts
219
+ * highlight(`important: ${msg}`) // infers default info code `CDK_TOOLKIT_I000`
220
+ * highlight('attention required: %s', reason) // infers default info code `CDK_TOOLKIT_I000`
221
+ * highlight({ message: 'notice', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`
222
+ * highlight({ message: 'notice: %s', code: 'CDK_TOOLKIT_I001' }, msg) // specifies info code `CDK_TOOLKIT_I001`
223
+ * ```
178
224
  */
179
- function prefix(prefixString, level = LogLevel.INFO) {
180
- return (fmt, ...args) => log({
181
- level,
182
- message: util.format(fmt, ...args),
183
- prefix: prefixString,
184
- });
185
- }
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.js","sourceRoot":"","sources":["logging.ts"],"names":[],"mappings":"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","sourcesContent":["import { Writable } from 'stream';\nimport * as util from 'util';\nimport * as chalk from 'chalk';\n\n/**\n * Available log levels in order of increasing verbosity.\n */\nexport enum LogLevel {\n  ERROR = 'error',\n  WARN = 'warn',\n  INFO = 'info',\n  DEBUG = 'debug',\n  TRACE = 'trace',\n}\n\n/**\n * Configuration options for a log entry.\n */\nexport interface LogEntry {\n  level: LogLevel;\n  message: string;\n  timestamp?: boolean;\n  prefix?: string;\n  style?: ((str: string) => string);\n  forceStdout?: boolean;\n}\n\nconst { stdout, stderr } = process;\n\n// Corking mechanism\nlet CORK_COUNTER = 0;\nconst logBuffer: [Writable, string][] = [];\n\n// Style mappings\nconst styleMap: Record<LogLevel, (str: string) => string> = {\n  [LogLevel.ERROR]: chalk.red,\n  [LogLevel.WARN]: chalk.yellow,\n  [LogLevel.INFO]: chalk.white,\n  [LogLevel.DEBUG]: chalk.gray,\n  [LogLevel.TRACE]: chalk.gray,\n};\n\n// Stream selection\nlet CI = false;\n\n/**\n * Determines which output stream to use based on log level and configuration.\n * @param level - The log level to determine stream for\n * @param forceStdout - Whether to force stdout regardless of level\n * @returns The appropriate Writable stream\n */\nconst getStream = (level: LogLevel, forceStdout?: boolean): Writable => {\n  // Special case - data() calls should always go to stdout\n  if (forceStdout) {\n    return stdout;\n  }\n  if (level === LogLevel.ERROR) return stderr;\n  return CI ? stdout : stderr;\n};\n\nconst levelPriority: Record<LogLevel, number> = {\n  [LogLevel.ERROR]: 0,\n  [LogLevel.WARN]: 1,\n  [LogLevel.INFO]: 2,\n  [LogLevel.DEBUG]: 3,\n  [LogLevel.TRACE]: 4,\n};\n\nlet currentLogLevel: LogLevel = LogLevel.INFO;\n\n/**\n * Sets the current log level. Messages with a lower priority level will be filtered out.\n * @param level - The new log level to set\n */\nexport function setLogLevel(level: LogLevel) {\n  currentLogLevel = level;\n}\n\n/**\n * Sets whether the logger is running in CI mode.\n * In CI mode, all non-error output goes to stdout instead of stderr.\n * @param newCI - Whether CI mode should be enabled\n */\nexport function setCI(newCI: boolean) {\n  CI = newCI;\n}\n\n/**\n * Formats a date object into a timestamp string (HH:MM:SS).\n * @param d - Date object to format\n * @returns Formatted time string\n */\nfunction formatTime(d: Date): string {\n  const pad = (n: number): string => n.toString().padStart(2, '0');\n  return `${pad(d.getHours())}:${pad(d.getMinutes())}:${pad(d.getSeconds())}`;\n}\n\n/**\n * Executes a block of code with corked logging. All log messages during execution\n * are buffered and only written after the block completes.\n * @param block - Async function to execute with corked logging\n * @returns Promise that resolves with the block's return value\n */\nexport async function withCorkedLogging<T>(block: () => Promise<T>): Promise<T> {\n  CORK_COUNTER++;\n  try {\n    return await block();\n  } finally {\n    CORK_COUNTER--;\n    if (CORK_COUNTER === 0) {\n      logBuffer.forEach(([stream, str]) => stream.write(str + '\\n'));\n      logBuffer.splice(0);\n    }\n  }\n}\n\n/**\n * Core logging function that handles all log output.\n * @param entry - LogEntry object or log level\n * @param fmt - Format string (when using with log level)\n * @param args - Format arguments (when using with log level)\n */\nexport function log(entry: LogEntry): void;\nexport function log(level: LogLevel, fmt: string, ...args: unknown[]): void;\nexport function log(levelOrEntry: LogLevel | LogEntry, fmt?: string, ...args: unknown[]): void {\n  // Normalize input\n  const entry: LogEntry = typeof levelOrEntry === 'string'\n    ? { level: levelOrEntry as LogLevel, message: util.format(fmt!, ...args) }\n    : levelOrEntry;\n\n  // Check if we should log this level\n  if (levelPriority[entry.level] > levelPriority[currentLogLevel]) {\n    return;\n  }\n\n  // Format the message\n  let finalMessage = entry.message;\n\n  // Add timestamp first if requested\n  if (entry.timestamp) {\n    finalMessage = `[${formatTime(new Date())}] ${finalMessage}`;\n  }\n\n  // Add prefix AFTER timestamp\n  if (entry.prefix) {\n    finalMessage = `${entry.prefix} ${finalMessage}`;\n  }\n\n  // Apply custom style if provided, otherwise use level-based style\n  const style = entry.style || styleMap[entry.level];\n  finalMessage = style(finalMessage);\n\n  // Get appropriate stream - pass through forceStdout flag\n  const stream = getStream(entry.level, entry.forceStdout);\n\n  // Handle corking\n  if (CORK_COUNTER > 0) {\n    logBuffer.push([stream, finalMessage]);\n    return;\n  }\n\n  // Write to stream\n  stream.write(finalMessage + '\\n');\n}\n\n// Convenience logging methods\nexport const error = (fmt: string, ...args: unknown[]) => log(LogLevel.ERROR, fmt, ...args);\nexport const warning = (fmt: string, ...args: unknown[]) => log(LogLevel.WARN, fmt, ...args);\nexport const info = (fmt: string, ...args: unknown[]) => log(LogLevel.INFO, fmt, ...args);\nexport const print = (fmt: string, ...args: unknown[]) => log(LogLevel.INFO, fmt, ...args);\nexport const data = (fmt: string, ...args: unknown[]) => log({\n  level: LogLevel.INFO,\n  message: util.format(fmt, ...args),\n  forceStdout: true,\n});\nexport const debug = (fmt: string, ...args: unknown[]) => log({\n  level: LogLevel.DEBUG,\n  message: util.format(fmt, ...args),\n  timestamp: true,\n});\n\nexport const trace = (fmt: string, ...args: unknown[]) => log({\n  level: LogLevel.TRACE,\n  message: util.format(fmt, ...args),\n  timestamp: true,\n});\n\nexport const success = (fmt: string, ...args: unknown[]) => log({\n  level: LogLevel.INFO,\n  message: util.format(fmt, ...args),\n  style: chalk.green,\n});\n\nexport const highlight = (fmt: string, ...args: unknown[]) => log({\n  level: LogLevel.INFO,\n  message: util.format(fmt, ...args),\n  style: chalk.bold,\n});\n\n/**\n * Creates a logging function that prepends a prefix to all messages.\n * @param prefixString - String to prepend to all messages\n * @param level - Log level to use (defaults to INFO)\n * @returns Logging function that accepts format string and arguments\n */\nexport function prefix(prefixString: string, level: LogLevel = LogLevel.INFO): (fmt: string, ...args: unknown[]) => void {\n  return (fmt: string, ...args: unknown[]) => log({\n    level,\n    message: util.format(fmt, ...args),\n    prefix: prefixString,\n  });\n}\n"]}
225
+ const highlight = (input, ...args) => {
226
+ return formatMessageAndLog('info', false, input, chalk.bold, ...args);
227
+ };
228
+ exports.highlight = highlight;
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.js","sourceRoot":"","sources":["logging.ts"],"names":[],"mappings":"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","sourcesContent":["import * as util from 'util';\nimport * as chalk from 'chalk';\nimport { IoMessageLevel, IoMessage, CliIoHost, IoMessageSpecificCode, IoMessageCode, IoMessageCodeCategory, IoCodeLevel } from './toolkit/cli-io-host';\n\n// Corking mechanism\nlet CORK_COUNTER = 0;\nconst logBuffer: IoMessage[] = [];\n\nconst levelPriority: Record<IoMessageLevel, number> = {\n  error: 0,\n  warn: 1,\n  info: 2,\n  debug: 3,\n  trace: 4,\n};\n\nlet currentIoMessageThreshold: IoMessageLevel = 'info';\n\n/**\n * Sets the current threshold. Messages with a lower priority level will be ignored.\n * @param level The new log level threshold\n */\nexport function setIoMessageThreshold(level: IoMessageLevel) {\n  currentIoMessageThreshold = level;\n}\n\n/**\n * Sets whether the logger is running in CI mode.\n * In CI mode, all non-error output goes to stdout instead of stderr.\n * @param newCI - Whether CI mode should be enabled\n */\nexport function setCI(newCI: boolean) {\n  CliIoHost.ci = newCI;\n}\n\n/**\n * Executes a block of code with corked logging. All log messages during execution\n * are buffered and only written when all nested cork blocks complete (when CORK_COUNTER reaches 0).\n * @param block - Async function to execute with corked logging\n * @returns Promise that resolves with the block's return value\n */\nexport async function withCorkedLogging<T>(block: () => Promise<T>): Promise<T> {\n  CORK_COUNTER++;\n  try {\n    return await block();\n  } finally {\n    CORK_COUNTER--;\n    if (CORK_COUNTER === 0) {\n      // Process each buffered message through notify\n      for (const ioMessage of logBuffer) {\n        void CliIoHost.getIoHost().notify(ioMessage);\n      }\n      logBuffer.splice(0);\n    }\n  }\n}\n\ninterface LogOptions {\n  /**\n   * The log level to use\n   */\n  readonly level: IoMessageLevel;\n  /**\n   * The message to log\n   */\n  readonly message: string;\n  /**\n   * Whether to force stdout\n   * @default false\n   */\n  readonly forceStdout?: boolean;\n  /**\n   * Message code of the format [CATEGORY]_[NUMBER_CODE]\n   * @pattern [A-Z]+_[0-2][0-9]{3}\n   * @default TOOLKIT_[0/1/2]000\n   */\n  readonly code: IoMessageCode;\n}\n\n/**\n * Internal core logging function that writes messages through the CLI IO host.\n * @param options Configuration options for the log message. See  {@link LogOptions}\n */\nfunction log(options: LogOptions) {\n  if (levelPriority[options.level] > levelPriority[currentIoMessageThreshold]) {\n    return;\n  }\n\n  const ioMessage: IoMessage = {\n    level: options.level,\n    message: options.message,\n    forceStdout: options.forceStdout,\n    time: new Date(),\n    action: CliIoHost.currentAction ?? 'none',\n    code: options.code,\n  };\n\n  if (CORK_COUNTER > 0) {\n    logBuffer.push(ioMessage);\n    return;\n  }\n\n  void CliIoHost.getIoHost().notify(ioMessage);\n}\n\n/**\n * Internal helper that processes log inputs into a consistent format.\n * Handles string interpolation, format strings, and object parameter styles.\n * Applies optional styling and prepares the final message for logging.\n */\nfunction formatMessageAndLog(\n  level: IoMessageLevel,\n  forceStdout: boolean,\n  input: LogInput<IoCodeLevel>,\n  style?: (str: string) => string,\n  ...args: unknown[]\n): void {\n  // Extract message and code from input, using new default code format\n  const { message, code = getDefaultCode(level) } = typeof input === 'object' ? input : { message: input };\n\n  // Format message if args are provided\n  const formattedMessage = args.length > 0\n    ? util.format(message, ...args)\n    : message;\n\n  // Apply style if provided\n  const finalMessage = style ? style(formattedMessage) : formattedMessage;\n\n  log({\n    level,\n    message: finalMessage,\n    code,\n    forceStdout,\n  });\n}\n\nfunction getDefaultCode(level: IoMessageLevel, category: IoMessageCodeCategory = 'TOOLKIT'): IoMessageCode {\n  const levelIndicator = level === 'error' ? 'E' :\n    level === 'warn' ? 'W' :\n      'I';\n  return `CDK_${category}_${levelIndicator}0000`;\n}\n\n// Type for the object parameter style\ninterface LogParams<L extends IoCodeLevel> {\n  /**\n   * @see {@link IoMessage.code}\n   */\n  readonly code?: IoMessageSpecificCode<L>;\n  /**\n   * @see {@link IoMessage.message}\n   */\n  readonly message: string;\n}\n\n// Type for the exported log function arguments\ntype LogInput<L extends IoCodeLevel> = string | LogParams<L>;\n\n// Exported logging functions. If any additional logging functionality is required, it should be added as\n// a new logging function here.\n\n/**\n * Logs an error level message.\n *\n * Can be used in multiple ways:\n * ```ts\n * error(`operation failed: ${e}`) // infers default error code `CDK_TOOLKIT_E000`\n * error('operation failed: %s', e) // infers default error code `CDK_TOOLKIT_E000`\n * error({ message: 'operation failed', code: 'CDK_SDK_E001' }) // specifies error code `CDK_SDK_E001`\n * error({ message: 'operation failed: %s', code: 'CDK_SDK_E001' }, e) // specifies error code `CDK_SDK_E001`\n * ```\n */\nexport const error = (input: LogInput<'E'>, ...args: unknown[]) => {\n  return formatMessageAndLog('error', false, input, undefined, ...args);\n};\n\n/**\n * Logs an warning level message.\n *\n * Can be used in multiple ways:\n * ```ts\n * warning(`deprected feature: ${message}`) // infers default warning code `CDK_TOOLKIT_W000`\n * warning('deprected feature: %s', message) // infers default warning code `CDK_TOOLKIT_W000`\n * warning({ message: 'deprected feature', code: 'CDK_SDK_W001' }) // specifies warning code `CDK_SDK_W001`\n * warning({ message: 'deprected feature: %s', code: 'CDK_SDK_W001' }, message) // specifies warning code `CDK_SDK_W001`\n * ```\n */\nexport const warning = (input: LogInput<'W'>, ...args: unknown[]) => {\n  return formatMessageAndLog('warn', false, input, undefined, ...args);\n};\n\n/**\n * Logs an info level message.\n *\n * Can be used in multiple ways:\n * ```ts\n * info(`processing: ${message}`) // infers default info code `CDK_TOOLKIT_I000`\n * info('processing: %s', message) // infers default info code `CDK_TOOLKIT_I000`\n * info({ message: 'processing', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`\n * info({ message: 'processing: %s', code: 'CDK_TOOLKIT_I001' }, message) // specifies info code `CDK_TOOLKIT_I001`\n * ```\n */\nexport const info = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('info', false, input, undefined, ...args);\n};\n\n/**\n * Logs an info level message to stdout.\n *\n * Can be used in multiple ways:\n * ```ts\n * data(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`\n * data('{\"count\": %d}', count) // infers default info code `CDK_TOOLKIT_I000`\n * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`\n * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`\n * ```\n */\nexport const data = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('info', true, input, undefined, ...args);\n};\n\n/**\n * Logs a debug level message.\n *\n * Can be used in multiple ways:\n * ```ts\n * debug(`state: ${JSON.stringify(state)}`) // infers default info code `CDK_TOOLKIT_I000`\n * debug('cache hit ratio: %d%%', ratio) // infers default info code `CDK_TOOLKIT_I000`\n * debug({ message: 'state update', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`\n * debug({ message: 'ratio: %d%%', code: 'CDK_TOOLKIT_I001' }, ratio) // specifies info code `CDK_TOOLKIT_I001`\n * ```\n */\nexport const debug = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('debug', false, input, undefined, ...args);\n};\n\n/**\n * Logs a trace level message.\n *\n * Can be used in multiple ways:\n * ```ts\n * trace(`entered ${name} with ${args}`) // infers default info code `CDK_TOOLKIT_I000`\n * trace('method: %s, args: %j', name, args) // infers default info code `CDK_TOOLKIT_I000`\n * trace({ message: 'entered', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`\n * trace({ message: 'method: %s', code: 'CDK_TOOLKIT_I001' }, name) // specifies info code `CDK_TOOLKIT_I001`\n * ```\n */\nexport const trace = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('trace', false, input, undefined, ...args);\n};\n\n/**\n * Logs an info level success message in green text.\n *\n * Can be used in multiple ways:\n * ```ts\n * success(`deployment completed: ${name}`) // infers default info code `CDK_TOOLKIT_I000`\n * success('processed %d items', count) // infers default info code `CDK_TOOLKIT_I000`\n * success({ message: 'completed', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`\n * success({ message: 'items: %d', code: 'CDK_TOOLKIT_I001' }, count) // specifies info code `CDK_TOOLKIT_I001`\n * ```\n */\nexport const success = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('info', false, input, chalk.green, ...args);\n};\n\n/**\n * Logs an info level message in bold text.\n *\n * Can be used in multiple ways:\n * ```ts\n * highlight(`important: ${msg}`) // infers default info code `CDK_TOOLKIT_I000`\n * highlight('attention required: %s', reason) // infers default info code `CDK_TOOLKIT_I000`\n * highlight({ message: 'notice', code: 'CDK_TOOLKIT_I001' }) // specifies info code `CDK_TOOLKIT_I001`\n * highlight({ message: 'notice: %s', code: 'CDK_TOOLKIT_I001' }, msg) // specifies info code `CDK_TOOLKIT_I001`\n * ```\n */\nexport const highlight = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('info', false, input, chalk.bold, ...args);\n};\n"]}