@aws-cdk/toolkit-lib 0.1.3 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/build-info.json +2 -2
  2. package/db.json.gz +0 -0
  3. package/lib/actions/bootstrap/index.d.ts +174 -0
  4. package/lib/actions/bootstrap/index.js +94 -0
  5. package/lib/actions/bootstrap/private/helpers.d.ts +5 -0
  6. package/lib/actions/bootstrap/private/helpers.js +23 -0
  7. package/lib/actions/bootstrap/private/index.d.ts +1 -0
  8. package/lib/actions/bootstrap/private/index.js +18 -0
  9. package/lib/actions/deploy/index.d.ts +4 -2
  10. package/lib/actions/deploy/index.js +4 -1
  11. package/lib/actions/deploy/private/deploy-options.d.ts +1 -1
  12. package/lib/actions/deploy/private/deploy-options.js +1 -1
  13. package/lib/actions/deploy/private/helpers.d.ts +3 -2
  14. package/lib/actions/deploy/private/helpers.js +1 -1
  15. package/lib/actions/destroy/index.d.ts +1 -1
  16. package/lib/actions/destroy/index.js +1 -1
  17. package/lib/actions/diff/private/helpers.d.ts +5 -5
  18. package/lib/actions/diff/private/helpers.js +13 -11
  19. package/lib/actions/index.d.ts +1 -0
  20. package/lib/actions/index.js +2 -1
  21. package/lib/api/aws-cdk.d.ts +5 -9
  22. package/lib/api/aws-cdk.js +1593 -735
  23. package/lib/api/aws-cdk.js.map +4 -4
  24. package/lib/api/bootstrap/bootstrap-template.yaml +707 -0
  25. package/lib/api/cloud-assembly/index.d.ts +1 -1
  26. package/lib/api/cloud-assembly/index.js +2 -2
  27. package/lib/api/cloud-assembly/private/cached-source.d.ts +2 -2
  28. package/lib/api/cloud-assembly/private/cached-source.js +1 -1
  29. package/lib/api/cloud-assembly/private/context-aware-source.d.ts +4 -4
  30. package/lib/api/cloud-assembly/private/context-aware-source.js +11 -12
  31. package/lib/api/cloud-assembly/private/identity-source.d.ts +1 -1
  32. package/lib/api/cloud-assembly/private/identity-source.js +1 -1
  33. package/lib/api/cloud-assembly/private/prepare-source.d.ts +5 -5
  34. package/lib/api/cloud-assembly/private/prepare-source.js +10 -7
  35. package/lib/api/cloud-assembly/private/source-builder.d.ts +4 -4
  36. package/lib/api/cloud-assembly/private/source-builder.js +24 -12
  37. package/lib/api/cloud-assembly/private/stack-assembly.d.ts +3 -3
  38. package/lib/api/cloud-assembly/private/stack-assembly.js +1 -1
  39. package/lib/api/cloud-assembly/private/stack-selectors.d.ts +1 -1
  40. package/lib/api/cloud-assembly/private/stack-selectors.js +1 -1
  41. package/lib/api/cloud-assembly/source-builder.d.ts +36 -0
  42. package/lib/api/cloud-assembly/source-builder.js +1 -1
  43. package/lib/api/cloud-assembly/stack-selector.d.ts +2 -81
  44. package/lib/api/cloud-assembly/stack-selector.js +5 -62
  45. package/lib/api/io/index.d.ts +1 -2
  46. package/lib/api/io/index.js +1 -17
  47. package/lib/api/io/private/index.d.ts +3 -6
  48. package/lib/api/io/private/index.js +7 -7
  49. package/lib/api/io/private/io-host-wrappers.d.ts +17 -0
  50. package/lib/api/io/private/io-host-wrappers.js +74 -0
  51. package/lib/api/io/private/sdk-logger.d.ts +3 -0
  52. package/lib/api/io/private/sdk-logger.js +124 -0
  53. package/lib/api/shared-private.d.ts +1 -0
  54. package/lib/api/shared-private.js +711 -0
  55. package/lib/api/shared-private.js.map +7 -0
  56. package/lib/api/shared-public.d.ts +2464 -1
  57. package/lib/api/shared-public.js +78 -5
  58. package/lib/api/shared-public.js.map +4 -4
  59. package/lib/index.d.ts +3 -0
  60. package/lib/index.js +4 -1
  61. package/lib/private/util.d.ts +1 -0
  62. package/lib/private/util.js +720 -0
  63. package/lib/private/util.js.map +7 -0
  64. package/lib/toolkit/index.d.ts +1 -1
  65. package/lib/toolkit/index.js +2 -2
  66. package/lib/toolkit/private/index.d.ts +12 -3
  67. package/lib/toolkit/private/index.js +18 -1
  68. package/lib/toolkit/toolkit.d.ts +10 -16
  69. package/lib/toolkit/toolkit.js +205 -152
  70. package/lib/util/concurrency.d.ts +5 -0
  71. package/lib/util/concurrency.js +11 -0
  72. package/package.json +12 -11
  73. package/CODE_REGISTRY.md +0 -35
  74. package/lib/api/io/io-host.d.ts +0 -15
  75. package/lib/api/io/io-host.js +0 -3
  76. package/lib/api/io/io-message.d.ts +0 -59
  77. package/lib/api/io/io-message.js +0 -3
  78. package/lib/api/io/private/codes.d.ts +0 -67
  79. package/lib/api/io/private/codes.js +0 -187
  80. package/lib/api/io/private/level-priority.d.ts +0 -11
  81. package/lib/api/io/private/level-priority.js +0 -33
  82. package/lib/api/io/private/logger.d.ts +0 -40
  83. package/lib/api/io/private/logger.js +0 -211
  84. package/lib/api/io/private/messages.d.ts +0 -58
  85. package/lib/api/io/private/messages.js +0 -163
  86. package/lib/api/io/private/timer.d.ts +0 -29
  87. package/lib/api/io/private/timer.js +0 -55
  88. package/lib/api/io/private/types.d.ts +0 -25
  89. package/lib/api/io/private/types.js +0 -3
  90. package/lib/toolkit/types.d.ts +0 -76
  91. package/lib/toolkit/types.js +0 -3
