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.
Files changed (42) hide show
  1. package/THIRD_PARTY_LICENSES +5518 -181
  2. package/build-info.json +2 -2
  3. package/db.json.gz +0 -0
  4. package/lib/api/aws-auth/sdk-logger.d.ts +4 -0
  5. package/lib/api/aws-auth/sdk-logger.js +18 -7
  6. package/lib/api/aws-auth/sdk-provider.js +4 -3
  7. package/lib/api/aws-auth/sdk.d.ts +1 -0
  8. package/lib/api/aws-auth/sdk.js +4 -3
  9. package/lib/api/aws-auth/tracing.d.ts +11 -0
  10. package/lib/api/aws-auth/tracing.js +60 -0
  11. package/lib/api/deployments/asset-publishing.js +7 -1
  12. package/lib/cli/cdk-toolkit.d.ts +6 -0
  13. package/lib/cli/cdk-toolkit.js +11 -10
  14. package/lib/cli/cli.js +10 -5
  15. package/lib/cli/parse-command-line-arguments.js +11 -15
  16. package/lib/cli/user-input.d.ts +4 -4
  17. package/lib/cli/user-input.js +1 -1
  18. package/lib/commands/context.js +2 -2
  19. package/lib/index.js +204 -158
  20. package/lib/index_bg.wasm +0 -0
  21. package/lib/init-templates/.init-version.json +1 -1
  22. package/lib/init-templates/.recommended-feature-flags.json +2 -1
  23. package/lib/legacy-exports-source.d.ts +1 -1
  24. package/lib/legacy-exports-source.js +3 -3
  25. package/lib/logging.d.ts +6 -13
  26. package/lib/logging.js +25 -70
  27. package/lib/toolkit/cli-io-host.d.ts +16 -12
  28. package/lib/toolkit/cli-io-host.js +127 -30
  29. package/package.json +10 -10
  30. package/test/_helpers/prompts.d.ts +11 -0
  31. package/test/_helpers/prompts.js +22 -0
  32. package/test/api/aws-auth/sdk-logger.test.js +16 -11
  33. package/test/api/logs/logging.test.js +4 -54
  34. package/test/cli/cdk-toolkit.test.js +7 -7
  35. package/test/cli/cli-arguments.test.js +4 -4
  36. package/test/cli/cli.test.js +2 -2
  37. package/test/cli/user-config.test.js +28 -1
  38. package/test/toolkit/cli-io-host-corked.test.d.ts +1 -0
  39. package/test/toolkit/cli-io-host-corked.test.js +73 -0
  40. package/test/toolkit/cli-io-host.test.js +164 -60
  41. package/lib/util/tracing.d.ts +0 -9
  42. package/lib/util/tracing.js +0 -58
