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.
- package/CONTRIBUTING.md +4 -4
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/api/aws-auth/credential-plugins.js +5 -5
- package/lib/api/aws-auth/sdk-provider.js +3 -2
- package/lib/api/aws-auth/sdk.js +3 -2
- package/lib/api/cxapp/cloud-assembly.js +4 -4
- package/lib/api/deploy-stack.js +11 -10
- package/lib/api/deployments.js +4 -4
- package/lib/api/environment-access.js +3 -2
- package/lib/api/environment-resources.js +3 -2
- package/lib/api/garbage-collection/garbage-collector.js +9 -9
- package/lib/api/garbage-collection/progress-printer.js +3 -3
- package/lib/api/hotswap-deployments.js +11 -10
- package/lib/api/logs/find-cloudwatch-logs.js +3 -2
- package/lib/api/logs/logs-monitor.js +3 -3
- package/lib/api/nested-stack-helpers.js +3 -2
- package/lib/api/plugin/plugin.js +1 -1
- package/lib/api/util/cloudformation/stack-activity-monitor.d.ts +4 -4
- package/lib/api/util/cloudformation/stack-activity-monitor.js +9 -9
- package/lib/api/util/cloudformation/stack-event-poller.js +3 -2
- package/lib/api/util/cloudformation.js +3 -3
- package/lib/cdk-toolkit.d.ts +0 -1
- package/lib/cdk-toolkit.js +32 -76
- package/lib/cli.js +12 -7
- package/lib/commands/context.js +20 -20
- package/lib/commands/docs.js +2 -2
- package/lib/commands/doctor.js +9 -9
- package/lib/commands/migrate.js +16 -16
- package/lib/config.d.ts +6 -3
- package/lib/config.js +10 -7
- package/lib/context-providers/ami.js +2 -2
- package/lib/context-providers/index.js +3 -2
- package/lib/convert-to-user-input.d.ts +3 -0
- package/lib/convert-to-user-input.js +431 -0
- package/lib/diff.js +3 -3
- package/lib/import.js +6 -6
- package/lib/index.js +50 -35
- package/lib/init-hooks.js +3 -2
- package/lib/init-templates/.init-version.json +1 -1
- package/lib/init-templates/.recommended-feature-flags.json +2 -1
- package/lib/init-templates/app/csharp/src/%name.PascalCased%/%name.PascalCased%.template.csproj +1 -1
- package/lib/init-templates/app/fsharp/src/%name.PascalCased%/%name.PascalCased%.template.fsproj +1 -1
- package/lib/init-templates/sample-app/csharp/src/%name.PascalCased%/%name.PascalCased%.template.csproj +1 -1
- package/lib/init-templates/sample-app/fsharp/src/%name.PascalCased%/%name.PascalCased%.template.fsproj +1 -1
- package/lib/init.d.ts +1 -1
- package/lib/init.js +20 -19
- package/lib/logging.d.ts +112 -48
- package/lib/logging.js +176 -133
- package/lib/notices.js +13 -12
- package/lib/parse-command-line-arguments.js +2 -2
- package/lib/settings.d.ts +2 -0
- package/lib/settings.js +3 -1
- package/lib/toolkit/cli-io-host.d.ts +56 -25
- package/lib/toolkit/cli-io-host.js +49 -22
- package/lib/toolkit/error.js +2 -2
- package/lib/{cli-arguments.d.ts → user-input.d.ts} +8 -8
- package/lib/user-input.js +3 -0
- package/lib/util/archive.js +3 -2
- package/lib/util/asset-publishing.js +3 -3
- package/lib/util/error.d.ts +9 -0
- package/lib/util/error.js +22 -0
- package/lib/version.js +2 -2
- package/package.json +12 -11
- package/scripts/user-input-gen +2 -0
- package/scripts/user-input-gen.js +17 -0
- package/test/api/exec.test.js +3 -3
- package/test/api/fake-sts.js +3 -2
- package/test/api/logs/logging.test.js +269 -0
- package/test/api/sdk-provider.test.js +3 -3
- package/test/api/stack-activity-monitor.test.js +16 -16
- package/test/api/util/error.test.d.ts +1 -0
- package/test/api/util/error.test.js +26 -0
- package/test/cdk-toolkit.test.js +1 -46
- package/test/cli-arguments.test.js +126 -81
- package/test/cli.test.js +8 -8
- package/test/init.test.js +5 -5
- package/test/jest-bufferedconsole.d.ts +14 -0
- package/test/jest-bufferedconsole.js +72 -0
- package/test/notices.test.js +14 -14
- package/test/toolkit/cli-io-host.test.js +93 -188
- package/test/util/silent.js +2 -2
- package/test/version.test.js +5 -5
- package/lib/cli-arguments.js +0 -3
- package/lib/convert-to-cli-args.d.ts +0 -2
- package/lib/convert-to-cli-args.js +0 -234
- package/scripts/cli-args-gen +0 -2
- package/scripts/cli-args-gen.js +0 -16
- package/test/api/logs/cli-logging.test.js +0 -135
- /package/scripts/{cli-args-gen.d.ts → user-input-gen.d.ts} +0 -0
- /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.
|
|
4
|
-
exports.
|
|
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
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
14
|
+
error: 0,
|
|
15
|
+
warn: 1,
|
|
16
|
+
info: 2,
|
|
17
|
+
debug: 3,
|
|
18
|
+
trace: 4,
|
|
57
19
|
};
|
|
58
|
-
let
|
|
20
|
+
let currentIoMessageThreshold = 'info';
|
|
59
21
|
/**
|
|
60
|
-
* Sets the current
|
|
61
|
-
* @param level
|
|
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
|
|
64
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
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
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
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(
|
|
75
|
+
logBuffer.push(ioMessage);
|
|
129
76
|
return;
|
|
130
77
|
}
|
|
131
|
-
|
|
132
|
-
|
|
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
|
-
//
|
|
135
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
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
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
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
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
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
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
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
|
-
*
|
|
175
|
-
*
|
|
176
|
-
*
|
|
177
|
-
*
|
|
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
|
-
|
|
180
|
-
return (
|
|
181
|
-
|
|
182
|
-
|
|
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"]}
|