aws-cdk 2.177.0 → 2.178.1
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/THIRD_PARTY_LICENSES +5518 -181
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/api/aws-auth/sdk-logger.d.ts +4 -0
- package/lib/api/aws-auth/sdk-logger.js +18 -7
- package/lib/api/aws-auth/sdk-provider.js +4 -3
- package/lib/api/aws-auth/sdk.d.ts +1 -0
- package/lib/api/aws-auth/sdk.js +4 -3
- package/lib/api/aws-auth/tracing.d.ts +11 -0
- package/lib/api/aws-auth/tracing.js +60 -0
- package/lib/api/deployments/asset-publishing.js +7 -1
- package/lib/cli/cdk-toolkit.d.ts +6 -0
- package/lib/cli/cdk-toolkit.js +11 -10
- package/lib/cli/cli.js +10 -5
- package/lib/cli/parse-command-line-arguments.js +11 -15
- package/lib/cli/user-input.d.ts +4 -4
- package/lib/cli/user-input.js +1 -1
- package/lib/commands/context.js +2 -2
- package/lib/index.js +204 -158
- package/lib/index_bg.wasm +0 -0
- package/lib/init-templates/.init-version.json +1 -1
- package/lib/init-templates/.recommended-feature-flags.json +2 -1
- package/lib/legacy-exports-source.d.ts +1 -1
- package/lib/legacy-exports-source.js +3 -3
- package/lib/logging.d.ts +6 -13
- package/lib/logging.js +25 -70
- package/lib/toolkit/cli-io-host.d.ts +16 -12
- package/lib/toolkit/cli-io-host.js +127 -30
- package/package.json +10 -10
- package/test/_helpers/prompts.d.ts +11 -0
- package/test/_helpers/prompts.js +22 -0
- package/test/api/aws-auth/sdk-logger.test.js +16 -11
- package/test/api/logs/logging.test.js +4 -54
- package/test/cli/cdk-toolkit.test.js +7 -7
- package/test/cli/cli-arguments.test.js +4 -4
- package/test/cli/cli.test.js +2 -2
- package/test/cli/user-config.test.js +28 -1
- package/test/toolkit/cli-io-host-corked.test.d.ts +1 -0
- package/test/toolkit/cli-io-host-corked.test.js +73 -0
- package/test/toolkit/cli-io-host.test.js +164 -60
- package/lib/util/tracing.d.ts +0 -9
- package/lib/util/tracing.js +0 -58
package/lib/index_bg.wasm
CHANGED
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"aws-cdk-lib": "2.
|
|
1
|
+
{"aws-cdk-lib": "2.178.1", "constructs": "^10.0.0"}
|
|
@@ -63,5 +63,6 @@
|
|
|
63
63
|
"@aws-cdk/aws-ec2:bastionHostUseAmazonLinux2023ByDefault": true,
|
|
64
64
|
"@aws-cdk/aws-route53-targets:userPoolDomainNameMethodWithoutCustomResource": true,
|
|
65
65
|
"@aws-cdk/aws-elasticloadbalancingV2:albDualstackWithoutPublicIpv4SecurityGroupRulesDefault": true,
|
|
66
|
-
"@aws-cdk/aws-iam:oidcRejectUnauthorizedConnections": true
|
|
66
|
+
"@aws-cdk/aws-iam:oidcRejectUnauthorizedConnections": true,
|
|
67
|
+
"@aws-cdk/core:enableAdditionalMetadataCollection": true
|
|
67
68
|
}
|
|
@@ -13,7 +13,7 @@ export { execProgram } from './api/cxapp/exec';
|
|
|
13
13
|
export { RequireApproval } from './diff';
|
|
14
14
|
export { leftPad } from './api/util/string-manipulation';
|
|
15
15
|
export { formatAsBanner } from './cli/util/console-formatters';
|
|
16
|
-
export { enableTracing } from './
|
|
16
|
+
export { setSdkTracing as enableTracing } from './api/aws-auth/tracing';
|
|
17
17
|
export { aliases, command, describe } from './commands/docs';
|
|
18
18
|
export { lowerCaseFirstCharacter } from './api/hotswap/common';
|
|
19
19
|
export { deepMerge } from './util/objects';
|
|
@@ -58,8 +58,8 @@ var string_manipulation_1 = require("./api/util/string-manipulation");
|
|
|
58
58
|
Object.defineProperty(exports, "leftPad", { enumerable: true, get: function () { return string_manipulation_1.leftPad; } });
|
|
59
59
|
var console_formatters_1 = require("./cli/util/console-formatters");
|
|
60
60
|
Object.defineProperty(exports, "formatAsBanner", { enumerable: true, get: function () { return console_formatters_1.formatAsBanner; } });
|
|
61
|
-
var tracing_1 = require("./
|
|
62
|
-
Object.defineProperty(exports, "enableTracing", { enumerable: true, get: function () { return tracing_1.
|
|
61
|
+
var tracing_1 = require("./api/aws-auth/tracing");
|
|
62
|
+
Object.defineProperty(exports, "enableTracing", { enumerable: true, get: function () { return tracing_1.setSdkTracing; } });
|
|
63
63
|
var docs_1 = require("./commands/docs");
|
|
64
64
|
Object.defineProperty(exports, "aliases", { enumerable: true, get: function () { return docs_1.aliases; } });
|
|
65
65
|
Object.defineProperty(exports, "command", { enumerable: true, get: function () { return docs_1.command; } });
|
|
@@ -85,4 +85,4 @@ var credential_plugins_1 = require("./api/aws-auth/credential-plugins");
|
|
|
85
85
|
Object.defineProperty(exports, "CredentialPlugins", { enumerable: true, get: function () { return credential_plugins_1.CredentialPlugins; } });
|
|
86
86
|
var awscli_compatible_1 = require("./api/aws-auth/awscli-compatible");
|
|
87
87
|
Object.defineProperty(exports, "AwsCliCompatible", { enumerable: true, get: function () { return awscli_compatible_1.AwsCliCompatible; } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVnYWN5LWV4cG9ydHMtc291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGVnYWN5LWV4cG9ydHMtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSw0R0FBNEc7QUFDNUcsMkVBQTJFO0FBQzNFLDBIQUEwSDtBQUMxSCxzRUFBc0U7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRXRFLG9EQUFvRDtBQUNwRCwwREFBd0M7QUFDeEMsK0JBQW9HO0FBQTNGLGlHQUFBLFNBQVMsT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLGlHQUFBLFNBQVMsT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLHNHQUFBLGNBQWMsT0FBQTtBQUFFLGlHQUFBLFNBQVMsT0FBQTtBQUNuRiwrREFBNkQ7QUFBcEQsMkdBQUEsV0FBVyxPQUFBO0FBQ3BCLGlDQUFzQztBQUE3QiwwRkFBQSxHQUFHLE9BQUE7QUFBRSwyRkFBQSxJQUFJLE9BQUE7QUFDbEIsMkNBQTZDO0FBQXBDLHVHQUFBLFdBQVcsT0FBQTtBQUNwQix1Q0FBMEM7QUFBakMsb0dBQUEsVUFBVSxPQUFBO0FBQ25CLG9EQUFrRDtBQUF6QywyR0FBQSxXQUFXLE9BQUE7QUFDcEIsK0RBQW1GO0FBQTFFLDZHQUFBLE9BQU8sT0FBQTtBQUFFLG1IQUFBLGFBQWEsT0FBQTtBQUFFLHFIQUFBLGVBQWUsT0FBQTtBQUNoRCwyQ0FBMEM7QUFBakMsb0dBQUEsUUFBUSxPQUFBO0FBQ2pCLDZDQUErQztBQUF0Qyx5R0FBQSxZQUFZLE9BQUE7QUFDckIsaUVBQStEO0FBQXRELG1IQUFBLGVBQWUsT0FBQTtBQUN4Qix5Q0FBK0M7QUFBdEMsbUdBQUEsV0FBVyxPQUFBO0FBQ3BCLCtCQUF5QztBQUFoQyx1R0FBQSxlQUFlLE9BQUE7QUFDeEIsc0VBQXlEO0FBQWhELDhHQUFBLE9BQU8sT0FBQTtBQUNoQixvRUFBK0Q7QUFBdEQsb0hBQUEsY0FBYyxPQUFBO0FBQ3ZCLGtEQUF3RTtBQUEvRCx3R0FBQSxhQUFhLE9BQWlCO0FBQ3ZDLHdDQUE2RDtBQUFwRCwrRkFBQSxPQUFPLE9BQUE7QUFBRSwrRkFBQSxPQUFPLE9BQUE7QUFBRSxnR0FBQSxRQUFRLE9BQUE7QUFDbkMsK0NBQStEO0FBQXRELGlIQUFBLHVCQUF1QixPQUFBO0FBQ2hDLDBDQUEyQztBQUFsQyxvR0FBQSxTQUFTLE9BQUE7QUFDbEIsaURBQWdEO0FBQXZDLDBHQUFBLFdBQVcsT0FBQTtBQUNwQixrREFBNkM7QUFBcEMsc0dBQUEsT0FBTyxPQUFBO0FBQ2hCLHlDQUFxRTtBQUE1RCxnSEFBQSxxQkFBcUIsT0FBQTtBQUFFLHdHQUFBLGFBQWEsT0FBQTtBQUM3QywrQkFBZ0Q7QUFBdkMsOEdBQUEsc0JBQXNCLE9BQUE7QUFDL0IsZ0RBQStDO0FBQXRDLGdHQUFBLE1BQU0sT0FBQTtBQUNmLDJGQUFnRjtBQUF2RSwwSUFBQSxzQkFBc0IsT0FBQTtBQUMvQix3RUFBc0U7QUFBN0QsdUhBQUEsaUJBQWlCLE9BQUE7QUFDMUIsc0VBQW9FO0FBQTNELHFIQUFBLGdCQUFnQixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBpcyBhIGJhcnJlbCBleHBvcnQgZmlsZSwgb2YgYWxsIGtub3duIHN5bWJvbHMgdGhhdCBhcmUgaW1wb3J0ZWQgYnkgdXNlcnMgZnJvbSB0aGUgYGF3cy1jZGtgIHBhY2thZ2UuXG4vLyBJbXBvcnRpbmcgdGhlc2Ugc3ltYm9scyB3YXMgbmV2ZXIgb2ZmaWNpYWxseSBzdXBwb3J0ZWQsIGJ1dCBoZXJlIHdlIGFyZS5cbi8vIEluIG9yZGVyIHRvIHByZXNlcnZlciBiYWNrd2FyZHMtY29tcGF0aWJseSBmb3IgdGhlc2UgdXNlcnMsIHdlIHJlLWV4cG9ydCBhbmQgcHJlc2VydmUgdGhlbSBhcyBleHBsaWNpdCBzdWJwYXRoIGV4cG9ydHMuXG4vLyBTZWUgaHR0cHM6Ly9naXRodWIuY29tL2F3cy9hd3MtY2RrL3B1bGwvMzMwMjEgZm9yIG1vcmUgaW5mb3JtYXRpb24uXG5cbi8vIE5vdGU6IEFsbCB0eXBlIGV4cG9ydHMgYXJlIGluIGBsZWdhY3ktZXhwb3J0cy50c2BcbmV4cG9ydCAqIGZyb20gJy4vbGVnYWN5LWxvZ2dpbmctc291cmNlJztcbmV4cG9ydCB7IGRlZXBDbG9uZSwgZmxhdHRlbiwgaWZEZWZpbmVkLCBpc0FycmF5LCBpc0VtcHR5LCBudW1iZXJGcm9tQm9vbCwgcGFydGl0aW9uIH0gZnJvbSAnLi91dGlsJztcbmV4cG9ydCB7IGRlcGxveVN0YWNrIH0gZnJvbSAnLi9hcGkvZGVwbG95bWVudHMvZGVwbG95LXN0YWNrJztcbmV4cG9ydCB7IGNsaSwgZXhlYyB9IGZyb20gJy4vY2xpL2NsaSc7XG5leHBvcnQgeyBTZGtQcm92aWRlciB9IGZyb20gJy4vYXBpL2F3cy1hdXRoJztcbmV4cG9ydCB7IFBsdWdpbkhvc3QgfSBmcm9tICcuL2FwaS9wbHVnaW4nO1xuZXhwb3J0IHsgY29udGVudEhhc2ggfSBmcm9tICcuL3V0aWwvY29udGVudC1oYXNoJztcbmV4cG9ydCB7IENvbW1hbmQsIENvbmZpZ3VyYXRpb24sIFBST0pFQ1RfQ09OVEVYVCB9IGZyb20gJy4vY2xpL3VzZXItY29uZmlndXJhdGlvbic7XG5leHBvcnQgeyBTZXR0aW5ncyB9IGZyb20gJy4vYXBpL3NldHRpbmdzJztcbmV4cG9ydCB7IEJvb3RzdHJhcHBlciB9IGZyb20gJy4vYXBpL2Jvb3RzdHJhcCc7XG5leHBvcnQgeyBDbG91ZEV4ZWN1dGFibGUgfSBmcm9tICcuL2FwaS9jeGFwcC9jbG91ZC1leGVjdXRhYmxlJztcbmV4cG9ydCB7IGV4ZWNQcm9ncmFtIH0gZnJvbSAnLi9hcGkvY3hhcHAvZXhlYyc7XG5leHBvcnQgeyBSZXF1aXJlQXBwcm92YWwgfSBmcm9tICcuL2RpZmYnO1xuZXhwb3J0IHsgbGVmdFBhZCB9IGZyb20gJy4vYXBpL3V0aWwvc3RyaW5nLW1hbmlwdWxhdGlvbic7XG5leHBvcnQgeyBmb3JtYXRBc0Jhbm5lciB9IGZyb20gJy4vY2xpL3V0aWwvY29uc29sZS1mb3JtYXR0ZXJzJztcbmV4cG9ydCB7IHNldFNka1RyYWNpbmcgYXMgZW5hYmxlVHJhY2luZyB9IGZyb20gJy4vYXBpL2F3cy1hdXRoL3RyYWNpbmcnO1xuZXhwb3J0IHsgYWxpYXNlcywgY29tbWFuZCwgZGVzY3JpYmUgfSBmcm9tICcuL2NvbW1hbmRzL2RvY3MnO1xuZXhwb3J0IHsgbG93ZXJDYXNlRmlyc3RDaGFyYWN0ZXIgfSBmcm9tICcuL2FwaS9ob3Rzd2FwL2NvbW1vbic7XG5leHBvcnQgeyBkZWVwTWVyZ2UgfSBmcm9tICcuL3V0aWwvb2JqZWN0cyc7XG5leHBvcnQgeyBEZXBsb3ltZW50cyB9IGZyb20gJy4vYXBpL2RlcGxveW1lbnRzJztcbmV4cG9ydCB7IHJvb3REaXIgfSBmcm9tICcuL3V0aWwvZGlyZWN0b3JpZXMnO1xuZXhwb3J0IHsgbGF0ZXN0VmVyc2lvbklmSGlnaGVyLCB2ZXJzaW9uTnVtYmVyIH0gZnJvbSAnLi9jbGkvdmVyc2lvbic7XG5leHBvcnQgeyBhdmFpbGFibGVJbml0VGVtcGxhdGVzIH0gZnJvbSAnLi9pbml0JztcbmV4cG9ydCB7IGNhY2hlZCB9IGZyb20gJy4vYXBpL2F3cy1hdXRoL2NhY2hlZCc7XG5leHBvcnQgeyBDZm5FdmFsdWF0aW9uRXhjZXB0aW9uIH0gZnJvbSAnLi9hcGkvZXZhbHVhdGUtY2xvdWRmb3JtYXRpb24tdGVtcGxhdGUnO1xuZXhwb3J0IHsgQ3JlZGVudGlhbFBsdWdpbnMgfSBmcm9tICcuL2FwaS9hd3MtYXV0aC9jcmVkZW50aWFsLXBsdWdpbnMnO1xuZXhwb3J0IHsgQXdzQ2xpQ29tcGF0aWJsZSB9IGZyb20gJy4vYXBpL2F3cy1hdXRoL2F3c2NsaS1jb21wYXRpYmxlJztcbiJdfQ==
|
package/lib/logging.d.ts
CHANGED
|
@@ -1,11 +1,4 @@
|
|
|
1
1
|
import { IoMessageSpecificCode, IoCodeLevel } from './toolkit/cli-io-host';
|
|
2
|
-
/**
|
|
3
|
-
* Executes a block of code with corked logging. All log messages during execution
|
|
4
|
-
* are buffered and only written when all nested cork blocks complete (when CORK_COUNTER reaches 0).
|
|
5
|
-
* @param block - Async function to execute with corked logging
|
|
6
|
-
* @returns Promise that resolves with the block's return value
|
|
7
|
-
*/
|
|
8
|
-
export declare function withCorkedLogging<T>(block: () => Promise<T>): Promise<T>;
|
|
9
2
|
interface LogParams<L extends IoCodeLevel> {
|
|
10
3
|
/**
|
|
11
4
|
* @see {@link IoMessage.code}
|
|
@@ -54,17 +47,17 @@ export declare const warning: (input: LogInput<"W">, ...args: unknown[]) => void
|
|
|
54
47
|
*/
|
|
55
48
|
export declare const info: (input: LogInput<"I">, ...args: unknown[]) => void;
|
|
56
49
|
/**
|
|
57
|
-
* Logs an
|
|
50
|
+
* Logs an result. In the CLI, this always goes to stdout.
|
|
58
51
|
*
|
|
59
52
|
* Can be used in multiple ways:
|
|
60
53
|
* ```ts
|
|
61
|
-
*
|
|
62
|
-
*
|
|
63
|
-
*
|
|
64
|
-
*
|
|
54
|
+
* result(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`
|
|
55
|
+
* result('{"count": %d}', count) // infers default info code `CDK_TOOLKIT_I000`
|
|
56
|
+
* result({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`
|
|
57
|
+
* result({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`
|
|
65
58
|
* ```
|
|
66
59
|
*/
|
|
67
|
-
export declare const
|
|
60
|
+
export declare const result: (input: LogInput<"I">, ...args: unknown[]) => void;
|
|
68
61
|
/**
|
|
69
62
|
* Logs a debug level message.
|
|
70
63
|
*
|
package/lib/logging.js
CHANGED
|
@@ -1,63 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.highlight = exports.success = exports.trace = exports.debug = exports.
|
|
4
|
-
exports.withCorkedLogging = withCorkedLogging;
|
|
3
|
+
exports.highlight = exports.success = exports.trace = exports.debug = exports.result = exports.info = exports.warning = exports.error = void 0;
|
|
5
4
|
const util = require("util");
|
|
6
5
|
const chalk = require("chalk");
|
|
7
6
|
const cli_io_host_1 = require("./toolkit/cli-io-host");
|
|
8
|
-
// Corking mechanism
|
|
9
|
-
let CORK_COUNTER = 0;
|
|
10
|
-
const logBuffer = [];
|
|
11
|
-
/**
|
|
12
|
-
* Executes a block of code with corked logging. All log messages during execution
|
|
13
|
-
* are buffered and only written when all nested cork blocks complete (when CORK_COUNTER reaches 0).
|
|
14
|
-
* @param block - Async function to execute with corked logging
|
|
15
|
-
* @returns Promise that resolves with the block's return value
|
|
16
|
-
*/
|
|
17
|
-
async function withCorkedLogging(block) {
|
|
18
|
-
CORK_COUNTER++;
|
|
19
|
-
try {
|
|
20
|
-
return await block();
|
|
21
|
-
}
|
|
22
|
-
finally {
|
|
23
|
-
CORK_COUNTER--;
|
|
24
|
-
if (CORK_COUNTER === 0) {
|
|
25
|
-
// Process each buffered message through notify
|
|
26
|
-
for (const ioMessage of logBuffer) {
|
|
27
|
-
void cli_io_host_1.CliIoHost.instance().notify(ioMessage);
|
|
28
|
-
}
|
|
29
|
-
logBuffer.splice(0);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Internal core logging function that writes messages through the CLI IO host.
|
|
35
|
-
* @param msg Configuration options for the log message. See {@link LogMessage}
|
|
36
|
-
*/
|
|
37
|
-
function log(msg) {
|
|
38
|
-
const ioMessage = {
|
|
39
|
-
level: msg.level,
|
|
40
|
-
message: msg.message,
|
|
41
|
-
forceStdout: msg.forceStdout,
|
|
42
|
-
time: new Date(),
|
|
43
|
-
action: cli_io_host_1.CliIoHost.instance().currentAction,
|
|
44
|
-
code: msg.code,
|
|
45
|
-
};
|
|
46
|
-
if (CORK_COUNTER > 0) {
|
|
47
|
-
if (cli_io_host_1.levelPriority[msg.level] > cli_io_host_1.levelPriority[cli_io_host_1.CliIoHost.instance().logLevel]) {
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
logBuffer.push(ioMessage);
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
void cli_io_host_1.CliIoHost.instance().notify(ioMessage);
|
|
54
|
-
}
|
|
55
7
|
/**
|
|
56
8
|
* Internal helper that processes log inputs into a consistent format.
|
|
57
9
|
* Handles string interpolation, format strings, and object parameter styles.
|
|
58
|
-
* Applies optional styling and
|
|
10
|
+
* Applies optional styling and sends the message to the IoHost.
|
|
59
11
|
*/
|
|
60
|
-
function formatMessageAndLog(level,
|
|
12
|
+
function formatMessageAndLog(level, input, style, ...args) {
|
|
61
13
|
// Extract message and code from input, using new default code format
|
|
62
14
|
const { message, code = getDefaultCode(level) } = typeof input === 'object' ? input : { message: input };
|
|
63
15
|
// Format message if args are provided
|
|
@@ -66,12 +18,15 @@ function formatMessageAndLog(level, forceStdout, input, style, ...args) {
|
|
|
66
18
|
: message;
|
|
67
19
|
// Apply style if provided
|
|
68
20
|
const finalMessage = style ? style(formattedMessage) : formattedMessage;
|
|
69
|
-
|
|
21
|
+
const ioHost = cli_io_host_1.CliIoHost.instance();
|
|
22
|
+
const ioMessage = {
|
|
23
|
+
time: new Date(),
|
|
24
|
+
action: ioHost.currentAction,
|
|
70
25
|
level,
|
|
71
26
|
message: finalMessage,
|
|
72
27
|
code,
|
|
73
|
-
|
|
74
|
-
|
|
28
|
+
};
|
|
29
|
+
void ioHost.notify(ioMessage);
|
|
75
30
|
}
|
|
76
31
|
function getDefaultCode(level, category = 'TOOLKIT') {
|
|
77
32
|
const levelIndicator = level === 'error' ? 'E' :
|
|
@@ -93,7 +48,7 @@ function getDefaultCode(level, category = 'TOOLKIT') {
|
|
|
93
48
|
* ```
|
|
94
49
|
*/
|
|
95
50
|
const error = (input, ...args) => {
|
|
96
|
-
return formatMessageAndLog('error',
|
|
51
|
+
return formatMessageAndLog('error', input, undefined, ...args);
|
|
97
52
|
};
|
|
98
53
|
exports.error = error;
|
|
99
54
|
/**
|
|
@@ -108,7 +63,7 @@ exports.error = error;
|
|
|
108
63
|
* ```
|
|
109
64
|
*/
|
|
110
65
|
const warning = (input, ...args) => {
|
|
111
|
-
return formatMessageAndLog('warn',
|
|
66
|
+
return formatMessageAndLog('warn', input, undefined, ...args);
|
|
112
67
|
};
|
|
113
68
|
exports.warning = warning;
|
|
114
69
|
/**
|
|
@@ -123,24 +78,24 @@ exports.warning = warning;
|
|
|
123
78
|
* ```
|
|
124
79
|
*/
|
|
125
80
|
const info = (input, ...args) => {
|
|
126
|
-
return formatMessageAndLog('info',
|
|
81
|
+
return formatMessageAndLog('info', input, undefined, ...args);
|
|
127
82
|
};
|
|
128
83
|
exports.info = info;
|
|
129
84
|
/**
|
|
130
|
-
* Logs an
|
|
85
|
+
* Logs an result. In the CLI, this always goes to stdout.
|
|
131
86
|
*
|
|
132
87
|
* Can be used in multiple ways:
|
|
133
88
|
* ```ts
|
|
134
|
-
*
|
|
135
|
-
*
|
|
136
|
-
*
|
|
137
|
-
*
|
|
89
|
+
* result(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`
|
|
90
|
+
* result('{"count": %d}', count) // infers default info code `CDK_TOOLKIT_I000`
|
|
91
|
+
* result({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`
|
|
92
|
+
* result({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`
|
|
138
93
|
* ```
|
|
139
94
|
*/
|
|
140
|
-
const
|
|
141
|
-
return formatMessageAndLog('
|
|
95
|
+
const result = (input, ...args) => {
|
|
96
|
+
return formatMessageAndLog('result', input, undefined, ...args);
|
|
142
97
|
};
|
|
143
|
-
exports.
|
|
98
|
+
exports.result = result;
|
|
144
99
|
/**
|
|
145
100
|
* Logs a debug level message.
|
|
146
101
|
*
|
|
@@ -153,7 +108,7 @@ exports.data = data;
|
|
|
153
108
|
* ```
|
|
154
109
|
*/
|
|
155
110
|
const debug = (input, ...args) => {
|
|
156
|
-
return formatMessageAndLog('debug',
|
|
111
|
+
return formatMessageAndLog('debug', input, undefined, ...args);
|
|
157
112
|
};
|
|
158
113
|
exports.debug = debug;
|
|
159
114
|
/**
|
|
@@ -168,7 +123,7 @@ exports.debug = debug;
|
|
|
168
123
|
* ```
|
|
169
124
|
*/
|
|
170
125
|
const trace = (input, ...args) => {
|
|
171
|
-
return formatMessageAndLog('trace',
|
|
126
|
+
return formatMessageAndLog('trace', input, undefined, ...args);
|
|
172
127
|
};
|
|
173
128
|
exports.trace = trace;
|
|
174
129
|
/**
|
|
@@ -183,7 +138,7 @@ exports.trace = trace;
|
|
|
183
138
|
* ```
|
|
184
139
|
*/
|
|
185
140
|
const success = (input, ...args) => {
|
|
186
|
-
return formatMessageAndLog('info',
|
|
141
|
+
return formatMessageAndLog('info', input, chalk.green, ...args);
|
|
187
142
|
};
|
|
188
143
|
exports.success = success;
|
|
189
144
|
/**
|
|
@@ -198,7 +153,7 @@ exports.success = success;
|
|
|
198
153
|
* ```
|
|
199
154
|
*/
|
|
200
155
|
const highlight = (input, ...args) => {
|
|
201
|
-
return formatMessageAndLog('info',
|
|
156
|
+
return formatMessageAndLog('info', input, chalk.bold, ...args);
|
|
202
157
|
};
|
|
203
158
|
exports.highlight = highlight;
|
|
204
|
-
//# 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, levelPriority } from './toolkit/cli-io-host';\n\n// Corking mechanism\nlet CORK_COUNTER = 0;\nconst logBuffer: IoMessage<any>[] = [];\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.instance().notify(ioMessage);\n      }\n      logBuffer.splice(0);\n    }\n  }\n}\n\ninterface LogMessage {\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 msg Configuration options for the log message. See  {@link LogMessage}\n */\nfunction log(msg: LogMessage) {\n  const ioMessage: IoMessage<undefined> = {\n    level: msg.level,\n    message: msg.message,\n    forceStdout: msg.forceStdout,\n    time: new Date(),\n    action: CliIoHost.instance().currentAction,\n    code: msg.code,\n  };\n\n  if (CORK_COUNTER > 0) {\n    if (levelPriority[msg.level] > levelPriority[CliIoHost.instance().logLevel]) {\n      return;\n    }\n    logBuffer.push(ioMessage);\n    return;\n  }\n\n  void CliIoHost.instance().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"]}
|
|
159
|
+
//# 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/**\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 sends the message to the IoHost.\n */\nfunction formatMessageAndLog(\n  level: IoMessageLevel,\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  const ioHost = CliIoHost.instance();\n  const ioMessage: IoMessage<undefined> = {\n    time: new Date(),\n    action: ioHost.currentAction,\n    level,\n    message: finalMessage,\n    code,\n  };\n\n  void ioHost.notify(ioMessage);\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', 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', 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', input, undefined, ...args);\n};\n\n/**\n * Logs an result. In the CLI, this always goes to stdout.\n *\n * Can be used in multiple ways:\n * ```ts\n * result(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`\n * result('{\"count\": %d}', count) // infers default info code `CDK_TOOLKIT_I000`\n * result({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`\n * result({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`\n * ```\n */\nexport const result = (input: LogInput<'I'>, ...args: unknown[]) => {\n  return formatMessageAndLog('result', 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', 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', 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', 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', input, chalk.bold, ...args);\n};\n"]}
|
|
@@ -40,13 +40,6 @@ export interface IoMessage<T> {
|
|
|
40
40
|
* The message text.
|
|
41
41
|
*/
|
|
42
42
|
readonly message: string;
|
|
43
|
-
/**
|
|
44
|
-
* If true, the message will be written to stdout
|
|
45
|
-
* regardless of any other parameters.
|
|
46
|
-
*
|
|
47
|
-
* @default false
|
|
48
|
-
*/
|
|
49
|
-
readonly forceStdout?: boolean;
|
|
50
43
|
/**
|
|
51
44
|
* The data attached to the message.
|
|
52
45
|
*/
|
|
@@ -58,12 +51,12 @@ export interface IoRequest<T, U> extends IoMessage<T> {
|
|
|
58
51
|
*/
|
|
59
52
|
readonly defaultResponse: U;
|
|
60
53
|
}
|
|
61
|
-
export type IoMessageLevel = 'error' | 'warn' | 'info' | 'debug' | 'trace';
|
|
54
|
+
export type IoMessageLevel = 'error' | 'result' | 'warn' | 'info' | 'debug' | 'trace';
|
|
62
55
|
export declare const levelPriority: Record<IoMessageLevel, number>;
|
|
63
56
|
/**
|
|
64
57
|
* The current action being performed by the CLI. 'none' represents the absence of an action.
|
|
65
58
|
*/
|
|
66
|
-
export type ToolkitAction = 'bootstrap' | 'synth' | 'list' | 'diff' | 'deploy' | 'rollback' | 'watch' | 'destroy' | 'context' | 'docs' | 'doctor' | 'gc' | 'import' | 'metadata' | 'notices' | 'init' | 'migrate' | 'version';
|
|
59
|
+
export type ToolkitAction = 'assembly' | 'bootstrap' | 'synth' | 'list' | 'diff' | 'deploy' | 'rollback' | 'watch' | 'destroy' | 'context' | 'docs' | 'doctor' | 'gc' | 'import' | 'metadata' | 'notices' | 'init' | 'migrate' | 'version';
|
|
67
60
|
export interface IIoHost {
|
|
68
61
|
/**
|
|
69
62
|
* Notifies the host of a message.
|
|
@@ -129,6 +122,8 @@ export declare class CliIoHost implements IIoHost {
|
|
|
129
122
|
private _isTTY;
|
|
130
123
|
private _logLevel;
|
|
131
124
|
private _internalIoHost?;
|
|
125
|
+
private corkedCounter;
|
|
126
|
+
private readonly corkedLoggingBuffer;
|
|
132
127
|
private constructor();
|
|
133
128
|
/**
|
|
134
129
|
* Returns the singleton instance
|
|
@@ -172,22 +167,31 @@ export declare class CliIoHost implements IIoHost {
|
|
|
172
167
|
* @param level The new log level threshold
|
|
173
168
|
*/
|
|
174
169
|
set logLevel(level: IoMessageLevel);
|
|
170
|
+
/**
|
|
171
|
+
* Executes a block of code with corked logging. All log messages during execution
|
|
172
|
+
* are buffered and only written when all nested cork blocks complete (when CORK_COUNTER reaches 0).
|
|
173
|
+
* The corking is bound to the specific instance of the CliIoHost.
|
|
174
|
+
*
|
|
175
|
+
* @param block - Async function to execute with corked logging
|
|
176
|
+
* @returns Promise that resolves with the block's return value
|
|
177
|
+
*/
|
|
178
|
+
withCorkedLogging<T>(block: () => Promise<T>): Promise<T>;
|
|
175
179
|
/**
|
|
176
180
|
* Notifies the host of a message.
|
|
177
181
|
* The caller waits until the notification completes.
|
|
178
182
|
*/
|
|
179
183
|
notify<T>(msg: IoMessage<T>): Promise<void>;
|
|
180
184
|
/**
|
|
181
|
-
* Determines
|
|
185
|
+
* Determines the output stream, based on message level and configuration.
|
|
182
186
|
*/
|
|
183
|
-
private
|
|
187
|
+
private selectStream;
|
|
184
188
|
/**
|
|
185
189
|
* Notifies the host of a message that requires a response.
|
|
186
190
|
*
|
|
187
191
|
* If the host does not return a response the suggested
|
|
188
192
|
* default response from the input message will be used.
|
|
189
193
|
*/
|
|
190
|
-
requestResponse<
|
|
194
|
+
requestResponse<DataType, ResponseType>(msg: IoRequest<DataType, ResponseType>): Promise<ResponseType>;
|
|
191
195
|
/**
|
|
192
196
|
* Formats a message for console output with optional color support
|
|
193
197
|
*/
|