package/lib/index_bg.wasm CHANGED
Binary file
@@ -1 +1 @@
1
- {"aws-cdk-lib": "2.177.0", "constructs": "^10.0.0"}
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 './util/tracing';
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("./util/tracing");
62
- Object.defineProperty(exports, "enableTracing", { enumerable: true, get: function () { return tracing_1.enableTracing; } });
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVnYWN5LWV4cG9ydHMtc291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGVnYWN5LWV4cG9ydHMtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSw0R0FBNEc7QUFDNUcsMkVBQTJFO0FBQzNFLDBIQUEwSDtBQUMxSCxzRUFBc0U7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRXRFLG9EQUFvRDtBQUNwRCwwREFBd0M7QUFDeEMsK0JBQW9HO0FBQTNGLGlHQUFBLFNBQVMsT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLGlHQUFBLFNBQVMsT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLHNHQUFBLGNBQWMsT0FBQTtBQUFFLGlHQUFBLFNBQVMsT0FBQTtBQUNuRiwrREFBNkQ7QUFBcEQsMkdBQUEsV0FBVyxPQUFBO0FBQ3BCLGlDQUFzQztBQUE3QiwwRkFBQSxHQUFHLE9BQUE7QUFBRSwyRkFBQSxJQUFJLE9BQUE7QUFDbEIsMkNBQTZDO0FBQXBDLHVHQUFBLFdBQVcsT0FBQTtBQUNwQix1Q0FBMEM7QUFBakMsb0dBQUEsVUFBVSxPQUFBO0FBQ25CLG9EQUFrRDtBQUF6QywyR0FBQSxXQUFXLE9BQUE7QUFDcEIsK0RBQW1GO0FBQTFFLDZHQUFBLE9BQU8sT0FBQTtBQUFFLG1IQUFBLGFBQWEsT0FBQTtBQUFFLHFIQUFBLGVBQWUsT0FBQTtBQUNoRCwyQ0FBMEM7QUFBakMsb0dBQUEsUUFBUSxPQUFBO0FBQ2pCLDZDQUErQztBQUF0Qyx5R0FBQSxZQUFZLE9BQUE7QUFDckIsaUVBQStEO0FBQXRELG1IQUFBLGVBQWUsT0FBQTtBQUN4Qix5Q0FBK0M7QUFBdEMsbUdBQUEsV0FBVyxPQUFBO0FBQ3BCLCtCQUF5QztBQUFoQyx1R0FBQSxlQUFlLE9BQUE7QUFDeEIsc0VBQXlEO0FBQWhELDhHQUFBLE9BQU8sT0FBQTtBQUNoQixvRUFBK0Q7QUFBdEQsb0hBQUEsY0FBYyxPQUFBO0FBQ3ZCLDBDQUErQztBQUF0Qyx3R0FBQSxhQUFhLE9BQUE7QUFDdEIsd0NBQTZEO0FBQXBELCtGQUFBLE9BQU8sT0FBQTtBQUFFLCtGQUFBLE9BQU8sT0FBQTtBQUFFLGdHQUFBLFFBQVEsT0FBQTtBQUNuQywrQ0FBK0Q7QUFBdEQsaUhBQUEsdUJBQXVCLE9BQUE7QUFDaEMsMENBQTJDO0FBQWxDLG9HQUFBLFNBQVMsT0FBQTtBQUNsQixpREFBZ0Q7QUFBdkMsMEdBQUEsV0FBVyxPQUFBO0FBQ3BCLGtEQUE2QztBQUFwQyxzR0FBQSxPQUFPLE9BQUE7QUFDaEIseUNBQXFFO0FBQTVELGdIQUFBLHFCQUFxQixPQUFBO0FBQUUsd0dBQUEsYUFBYSxPQUFBO0FBQzdDLCtCQUFnRDtBQUF2Qyw4R0FBQSxzQkFBc0IsT0FBQTtBQUMvQixnREFBK0M7QUFBdEMsZ0dBQUEsTUFBTSxPQUFBO0FBQ2YsMkZBQWdGO0FBQXZFLDBJQUFBLHNCQUFzQixPQUFBO0FBQy9CLHdFQUFzRTtBQUE3RCx1SEFBQSxpQkFBaUIsT0FBQTtBQUMxQixzRUFBb0U7QUFBM0QscUhBQUEsZ0JBQWdCLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGlzIGEgYmFycmVsIGV4cG9ydCBmaWxlLCBvZiBhbGwga25vd24gc3ltYm9scyB0aGF0IGFyZSBpbXBvcnRlZCBieSB1c2VycyBmcm9tIHRoZSBgYXdzLWNka2AgcGFja2FnZS5cbi8vIEltcG9ydGluZyB0aGVzZSBzeW1ib2xzIHdhcyBuZXZlciBvZmZpY2lhbGx5IHN1cHBvcnRlZCwgYnV0IGhlcmUgd2UgYXJlLlxuLy8gSW4gb3JkZXIgdG8gcHJlc2VydmVyIGJhY2t3YXJkcy1jb21wYXRpYmx5IGZvciB0aGVzZSB1c2Vycywgd2UgcmUtZXhwb3J0IGFuZCBwcmVzZXJ2ZSB0aGVtIGFzIGV4cGxpY2l0IHN1YnBhdGggZXhwb3J0cy5cbi8vIFNlZSBodHRwczovL2dpdGh1Yi5jb20vYXdzL2F3cy1jZGsvcHVsbC8zMzAyMSBmb3IgbW9yZSBpbmZvcm1hdGlvbi5cblxuLy8gTm90ZTogQWxsIHR5cGUgZXhwb3J0cyBhcmUgaW4gYGxlZ2FjeS1leHBvcnRzLnRzYFxuZXhwb3J0ICogZnJvbSAnLi9sZWdhY3ktbG9nZ2luZy1zb3VyY2UnO1xuZXhwb3J0IHsgZGVlcENsb25lLCBmbGF0dGVuLCBpZkRlZmluZWQsIGlzQXJyYXksIGlzRW1wdHksIG51bWJlckZyb21Cb29sLCBwYXJ0aXRpb24gfSBmcm9tICcuL3V0aWwnO1xuZXhwb3J0IHsgZGVwbG95U3RhY2sgfSBmcm9tICcuL2FwaS9kZXBsb3ltZW50cy9kZXBsb3ktc3RhY2snO1xuZXhwb3J0IHsgY2xpLCBleGVjIH0gZnJvbSAnLi9jbGkvY2xpJztcbmV4cG9ydCB7IFNka1Byb3ZpZGVyIH0gZnJvbSAnLi9hcGkvYXdzLWF1dGgnO1xuZXhwb3J0IHsgUGx1Z2luSG9zdCB9IGZyb20gJy4vYXBpL3BsdWdpbic7XG5leHBvcnQgeyBjb250ZW50SGFzaCB9IGZyb20gJy4vdXRpbC9jb250ZW50LWhhc2gnO1xuZXhwb3J0IHsgQ29tbWFuZCwgQ29uZmlndXJhdGlvbiwgUFJPSkVDVF9DT05URVhUIH0gZnJvbSAnLi9jbGkvdXNlci1jb25maWd1cmF0aW9uJztcbmV4cG9ydCB7IFNldHRpbmdzIH0gZnJvbSAnLi9hcGkvc2V0dGluZ3MnO1xuZXhwb3J0IHsgQm9vdHN0cmFwcGVyIH0gZnJvbSAnLi9hcGkvYm9vdHN0cmFwJztcbmV4cG9ydCB7IENsb3VkRXhlY3V0YWJsZSB9IGZyb20gJy4vYXBpL2N4YXBwL2Nsb3VkLWV4ZWN1dGFibGUnO1xuZXhwb3J0IHsgZXhlY1Byb2dyYW0gfSBmcm9tICcuL2FwaS9jeGFwcC9leGVjJztcbmV4cG9ydCB7IFJlcXVpcmVBcHByb3ZhbCB9IGZyb20gJy4vZGlmZic7XG5leHBvcnQgeyBsZWZ0UGFkIH0gZnJvbSAnLi9hcGkvdXRpbC9zdHJpbmctbWFuaXB1bGF0aW9uJztcbmV4cG9ydCB7IGZvcm1hdEFzQmFubmVyIH0gZnJvbSAnLi9jbGkvdXRpbC9jb25zb2xlLWZvcm1hdHRlcnMnO1xuZXhwb3J0IHsgZW5hYmxlVHJhY2luZyB9IGZyb20gJy4vdXRpbC90cmFjaW5nJztcbmV4cG9ydCB7IGFsaWFzZXMsIGNvbW1hbmQsIGRlc2NyaWJlIH0gZnJvbSAnLi9jb21tYW5kcy9kb2NzJztcbmV4cG9ydCB7IGxvd2VyQ2FzZUZpcnN0Q2hhcmFjdGVyIH0gZnJvbSAnLi9hcGkvaG90c3dhcC9jb21tb24nO1xuZXhwb3J0IHsgZGVlcE1lcmdlIH0gZnJvbSAnLi91dGlsL29iamVjdHMnO1xuZXhwb3J0IHsgRGVwbG95bWVudHMgfSBmcm9tICcuL2FwaS9kZXBsb3ltZW50cyc7XG5leHBvcnQgeyByb290RGlyIH0gZnJvbSAnLi91dGlsL2RpcmVjdG9yaWVzJztcbmV4cG9ydCB7IGxhdGVzdFZlcnNpb25JZkhpZ2hlciwgdmVyc2lvbk51bWJlciB9IGZyb20gJy4vY2xpL3ZlcnNpb24nO1xuZXhwb3J0IHsgYXZhaWxhYmxlSW5pdFRlbXBsYXRlcyB9IGZyb20gJy4vaW5pdCc7XG5leHBvcnQgeyBjYWNoZWQgfSBmcm9tICcuL2FwaS9hd3MtYXV0aC9jYWNoZWQnO1xuZXhwb3J0IHsgQ2ZuRXZhbHVhdGlvbkV4Y2VwdGlvbiB9IGZyb20gJy4vYXBpL2V2YWx1YXRlLWNsb3VkZm9ybWF0aW9uLXRlbXBsYXRlJztcbmV4cG9ydCB7IENyZWRlbnRpYWxQbHVnaW5zIH0gZnJvbSAnLi9hcGkvYXdzLWF1dGgvY3JlZGVudGlhbC1wbHVnaW5zJztcbmV4cG9ydCB7IEF3c0NsaUNvbXBhdGlibGUgfSBmcm9tICcuL2FwaS9hd3MtYXV0aC9hd3NjbGktY29tcGF0aWJsZSc7XG4iXX0=
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 info level message to stdout.
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
- * data(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`
62
- * data('{"count": %d}', count) // infers default info code `CDK_TOOLKIT_I000`
63
- * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`
64
- * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`
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 data: (input: LogInput<"I">, ...args: unknown[]) => void;
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.data = exports.info = exports.warning = exports.error = void 0;
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 prepares the final message for logging.
10
+ * Applies optional styling and sends the message to the IoHost.
59
11
  */
60
- function formatMessageAndLog(level, forceStdout, input, style, ...args) {
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
- log({
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
- forceStdout,
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', false, input, undefined, ...args);
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', false, input, undefined, ...args);
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', false, input, undefined, ...args);
81
+ return formatMessageAndLog('info', input, undefined, ...args);
127
82
  };
128
83
  exports.info = info;
129
84
  /**
130
- * Logs an info level message to stdout.
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
- * data(`${JSON.stringify(stats)}`) // infers default info code `CDK_TOOLKIT_I000`
135
- * data('{"count": %d}', count) // infers default info code `CDK_TOOLKIT_I000`
136
- * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }) // specifies info code `CDK_DATA_I001`
137
- * data({ message: 'stats: %j', code: 'CDK_DATA_I001' }, stats) // specifies info code `CDK_DATA_I001`
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 data = (input, ...args) => {
141
- return formatMessageAndLog('info', true, input, undefined, ...args);
95
+ const result = (input, ...args) => {
96
+ return formatMessageAndLog('result', input, undefined, ...args);
142
97
  };
143
- exports.data = data;
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', false, input, undefined, ...args);
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', false, input, undefined, ...args);
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', false, input, chalk.green, ...args);
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', false, input, chalk.bold, ...args);
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":";;;AAcA,8CAcC;AA5BD,6BAA6B;AAC7B,+BAA+B;AAC/B,uDAAsK;AAEtK,oBAAoB;AACpB,IAAI,YAAY,GAAG,CAAC,CAAC;AACrB,MAAM,SAAS,GAAqB,EAAE,CAAC;AAEvC;;;;;GAKG;AACI,KAAK,UAAU,iBAAiB,CAAI,KAAuB;IAChE,YAAY,EAAE,CAAC;IACf,IAAI,CAAC;QACH,OAAO,MAAM,KAAK,EAAE,CAAC;IACvB,CAAC;YAAS,CAAC;QACT,YAAY,EAAE,CAAC;QACf,IAAI,YAAY,KAAK,CAAC,EAAE,CAAC;YACvB,+CAA+C;YAC/C,KAAK,MAAM,SAAS,IAAI,SAAS,EAAE,CAAC;gBAClC,KAAK,uBAAS,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAC9C,CAAC;YACD,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACH,CAAC;AACH,CAAC;AAwBD;;;GAGG;AACH,SAAS,GAAG,CAAC,GAAe;IAC1B,MAAM,SAAS,GAAyB;QACtC,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,IAAI,EAAE,IAAI,IAAI,EAAE;QAChB,MAAM,EAAE,uBAAS,CAAC,QAAQ,EAAE,CAAC,aAAa;QAC1C,IAAI,EAAE,GAAG,CAAC,IAAI;KACf,CAAC;IAEF,IAAI,YAAY,GAAG,CAAC,EAAE,CAAC;QACrB,IAAI,2BAAa,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,2BAAa,CAAC,uBAAS,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC5E,OAAO;QACT,CAAC;QACD,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1B,OAAO;IACT,CAAC;IAED,KAAK,uBAAS,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;AAC9C,CAAC;AAED;;;;GAIG;AACH,SAAS,mBAAmB,CAC1B,KAAqB,EACrB,WAAoB,EACpB,KAA4B,EAC5B,KAA+B,EAC/B,GAAG,IAAe;IAElB,qEAAqE;IACrE,MAAM,EAAE,OAAO,EAAE,IAAI,GAAG,cAAc,CAAC,KAAK,CAAC,EAAE,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAEzG,sCAAsC;IACtC,MAAM,gBAAgB,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC;QACtC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;QAC/B,CAAC,CAAC,OAAO,CAAC;IAEZ,0BAA0B;IAC1B,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC;IAExE,GAAG,CAAC;QACF,KAAK;QACL,OAAO,EAAE,YAAY;QACrB,IAAI;QACJ,WAAW;KACZ,CAAC,CAAC;AACL,CAAC;AAED,SAAS,cAAc,CAAC,KAAqB,EAAE,WAAkC,SAAS;IACxF,MAAM,cAAc,GAAG,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC9C,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACtB,GAAG,CAAC;IACR,OAAO,OAAO,QAAQ,IAAI,cAAc,MAAM,CAAC;AACjD,CAAC;AAiBD,yGAAyG;AACzG,+BAA+B;AAE/B;;;;;;;;;;GAUG;AACI,MAAM,KAAK,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAChE,OAAO,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;AACxE,CAAC,CAAC;AAFW,QAAA,KAAK,SAEhB;AAEF;;;;;;;;;;GAUG;AACI,MAAM,OAAO,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAClE,OAAO,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;AACvE,CAAC,CAAC;AAFW,QAAA,OAAO,WAElB;AAEF;;;;;;;;;;GAUG;AACI,MAAM,IAAI,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAC/D,OAAO,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;AACvE,CAAC,CAAC;AAFW,QAAA,IAAI,QAEf;AAEF;;;;;;;;;;GAUG;AACI,MAAM,IAAI,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAC/D,OAAO,mBAAmB,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;AACtE,CAAC,CAAC;AAFW,QAAA,IAAI,QAEf;AAEF;;;;;;;;;;GAUG;AACI,MAAM,KAAK,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAChE,OAAO,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;AACxE,CAAC,CAAC;AAFW,QAAA,KAAK,SAEhB;AAEF;;;;;;;;;;GAUG;AACI,MAAM,KAAK,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAChE,OAAO,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;AACxE,CAAC,CAAC;AAFW,QAAA,KAAK,SAEhB;AAEF;;;;;;;;;;GAUG;AACI,MAAM,OAAO,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IAClE,OAAO,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;AACzE,CAAC,CAAC;AAFW,QAAA,OAAO,WAElB;AAEF;;;;;;;;;;GAUG;AACI,MAAM,SAAS,GAAG,CAAC,KAAoB,EAAE,GAAG,IAAe,EAAE,EAAE;IACpE,OAAO,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;AACxE,CAAC,CAAC;AAFW,QAAA,SAAS,aAEpB","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 which output stream to use based on log level and configuration.
185
+ * Determines the output stream, based on message level and configuration.
182
186
  */
183
- private stream;
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<T, U>(msg: IoRequest<T, U>): Promise<U>;
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
  */