@@ -1,211 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.withAction = withAction;
4
- exports.withoutColor = withoutColor;
5
- exports.withoutEmojis = withoutEmojis;
6
- exports.withTrimmedWhitespace = withTrimmedWhitespace;
7
- exports.asSdkLogger = asSdkLogger;
8
- exports.asLogger = asLogger;
9
- const util = require("node:util");
10
- const messages_1 = require("./messages");
11
- const aws_cdk_1 = require("../../aws-cdk");
12
- /**
13
- * An IoHost wrapper that adds the given action to an actionless message before
14
- * sending the message to the given IoHost
15
- */
16
- function withAction(ioHost, action) {
17
- return {
18
- notify: async (msg) => {
19
- await ioHost.notify({
20
- ...msg,
21
- action,
22
- });
23
- },
24
- requestResponse: async (msg) => {
25
- return ioHost.requestResponse({
26
- ...msg,
27
- action,
28
- });
29
- },
30
- };
31
- }
32
- /**
33
- * An IoHost wrapper that strips out ANSI colors and styles from the message before
34
- * sending the message to the given IoHost
35
- */
36
- function withoutColor(ioHost) {
37
- return {
38
- notify: async (msg) => {
39
- await ioHost.notify({
40
- ...msg,
41
- message: stripColor(msg.message),
42
- });
43
- },
44
- requestResponse: async (msg) => {
45
- return ioHost.requestResponse({
46
- ...msg,
47
- message: stripColor(msg.message),
48
- });
49
- },
50
- };
51
- }
52
- function stripColor(msg) {
53
- return msg.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '');
54
- }
55
- /**
56
- * An IoHost wrapper that strips out emojis from the message before
57
- * sending the message to the given IoHost
58
- */
59
- function withoutEmojis(ioHost) {
60
- return {
61
- notify: async (msg) => {
62
- await ioHost.notify({
63
- ...msg,
64
- message: stripEmojis(msg.message),
65
- });
66
- },
67
- requestResponse: async (msg) => {
68
- return ioHost.requestResponse({
69
- ...msg,
70
- message: stripEmojis(msg.message),
71
- });
72
- },
73
- };
74
- }
75
- function stripEmojis(msg) {
76
- // https://www.unicode.org/reports/tr51/#def_emoji_presentation
77
- return msg.replace(/\p{Emoji_Presentation}/gu, '');
78
- }
79
- /**
80
- * An IoHost wrapper that trims whitespace at the beginning and end of messages.
81
- * This is required, since after removing emojis and ANSI colors,
82
- * we might end up with floating whitespace at either end.
83
- */
84
- function withTrimmedWhitespace(ioHost) {
85
- return {
86
- notify: async (msg) => {
87
- await ioHost.notify({
88
- ...msg,
89
- message: msg.message.trim(),
90
- });
91
- },
92
- requestResponse: async (msg) => {
93
- return ioHost.requestResponse({
94
- ...msg,
95
- message: msg.message.trim(),
96
- });
97
- },
98
- };
99
- }
100
- // @todo these cannot be awaited WTF
101
- function asSdkLogger(ioHost, action) {
102
- return new class {
103
- // This is too much detail for our logs
104
- trace(..._content) {
105
- }
106
- debug(..._content) {
107
- }
108
- /**
109
- * Info is called mostly (exclusively?) for successful API calls
110
- *
111
- * Payload:
112
- *
113
- * (Note the input contains entire CFN templates, for example)
114
- *
115
- * ```
116
- * {
117
- * clientName: 'S3Client',
118
- * commandName: 'GetBucketLocationCommand',
119
- * input: {
120
- * Bucket: '.....',
121
- * ExpectedBucketOwner: undefined
122
- * },
123
- * output: { LocationConstraint: 'eu-central-1' },
124
- * metadata: {
125
- * httpStatusCode: 200,
126
- * requestId: '....',
127
- * extendedRequestId: '...',
128
- * cfId: undefined,
129
- * attempts: 1,
130
- * totalRetryDelay: 0
131
- * }
132
- * }
133
- * ```
134
- */
135
- info(...content) {
136
- void ioHost.notify({
137
- action,
138
- ...(0, messages_1.trace)(`[sdk info] ${(0, aws_cdk_1.formatSdkLoggerContent)(content)}`),
139
- data: {
140
- sdkLevel: 'info',
141
- content,
142
- },
143
- });
144
- }
145
- warn(...content) {
146
- void ioHost.notify({
147
- action,
148
- ...(0, messages_1.trace)(`[sdk warn] ${(0, aws_cdk_1.formatSdkLoggerContent)(content)}`),
149
- data: {
150
- sdkLevel: 'warn',
151
- content,
152
- },
153
- });
154
- }
155
- /**
156
- * Error is called mostly (exclusively?) for failing API calls
157
- *
158
- * Payload (input would be the entire API call arguments).
159
- *
160
- * ```
161
- * {
162
- * clientName: 'STSClient',
163
- * commandName: 'GetCallerIdentityCommand',
164
- * input: {},
165
- * error: AggregateError [ECONNREFUSED]:
166
- * at internalConnectMultiple (node:net:1121:18)
167
- * at afterConnectMultiple (node:net:1688:7) {
168
- * code: 'ECONNREFUSED',
169
- * '$metadata': { attempts: 3, totalRetryDelay: 600 },
170
- * [errors]: [ [Error], [Error] ]
171
- * },
172
- * metadata: { attempts: 3, totalRetryDelay: 600 }
173
- * }
174
- * ```
175
- */
176
- error(...content) {
177
- void ioHost.notify({
178
- action,
179
- ...(0, messages_1.trace)(`[sdk error] ${(0, aws_cdk_1.formatSdkLoggerContent)(content)}`),
180
- data: {
181
- sdkLevel: 'error',
182
- content,
183
- },
184
- });
185
- }
186
- };
187
- }
188
- /**
189
- * Turn an ActionAwareIoHost into a logger that is compatible with older code, but doesn't support data
190
- */
191
- function asLogger(ioHost, category) {
192
- const code = (level) => (0, messages_1.defaultMessageCode)(level, category);
193
- return {
194
- trace: async (msg, ...args) => {
195
- await ioHost.notify((0, messages_1.trace)(util.format(msg, args), code('trace')));
196
- },
197
- debug: async (msg, ...args) => {
198
- await ioHost.notify((0, messages_1.debug)(util.format(msg, args), code('debug')));
199
- },
200
- info: async (msg, ...args) => {
201
- await ioHost.notify((0, messages_1.info)(util.format(msg, args), code('info')));
202
- },
203
- warn: async (msg, ...args) => {
204
- await ioHost.notify((0, messages_1.warn)(util.format(msg, args), code('warn')));
205
- },
206
- error: async (msg, ...args) => {
207
- await ioHost.notify((0, messages_1.error)(util.format(msg, args), code('error')));
208
- },
209
- };
210
- }
211
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["logger.ts"],"names":[],"mappings":"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","sourcesContent":["import * as util from 'node:util';\nimport type { Logger } from '@smithy/types';\nimport type { IoMessage, IoMessageLevel, IoRequest } from '../io-message';\nimport { debug, error, info, defaultMessageCode, trace, warn } from './messages';\nimport type { ActionAwareIoHost, IoMessageCodeCategory } from './types';\nimport type { ToolkitAction } from '../../../toolkit';\nimport { formatSdkLoggerContent } from '../../aws-cdk';\nimport type { IIoHost } from '../io-host';\n\n/**\n * An IoHost wrapper that adds the given action to an actionless message before\n * sending the message to the given IoHost\n */\nexport function withAction(ioHost: IIoHost, action: ToolkitAction) {\n  return {\n    notify: async <T>(msg: Omit<IoMessage<T>, 'action'>) => {\n      await ioHost.notify({\n        ...msg,\n        action,\n      });\n    },\n    requestResponse: async <T, U>(msg: Omit<IoRequest<T, U>, 'action'>) => {\n      return ioHost.requestResponse({\n        ...msg,\n        action,\n      });\n    },\n  };\n}\n\n/**\n * An IoHost wrapper that strips out ANSI colors and styles from the message before\n * sending the message to the given IoHost\n */\nexport function withoutColor(ioHost: IIoHost): IIoHost {\n  return {\n    notify: async <T>(msg: IoMessage<T>) => {\n      await ioHost.notify({\n        ...msg,\n        message: stripColor(msg.message),\n      });\n    },\n    requestResponse: async <T, U>(msg: IoRequest<T, U>) => {\n      return ioHost.requestResponse({\n        ...msg,\n        message: stripColor(msg.message),\n      });\n    },\n  };\n}\n\nfunction stripColor(msg: string): string {\n  return msg.replace(/[\\u001b\\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '');\n}\n\n/**\n * An IoHost wrapper that strips out emojis from the message before\n * sending the message to the given IoHost\n */\nexport function withoutEmojis(ioHost: IIoHost): IIoHost {\n  return {\n    notify: async <T>(msg: IoMessage<T>) => {\n      await ioHost.notify({\n        ...msg,\n        message: stripEmojis(msg.message),\n      });\n    },\n    requestResponse: async <T, U>(msg: IoRequest<T, U>) => {\n      return ioHost.requestResponse({\n        ...msg,\n        message: stripEmojis(msg.message),\n      });\n    },\n  };\n}\n\nfunction stripEmojis(msg: string): string {\n  // https://www.unicode.org/reports/tr51/#def_emoji_presentation\n  return msg.replace(/\\p{Emoji_Presentation}/gu, '');\n}\n\n/**\n * An IoHost wrapper that trims whitespace at the beginning and end of messages.\n * This is required, since after removing emojis and ANSI colors,\n * we might end up with floating whitespace at either end.\n */\nexport function withTrimmedWhitespace(ioHost: IIoHost): IIoHost {\n  return {\n    notify: async <T>(msg: IoMessage<T>) => {\n      await ioHost.notify({\n        ...msg,\n        message: msg.message.trim(),\n      });\n    },\n    requestResponse: async <T, U>(msg: IoRequest<T, U>) => {\n      return ioHost.requestResponse({\n        ...msg,\n        message: msg.message.trim(),\n      });\n    },\n  };\n}\n\n// @todo these cannot be awaited WTF\nexport function asSdkLogger(ioHost: IIoHost, action: ToolkitAction): Logger {\n  return new class implements Logger {\n    // This is too much detail for our logs\n    public trace(..._content: any[]) {\n    }\n    public debug(..._content: any[]) {\n    }\n\n    /**\n     * Info is called mostly (exclusively?) for successful API calls\n     *\n     * Payload:\n     *\n     * (Note the input contains entire CFN templates, for example)\n     *\n     * ```\n     * {\n     *   clientName: 'S3Client',\n     *   commandName: 'GetBucketLocationCommand',\n     *   input: {\n     *     Bucket: '.....',\n     *     ExpectedBucketOwner: undefined\n     *   },\n     *   output: { LocationConstraint: 'eu-central-1' },\n     *   metadata: {\n     *     httpStatusCode: 200,\n     *     requestId: '....',\n     *     extendedRequestId: '...',\n     *     cfId: undefined,\n     *     attempts: 1,\n     *     totalRetryDelay: 0\n     *   }\n     * }\n     * ```\n     */\n    public info(...content: any[]) {\n      void ioHost.notify({\n        action,\n        ...trace(`[sdk info] ${formatSdkLoggerContent(content)}`),\n        data: {\n          sdkLevel: 'info',\n          content,\n        },\n      });\n    }\n\n    public warn(...content: any[]) {\n      void ioHost.notify({\n        action,\n        ...trace(`[sdk warn] ${formatSdkLoggerContent(content)}`),\n        data: {\n          sdkLevel: 'warn',\n          content,\n        },\n      });\n    }\n\n    /**\n     * Error is called mostly (exclusively?) for failing API calls\n     *\n     * Payload (input would be the entire API call arguments).\n     *\n     * ```\n     * {\n     *   clientName: 'STSClient',\n     *   commandName: 'GetCallerIdentityCommand',\n     *   input: {},\n     *   error: AggregateError [ECONNREFUSED]:\n     *       at internalConnectMultiple (node:net:1121:18)\n     *       at afterConnectMultiple (node:net:1688:7) {\n     *     code: 'ECONNREFUSED',\n     *     '$metadata': { attempts: 3, totalRetryDelay: 600 },\n     *     [errors]: [ [Error], [Error] ]\n     *   },\n     *   metadata: { attempts: 3, totalRetryDelay: 600 }\n     * }\n     * ```\n     */\n    public error(...content: any[]) {\n      void ioHost.notify({\n        action,\n        ...trace(`[sdk error] ${formatSdkLoggerContent(content)}`),\n        data: {\n          sdkLevel: 'error',\n          content,\n        },\n      });\n    }\n  };\n}\n\n/**\n * Turn an ActionAwareIoHost into a logger that is compatible with older code, but doesn't support data\n */\nexport function asLogger(ioHost: ActionAwareIoHost, category?: IoMessageCodeCategory) {\n  const code = (level: IoMessageLevel) => defaultMessageCode(level, category);\n\n  return {\n    trace: async (msg: string, ...args: any[]) => {\n      await ioHost.notify(trace(util.format(msg, args), code('trace')));\n    },\n    debug: async (msg: string, ...args: any[]) => {\n      await ioHost.notify(debug(util.format(msg, args), code('debug')));\n    },\n    info: async (msg: string, ...args: any[]) => {\n      await ioHost.notify(info(util.format(msg, args), code('info')));\n    },\n    warn: async (msg: string, ...args: any[]) => {\n      await ioHost.notify(warn(util.format(msg, args), code('warn')));\n    },\n    error: async (msg: string, ...args: any[]) => {\n      await ioHost.notify(error(util.format(msg, args), code('error')));\n    },\n  };\n}\n"]}
@@ -1,58 +0,0 @@
1
- import type { IoMessageLevel } from '../io-message';
2
- import { CodeInfo } from './codes';
3
- import type { ActionLessMessage, ActionLessRequest, IoMessageCodeCategory } from './types';
4
- /**
5
- * Build a message code from level and category. The code must be valid for this function to pass.
6
- * Otherwise it returns a ToolkitError.
7
- */
8
- export declare function defaultMessageCode(level: IoMessageLevel, category?: IoMessageCodeCategory): CodeInfo;
9
- /**
10
- * Requests a yes/no confirmation from the IoHost.
11
- */
12
- export declare const confirm: (code: CodeInfo, question: string, motivation: string, defaultResponse: boolean, concurrency?: number) => ActionLessRequest<{
13
- motivation: string;
14
- concurrency?: number;
15
- }, boolean>;
16
- /**
17
- * Prompt for a response from the IoHost.
18
- */
19
- export declare const prompt: <T, U>(code: CodeInfo, message: string, defaultResponse: U, payload?: T) => ActionLessRequest<T, U>;
20
- /**
21
- * Creates an error level message.
22
- * Errors must always have a unique code.
23
- */
24
- export declare const error: <T>(message: string, code: CodeInfo, payload?: T) => ActionLessMessage<T>;
25
- /**
26
- * Creates a result level message and represents the most important message for a given action.
27
- *
28
- * They should be used sparsely, with an action usually having no or exactly one result.
29
- * However actions that operate on Cloud Assemblies might include a result per Stack.
30
- * Unlike other messages, results must always have a code and a payload.
31
- */
32
- export declare const result: <T>(message: string, code: CodeInfo, payload: T) => ActionLessMessage<T>;
33
- /**
34
- * Creates a warning level message.
35
- */
36
- export declare const warn: <T>(message: string, code?: CodeInfo, payload?: T) => ActionLessMessage<T>;
37
- /**
38
- * Creates an info level message.
39
- */
40
- export declare const info: <T>(message: string, code?: CodeInfo, payload?: T) => ActionLessMessage<T>;
41
- /**
42
- * Creates a debug level message.
43
- */
44
- export declare const debug: <T>(message: string, code?: CodeInfo, payload?: T) => ActionLessMessage<T>;
45
- /**
46
- * Creates a trace level message.
47
- */
48
- export declare const trace: <T>(message: string, code?: CodeInfo, payload?: T) => ActionLessMessage<T>;
49
- /**
50
- * Creates an info level success message in green text.
51
- * @deprecated
52
- */
53
- export declare const success: <T>(message: string, code?: CodeInfo, payload?: T) => ActionLessMessage<T>;
54
- /**
55
- * Creates an info level message in bold text.
56
- * @deprecated
57
- */
58
- export declare const highlight: <T>(message: string, code?: CodeInfo, payload?: T) => ActionLessMessage<T>;
@@ -1,163 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.highlight = exports.success = exports.trace = exports.debug = exports.info = exports.warn = exports.result = exports.error = exports.prompt = exports.confirm = void 0;
4
- exports.defaultMessageCode = defaultMessageCode;
5
- const chalk = require("chalk");
6
- /**
7
- * Internal helper that processes log inputs into a consistent format.
8
- * Handles string interpolation, format strings, and object parameter styles.
9
- * Applies optional styling and prepares the final message for logging.
10
- */
11
- function formatMessage(msg, category = 'TOOLKIT') {
12
- return {
13
- time: new Date(),
14
- level: msg.level,
15
- code: msg.code ?? defaultMessageCode(msg.level, category).code,
16
- message: msg.message,
17
- data: msg.data,
18
- };
19
- }
20
- /**
21
- * Build a message code from level and category. The code must be valid for this function to pass.
22
- * Otherwise it returns a ToolkitError.
23
- */
24
- function defaultMessageCode(level, category = 'TOOLKIT') {
25
- const levelIndicator = level === 'error' ? 'E' :
26
- level === 'warn' ? 'W' :
27
- 'I';
28
- const code = `CDK_${category}_${levelIndicator}0000`;
29
- return {
30
- code,
31
- description: `Generic ${level} message for CDK_${category}`,
32
- level,
33
- };
34
- }
35
- /**
36
- * Requests a yes/no confirmation from the IoHost.
37
- */
38
- const confirm = (code, question, motivation, defaultResponse, concurrency) => {
39
- return (0, exports.prompt)(code, `${chalk.cyan(question)} (y/n)?`, defaultResponse, {
40
- motivation,
41
- concurrency,
42
- });
43
- };
44
- exports.confirm = confirm;
45
- /**
46
- * Prompt for a response from the IoHost.
47
- */
48
- const prompt = (code, message, defaultResponse, payload) => {
49
- return {
50
- defaultResponse,
51
- ...formatMessage({
52
- level: code.level,
53
- code: code.code,
54
- message,
55
- data: payload,
56
- }),
57
- };
58
- };
59
- exports.prompt = prompt;
60
- /**
61
- * Creates an error level message.
62
- * Errors must always have a unique code.
63
- */
64
- const error = (message, code, payload) => {
65
- return formatMessage({
66
- level: 'error',
67
- code: code.code,
68
- message,
69
- data: payload,
70
- });
71
- };
72
- exports.error = error;
73
- /**
74
- * Creates a result level message and represents the most important message for a given action.
75
- *
76
- * They should be used sparsely, with an action usually having no or exactly one result.
77
- * However actions that operate on Cloud Assemblies might include a result per Stack.
78
- * Unlike other messages, results must always have a code and a payload.
79
- */
80
- const result = (message, code, payload) => {
81
- return formatMessage({
82
- level: 'result',
83
- code: code.code,
84
- message,
85
- data: payload,
86
- });
87
- };
88
- exports.result = result;
89
- /**
90
- * Creates a warning level message.
91
- */
92
- const warn = (message, code, payload) => {
93
- return formatMessage({
94
- level: 'warn',
95
- code: code?.code,
96
- message,
97
- data: payload,
98
- });
99
- };
100
- exports.warn = warn;
101
- /**
102
- * Creates an info level message.
103
- */
104
- const info = (message, code, payload) => {
105
- return formatMessage({
106
- level: 'info',
107
- code: code?.code,
108
- message,
109
- data: payload,
110
- });
111
- };
112
- exports.info = info;
113
- /**
114
- * Creates a debug level message.
115
- */
116
- const debug = (message, code, payload) => {
117
- return formatMessage({
118
- level: 'debug',
119
- code: code?.code,
120
- message,
121
- data: payload,
122
- });
123
- };
124
- exports.debug = debug;
125
- /**
126
- * Creates a trace level message.
127
- */
128
- const trace = (message, code, payload) => {
129
- return formatMessage({
130
- level: 'trace',
131
- code: code?.code,
132
- message,
133
- data: payload,
134
- });
135
- };
136
- exports.trace = trace;
137
- /**
138
- * Creates an info level success message in green text.
139
- * @deprecated
140
- */
141
- const success = (message, code, payload) => {
142
- return formatMessage({
143
- level: 'info',
144
- code: code?.code,
145
- message: chalk.green(message),
146
- data: payload,
147
- });
148
- };
149
- exports.success = success;
150
- /**
151
- * Creates an info level message in bold text.
152
- * @deprecated
153
- */
154
- const highlight = (message, code, payload) => {
155
- return formatMessage({
156
- level: 'info',
157
- code: code?.code,
158
- message: chalk.bold(message),
159
- data: payload,
160
- });
161
- };
162
- exports.highlight = highlight;
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["messages.ts"],"names":[],"mappings":"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","sourcesContent":["import * as chalk from 'chalk';\nimport type { IoMessageCode, IoMessageLevel } from '../io-message';\nimport { CodeInfo } from './codes';\nimport type { ActionLessMessage, ActionLessRequest, IoMessageCodeCategory, Optional, SimplifiedMessage } from './types';\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 formatMessage<T>(msg: Optional<SimplifiedMessage<T>, 'code'>, category: IoMessageCodeCategory = 'TOOLKIT'): ActionLessMessage<T> {\n  return {\n    time: new Date(),\n    level: msg.level,\n    code: msg.code ?? defaultMessageCode(msg.level, category).code,\n    message: msg.message,\n    data: msg.data,\n  };\n}\n\n/**\n * Build a message code from level and category. The code must be valid for this function to pass.\n * Otherwise it returns a ToolkitError.\n */\nexport function defaultMessageCode(level: IoMessageLevel, category: IoMessageCodeCategory = 'TOOLKIT'): CodeInfo {\n  const levelIndicator = level === 'error' ? 'E' :\n    level === 'warn' ? 'W' :\n      'I';\n  const code = `CDK_${category}_${levelIndicator}0000` as IoMessageCode;\n  return {\n    code,\n    description: `Generic ${level} message for CDK_${category}`,\n    level,\n  };\n}\n\n/**\n * Requests a yes/no confirmation from the IoHost.\n */\nexport const confirm = (\n  code: CodeInfo,\n  question: string,\n  motivation: string,\n  defaultResponse: boolean,\n  concurrency?: number,\n): ActionLessRequest<{\n  motivation: string;\n  concurrency?: number;\n}, boolean> => {\n  return prompt(code, `${chalk.cyan(question)} (y/n)?`, defaultResponse, {\n    motivation,\n    concurrency,\n  });\n};\n\n/**\n * Prompt for a response from the IoHost.\n */\nexport const prompt = <T, U>(code: CodeInfo, message: string, defaultResponse: U, payload?: T): ActionLessRequest<T, U> => {\n  return {\n    defaultResponse,\n    ...formatMessage({\n      level: code.level,\n      code: code.code,\n      message,\n      data: payload,\n    }),\n  };\n};\n\n/**\n * Creates an error level message.\n * Errors must always have a unique code.\n */\nexport const error = <T>(message: string, code: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'error',\n    code: code.code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a result level message and represents the most important message for a given action.\n *\n * They should be used sparsely, with an action usually having no or exactly one result.\n * However actions that operate on Cloud Assemblies might include a result per Stack.\n * Unlike other messages, results must always have a code and a payload.\n */\nexport const result = <T>(message: string, code: CodeInfo, payload: T) => {\n  return formatMessage({\n    level: 'result',\n    code: code.code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a warning level message.\n */\nexport const warn = <T>(message: string, code?: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'warn',\n    code: code?.code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates an info level message.\n */\nexport const info = <T>(message: string, code?: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'info',\n    code: code?.code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a debug level message.\n */\nexport const debug = <T>(message: string, code?: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'debug',\n    code: code?.code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a trace level message.\n */\nexport const trace = <T>(message: string, code?: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'trace',\n    code: code?.code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates an info level success message in green text.\n * @deprecated\n */\nexport const success = <T>(message: string, code?: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'info',\n    code: code?.code,\n    message: chalk.green(message),\n    data: payload,\n  });\n};\n\n/**\n * Creates an info level message in bold text.\n * @deprecated\n */\nexport const highlight = <T>(message: string, code?: CodeInfo, payload?: T) => {\n  return formatMessage({\n    level: 'info',\n    code: code?.code,\n    message: chalk.bold(message),\n    data: payload,\n  });\n};\n"]}
@@ -1,29 +0,0 @@
1
- import { ActionAwareIoHost } from './types';
2
- /**
3
- * Helper class to measure the time of code.
4
- */
5
- export declare class Timer {
6
- /**
7
- * Start the timer.
8
- * @return the timer instance
9
- */
10
- static start(): Timer;
11
- private readonly startTime;
12
- private constructor();
13
- /**
14
- * End the current timer.
15
- * @returns the elapsed time
16
- */
17
- end(): {
18
- asMs: number;
19
- asSec: number;
20
- };
21
- /**
22
- * Ends the current timer as a specified timing and notifies the IoHost.
23
- * @returns the elapsed time
24
- */
25
- endAs(ioHost: ActionAwareIoHost, type: 'synth' | 'deploy' | 'rollback' | 'destroy'): Promise<{
26
- asMs: number;
27
- asSec: number;
28
- }>;
29
- }
@@ -1,55 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Timer = void 0;
4
- const codes_1 = require("./codes");
5
- const messages_1 = require("./messages");
6
- const aws_cdk_1 = require("../../aws-cdk");
7
- /**
8
- * Helper class to measure the time of code.
9
- */
10
- class Timer {
11
- /**
12
- * Start the timer.
13
- * @return the timer instance
14
- */
15
- static start() {
16
- return new Timer();
17
- }
18
- startTime;
19
- constructor() {
20
- this.startTime = new Date().getTime();
21
- }
22
- /**
23
- * End the current timer.
24
- * @returns the elapsed time
25
- */
26
- end() {
27
- const elapsedTime = new Date().getTime() - this.startTime;
28
- return {
29
- asMs: elapsedTime,
30
- asSec: (0, aws_cdk_1.formatTime)(elapsedTime),
31
- };
32
- }
33
- /**
34
- * Ends the current timer as a specified timing and notifies the IoHost.
35
- * @returns the elapsed time
36
- */
37
- async endAs(ioHost, type) {
38
- const duration = this.end();
39
- const { code, text } = timerMessageProps(type);
40
- await ioHost.notify((0, messages_1.info)(`\n✨ ${text} time: ${duration.asSec}s\n`, code, {
41
- duration: duration.asMs,
42
- }));
43
- return duration;
44
- }
45
- }
46
- exports.Timer = Timer;
47
- function timerMessageProps(type) {
48
- switch (type) {
49
- case 'synth': return { code: codes_1.CODES.CDK_TOOLKIT_I1000, text: 'Synthesis' };
50
- case 'deploy': return { code: codes_1.CODES.CDK_TOOLKIT_I5000, text: 'Deployment' };
51
- case 'rollback': return { code: codes_1.CODES.CDK_TOOLKIT_I6000, text: 'Rollback' };
52
- case 'destroy': return { code: codes_1.CODES.CDK_TOOLKIT_I7000, text: 'Destroy' };
53
- }
54
- }
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0aW1lci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBMEM7QUFDMUMseUNBQWtDO0FBRWxDLDJDQUEyQztBQUUzQzs7R0FFRztBQUNILE1BQWEsS0FBSztJQUNoQjs7O09BR0c7SUFDSSxNQUFNLENBQUMsS0FBSztRQUNqQixPQUFPLElBQUksS0FBSyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVnQixTQUFTLENBQVM7SUFFbkM7UUFDRSxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDeEMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLEdBQUc7UUFDUixNQUFNLFdBQVcsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDMUQsT0FBTztZQUNMLElBQUksRUFBRSxXQUFXO1lBQ2pCLEtBQUssRUFBRSxJQUFBLG9CQUFVLEVBQUMsV0FBVyxDQUFDO1NBQy9CLENBQUM7SUFDSixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUF5QixFQUFFLElBQWlEO1FBQzdGLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUM1QixNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBRS9DLE1BQU0sTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFBLGVBQUksRUFBQyxRQUFRLElBQUksVUFBVSxRQUFRLENBQUMsS0FBSyxLQUFLLEVBQUUsSUFBSSxFQUFFO1lBQ3hFLFFBQVEsRUFBRSxRQUFRLENBQUMsSUFBSTtTQUN4QixDQUFDLENBQUMsQ0FBQztRQUVKLE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7Q0FDRjtBQXpDRCxzQkF5Q0M7QUFFRCxTQUFTLGlCQUFpQixDQUFDLElBQWdEO0lBSXpFLFFBQVEsSUFBSSxFQUFFLENBQUM7UUFDYixLQUFLLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsYUFBSyxDQUFDLGlCQUFpQixFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsQ0FBQztRQUMxRSxLQUFLLFFBQVEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsYUFBSyxDQUFDLGlCQUFpQixFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsQ0FBQztRQUM1RSxLQUFLLFVBQVUsQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsYUFBSyxDQUFDLGlCQUFpQixFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsQ0FBQztRQUM1RSxLQUFLLFNBQVMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsYUFBSyxDQUFDLGlCQUFpQixFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsQ0FBQztJQUM1RSxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvZGVJbmZvLCBDT0RFUyB9IGZyb20gJy4vY29kZXMnO1xuaW1wb3J0IHsgaW5mbyB9IGZyb20gJy4vbWVzc2FnZXMnO1xuaW1wb3J0IHsgQWN0aW9uQXdhcmVJb0hvc3QgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IGZvcm1hdFRpbWUgfSBmcm9tICcuLi8uLi9hd3MtY2RrJztcblxuLyoqXG4gKiBIZWxwZXIgY2xhc3MgdG8gbWVhc3VyZSB0aGUgdGltZSBvZiBjb2RlLlxuICovXG5leHBvcnQgY2xhc3MgVGltZXIge1xuICAvKipcbiAgICogU3RhcnQgdGhlIHRpbWVyLlxuICAgKiBAcmV0dXJuIHRoZSB0aW1lciBpbnN0YW5jZVxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBzdGFydCgpOiBUaW1lciB7XG4gICAgcmV0dXJuIG5ldyBUaW1lcigpO1xuICB9XG5cbiAgcHJpdmF0ZSByZWFkb25seSBzdGFydFRpbWU6IG51bWJlcjtcblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuc3RhcnRUaW1lID0gbmV3IERhdGUoKS5nZXRUaW1lKCk7XG4gIH1cblxuICAvKipcbiAgICogRW5kIHRoZSBjdXJyZW50IHRpbWVyLlxuICAgKiBAcmV0dXJucyB0aGUgZWxhcHNlZCB0aW1lXG4gICAqL1xuICBwdWJsaWMgZW5kKCkge1xuICAgIGNvbnN0IGVsYXBzZWRUaW1lID0gbmV3IERhdGUoKS5nZXRUaW1lKCkgLSB0aGlzLnN0YXJ0VGltZTtcbiAgICByZXR1cm4ge1xuICAgICAgYXNNczogZWxhcHNlZFRpbWUsXG4gICAgICBhc1NlYzogZm9ybWF0VGltZShlbGFwc2VkVGltZSksXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFbmRzIHRoZSBjdXJyZW50IHRpbWVyIGFzIGEgc3BlY2lmaWVkIHRpbWluZyBhbmQgbm90aWZpZXMgdGhlIElvSG9zdC5cbiAgICogQHJldHVybnMgdGhlIGVsYXBzZWQgdGltZVxuICAgKi9cbiAgcHVibGljIGFzeW5jIGVuZEFzKGlvSG9zdDogQWN0aW9uQXdhcmVJb0hvc3QsIHR5cGU6ICdzeW50aCcgfCAnZGVwbG95JyB8ICdyb2xsYmFjaycgfCAnZGVzdHJveScpIHtcbiAgICBjb25zdCBkdXJhdGlvbiA9IHRoaXMuZW5kKCk7XG4gICAgY29uc3QgeyBjb2RlLCB0ZXh0IH0gPSB0aW1lck1lc3NhZ2VQcm9wcyh0eXBlKTtcblxuICAgIGF3YWl0IGlvSG9zdC5ub3RpZnkoaW5mbyhgXFxu4pyoICAke3RleHR9IHRpbWU6ICR7ZHVyYXRpb24uYXNTZWN9c1xcbmAsIGNvZGUsIHtcbiAgICAgIGR1cmF0aW9uOiBkdXJhdGlvbi5hc01zLFxuICAgIH0pKTtcblxuICAgIHJldHVybiBkdXJhdGlvbjtcbiAgfVxufVxuXG5mdW5jdGlvbiB0aW1lck1lc3NhZ2VQcm9wcyh0eXBlOiAnc3ludGgnIHwgJ2RlcGxveScgfCAncm9sbGJhY2snfCAnZGVzdHJveScpOiB7XG4gIGNvZGU6IENvZGVJbmZvO1xuICB0ZXh0OiBzdHJpbmc7XG59IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnc3ludGgnOiByZXR1cm4geyBjb2RlOiBDT0RFUy5DREtfVE9PTEtJVF9JMTAwMCwgdGV4dDogJ1N5bnRoZXNpcycgfTtcbiAgICBjYXNlICdkZXBsb3knOiByZXR1cm4geyBjb2RlOiBDT0RFUy5DREtfVE9PTEtJVF9JNTAwMCwgdGV4dDogJ0RlcGxveW1lbnQnIH07XG4gICAgY2FzZSAncm9sbGJhY2snOiByZXR1cm4geyBjb2RlOiBDT0RFUy5DREtfVE9PTEtJVF9JNjAwMCwgdGV4dDogJ1JvbGxiYWNrJyB9O1xuICAgIGNhc2UgJ2Rlc3Ryb3knOiByZXR1cm4geyBjb2RlOiBDT0RFUy5DREtfVE9PTEtJVF9JNzAwMCwgdGV4dDogJ0Rlc3Ryb3knIH07XG4gIH1cbn1cbiJdfQ==
@@ -1,25 +0,0 @@
1
- import { IIoHost } from '../io-host';
2
- import { IoMessage, IoRequest } from '../io-message';
3
- /**
4
- * Valid reporting categories for messages.
5
- */
6
- export type IoMessageCodeCategory = 'TOOLKIT' | 'SDK' | 'ASSETS' | 'ASSEMBLY';
7
- /**
8
- * Code level matching the reporting level.
9
- */
10
- export type IoCodeLevel = 'E' | 'W' | 'I';
11
- /**
12
- * A message code at a specific level
13
- */
14
- export type IoMessageSpecificCode<L extends IoCodeLevel> = `CDK_${IoMessageCodeCategory}_${L}${number}${number}${number}${number}`;
15
- export type Optional<T, K extends keyof T> = Pick<Partial<T>, K> & Omit<T, K>;
16
- export type SimplifiedMessage<T> = Pick<IoMessage<T>, 'level' | 'code' | 'message' | 'data'>;
17
- export type ActionLessMessage<T> = Omit<IoMessage<T>, 'action'>;
18
- export type ActionLessRequest<T, U> = Omit<IoRequest<T, U>, 'action'>;
19
- /**
20
- * Helper type for IoHosts that are action aware
21
- */
22
- export interface ActionAwareIoHost extends IIoHost {
23
- notify<T>(msg: ActionLessMessage<T>): Promise<void>;
24
- requestResponse<T, U>(msg: ActionLessRequest<T, U>): Promise<U>;
25
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUlvSG9zdCB9IGZyb20gJy4uL2lvLWhvc3QnO1xuaW1wb3J0IHsgSW9NZXNzYWdlLCBJb1JlcXVlc3QgfSBmcm9tICcuLi9pby1tZXNzYWdlJztcblxuLyoqXG4gKiBWYWxpZCByZXBvcnRpbmcgY2F0ZWdvcmllcyBmb3IgbWVzc2FnZXMuXG4gKi9cbmV4cG9ydCB0eXBlIElvTWVzc2FnZUNvZGVDYXRlZ29yeSA9ICdUT09MS0lUJyB8ICdTREsnIHwgJ0FTU0VUUycgfCAnQVNTRU1CTFknO1xuXG4vKipcbiAqIENvZGUgbGV2ZWwgbWF0Y2hpbmcgdGhlIHJlcG9ydGluZyBsZXZlbC5cbiAqL1xuZXhwb3J0IHR5cGUgSW9Db2RlTGV2ZWwgPSAnRScgfCAnVycgfCAnSSc7XG5cbi8qKlxuICogQSBtZXNzYWdlIGNvZGUgYXQgYSBzcGVjaWZpYyBsZXZlbFxuICovXG5leHBvcnQgdHlwZSBJb01lc3NhZ2VTcGVjaWZpY0NvZGU8TCBleHRlbmRzIElvQ29kZUxldmVsPiA9IGBDREtfJHtJb01lc3NhZ2VDb2RlQ2F0ZWdvcnl9XyR7TH0ke251bWJlcn0ke251bWJlcn0ke251bWJlcn0ke251bWJlcn1gO1xuXG5leHBvcnQgdHlwZSBPcHRpb25hbDxULCBLIGV4dGVuZHMga2V5b2YgVD4gPSBQaWNrPFBhcnRpYWw8VD4sIEs+ICYgT21pdDxULCBLPjtcbmV4cG9ydCB0eXBlIFNpbXBsaWZpZWRNZXNzYWdlPFQ+ID0gUGljazxJb01lc3NhZ2U8VD4sICdsZXZlbCcgfCAnY29kZScgfCAnbWVzc2FnZScgfCAnZGF0YSc+O1xuZXhwb3J0IHR5cGUgQWN0aW9uTGVzc01lc3NhZ2U8VD4gPSBPbWl0PElvTWVzc2FnZTxUPiwgJ2FjdGlvbic+O1xuZXhwb3J0IHR5cGUgQWN0aW9uTGVzc1JlcXVlc3Q8VCwgVT4gPSBPbWl0PElvUmVxdWVzdDxULCBVPiwgJ2FjdGlvbic+O1xuXG4vKipcbiAqIEhlbHBlciB0eXBlIGZvciBJb0hvc3RzIHRoYXQgYXJlIGFjdGlvbiBhd2FyZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFjdGlvbkF3YXJlSW9Ib3N0IGV4dGVuZHMgSUlvSG9zdCB7XG4gIG5vdGlmeTxUPihtc2c6IEFjdGlvbkxlc3NNZXNzYWdlPFQ+KTogUHJvbWlzZTx2b2lkPjtcbiAgcmVxdWVzdFJlc3BvbnNlPFQsIFU+KG1zZzogQWN0aW9uTGVzc1JlcXVlc3Q8VCwgVT4pOiBQcm9taXNlPFU+O1xufVxuIl19