@aws-cdk/toolkit-lib 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/NOTICE +16 -0
- package/README.md +432 -0
- package/build-info.json +4 -0
- package/db.json.gz +0 -0
- package/lib/actions/deploy/index.d.ts +178 -0
- package/lib/actions/deploy/index.js +78 -0
- package/lib/actions/deploy/private/deploy-options.d.ts +78 -0
- package/lib/actions/deploy/private/deploy-options.js +3 -0
- package/lib/actions/deploy/private/helpers.d.ts +15 -0
- package/lib/actions/deploy/private/helpers.js +41 -0
- package/lib/actions/deploy/private/index.d.ts +2 -0
- package/lib/actions/deploy/private/index.js +19 -0
- package/lib/actions/destroy/index.d.ts +17 -0
- package/lib/actions/destroy/index.js +3 -0
- package/lib/actions/diff/index.d.ts +83 -0
- package/lib/actions/diff/index.js +45 -0
- package/lib/actions/diff/private/helpers.d.ts +7 -0
- package/lib/actions/diff/private/helpers.js +20 -0
- package/lib/actions/diff/private/index.d.ts +1 -0
- package/lib/actions/diff/private/index.js +18 -0
- package/lib/actions/import/index.d.ts +21 -0
- package/lib/actions/import/index.js +3 -0
- package/lib/actions/index.d.ts +6 -0
- package/lib/actions/index.js +23 -0
- package/lib/actions/list/index.d.ts +7 -0
- package/lib/actions/list/index.js +3 -0
- package/lib/actions/rollback/index.d.ts +39 -0
- package/lib/actions/rollback/index.js +3 -0
- package/lib/actions/synth/index.d.ts +12 -0
- package/lib/actions/synth/index.js +3 -0
- package/lib/actions/watch/index.d.ts +35 -0
- package/lib/actions/watch/index.js +3 -0
- package/lib/actions/watch/private/helpers.d.ts +4 -0
- package/lib/actions/watch/private/helpers.js +8 -0
- package/lib/actions/watch/private/index.d.ts +1 -0
- package/lib/actions/watch/private/index.js +18 -0
- package/lib/api/aws-auth/index.d.ts +1 -0
- package/lib/api/aws-auth/index.js +18 -0
- package/lib/api/aws-auth/types.d.ts +32 -0
- package/lib/api/aws-auth/types.js +3 -0
- package/lib/api/aws-cdk.d.ts +25 -0
- package/lib/api/aws-cdk.js +9329 -0
- package/lib/api/aws-cdk.js.map +7 -0
- package/lib/api/cloud-assembly/index.d.ts +3 -0
- package/lib/api/cloud-assembly/index.js +20 -0
- package/lib/api/cloud-assembly/private/cached-source.d.ts +15 -0
- package/lib/api/cloud-assembly/private/cached-source.js +25 -0
- package/lib/api/cloud-assembly/private/context-aware-source.d.ts +45 -0
- package/lib/api/cloud-assembly/private/context-aware-source.js +89 -0
- package/lib/api/cloud-assembly/private/exec.d.ts +13 -0
- package/lib/api/cloud-assembly/private/exec.js +56 -0
- package/lib/api/cloud-assembly/private/identity-source.d.ts +10 -0
- package/lib/api/cloud-assembly/private/identity-source.js +17 -0
- package/lib/api/cloud-assembly/private/index.d.ts +8 -0
- package/lib/api/cloud-assembly/private/index.js +25 -0
- package/lib/api/cloud-assembly/private/prepare-source.d.ts +52 -0
- package/lib/api/cloud-assembly/private/prepare-source.js +166 -0
- package/lib/api/cloud-assembly/private/source-builder.d.ts +29 -0
- package/lib/api/cloud-assembly/private/source-builder.js +121 -0
- package/lib/api/cloud-assembly/private/stack-assembly.d.ts +30 -0
- package/lib/api/cloud-assembly/private/stack-assembly.js +94 -0
- package/lib/api/cloud-assembly/private/stack-selectors.d.ts +2 -0
- package/lib/api/cloud-assembly/private/stack-selectors.js +8 -0
- package/lib/api/cloud-assembly/source-builder.d.ts +113 -0
- package/lib/api/cloud-assembly/source-builder.js +3 -0
- package/lib/api/cloud-assembly/stack-selector.d.ts +81 -0
- package/lib/api/cloud-assembly/stack-selector.js +64 -0
- package/lib/api/cloud-assembly/types.d.ts +7 -0
- package/lib/api/cloud-assembly/types.js +3 -0
- package/lib/api/errors.d.ts +44 -0
- package/lib/api/errors.js +82 -0
- package/lib/api/io/index.d.ts +2 -0
- package/lib/api/io/index.js +19 -0
- package/lib/api/io/io-host.d.ts +15 -0
- package/lib/api/io/io-host.js +3 -0
- package/lib/api/io/io-message.d.ts +59 -0
- package/lib/api/io/io-message.js +3 -0
- package/lib/api/io/private/codes.d.ts +37 -0
- package/lib/api/io/private/codes.js +48 -0
- package/lib/api/io/private/index.d.ts +6 -0
- package/lib/api/io/private/index.js +23 -0
- package/lib/api/io/private/level-priority.d.ts +11 -0
- package/lib/api/io/private/level-priority.js +33 -0
- package/lib/api/io/private/logger.d.ts +40 -0
- package/lib/api/io/private/logger.js +211 -0
- package/lib/api/io/private/messages.d.ts +64 -0
- package/lib/api/io/private/messages.js +159 -0
- package/lib/api/io/private/timer.d.ts +29 -0
- package/lib/api/io/private/timer.js +54 -0
- package/lib/api/io/private/types.d.ts +25 -0
- package/lib/api/io/private/types.js +3 -0
- package/lib/index.d.ts +6 -0
- package/lib/index.js +25 -0
- package/lib/index_bg.wasm +0 -0
- package/lib/toolkit/index.d.ts +1 -0
- package/lib/toolkit/index.js +18 -0
- package/lib/toolkit/private/index.d.ts +9 -0
- package/lib/toolkit/private/index.js +3 -0
- package/lib/toolkit/toolkit.d.ts +142 -0
- package/lib/toolkit/toolkit.js +644 -0
- package/package.json +147 -0
|
@@ -0,0 +1,211 @@
|
|
|
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"]}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import type { IoMessageLevel } from '../io-message';
|
|
2
|
+
import { type VALID_CODE } from './codes';
|
|
3
|
+
import type { ActionLessMessage, ActionLessRequest, IoMessageCodeCategory, Optional, SimplifiedMessage } from './types';
|
|
4
|
+
/**
|
|
5
|
+
* Internal helper that processes log inputs into a consistent format.
|
|
6
|
+
* Handles string interpolation, format strings, and object parameter styles.
|
|
7
|
+
* Applies optional styling and prepares the final message for logging.
|
|
8
|
+
*/
|
|
9
|
+
export declare function formatMessage<T>(msg: Optional<SimplifiedMessage<T>, 'code'>, category?: IoMessageCodeCategory): ActionLessMessage<T>;
|
|
10
|
+
/**
|
|
11
|
+
* Build a message code from level and category. The code must be valid for this function to pass.
|
|
12
|
+
* Otherwise it returns a ToolkitError.
|
|
13
|
+
*/
|
|
14
|
+
export declare function defaultMessageCode(level: IoMessageLevel, category?: IoMessageCodeCategory): VALID_CODE;
|
|
15
|
+
/**
|
|
16
|
+
* Requests a yes/no confirmation from the IoHost.
|
|
17
|
+
*/
|
|
18
|
+
export declare const confirm: (code: VALID_CODE, question: string, motivation: string, defaultResponse: boolean, concurrency?: number) => ActionLessRequest<{
|
|
19
|
+
motivation: string;
|
|
20
|
+
concurrency?: number;
|
|
21
|
+
}, boolean>;
|
|
22
|
+
/**
|
|
23
|
+
* Prompt for a a response from the IoHost.
|
|
24
|
+
*/
|
|
25
|
+
export declare const prompt: <T, U>(code: VALID_CODE, message: string, defaultResponse: U, payload?: T) => ActionLessRequest<T, U>;
|
|
26
|
+
/**
|
|
27
|
+
* Creates an error level message.
|
|
28
|
+
* Errors must always have a unique code.
|
|
29
|
+
*/
|
|
30
|
+
export declare const error: <T>(message: string, code: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
31
|
+
/**
|
|
32
|
+
* Creates a result level message and represents the most important message for a given action.
|
|
33
|
+
*
|
|
34
|
+
* They should be used sparsely, with an action usually having no or exactly one result.
|
|
35
|
+
* However actions that operate on Cloud Assemblies might include a result per Stack.
|
|
36
|
+
* Unlike other messages, results must always have a code and a payload.
|
|
37
|
+
*/
|
|
38
|
+
export declare const result: <T>(message: string, code: VALID_CODE, payload: T) => ActionLessMessage<T>;
|
|
39
|
+
/**
|
|
40
|
+
* Creates a warning level message.
|
|
41
|
+
*/
|
|
42
|
+
export declare const warn: <T>(message: string, code?: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
43
|
+
/**
|
|
44
|
+
* Creates an info level message.
|
|
45
|
+
*/
|
|
46
|
+
export declare const info: <T>(message: string, code?: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
47
|
+
/**
|
|
48
|
+
* Creates a debug level message.
|
|
49
|
+
*/
|
|
50
|
+
export declare const debug: <T>(message: string, code?: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
51
|
+
/**
|
|
52
|
+
* Creates a trace level message.
|
|
53
|
+
*/
|
|
54
|
+
export declare const trace: <T>(message: string, code?: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
55
|
+
/**
|
|
56
|
+
* Creates an info level success message in green text.
|
|
57
|
+
* @deprecated
|
|
58
|
+
*/
|
|
59
|
+
export declare const success: <T>(message: string, code?: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
60
|
+
/**
|
|
61
|
+
* Creates an info level message in bold text.
|
|
62
|
+
* @deprecated
|
|
63
|
+
*/
|
|
64
|
+
export declare const highlight: <T>(message: string, code?: VALID_CODE, payload?: T) => ActionLessMessage<T>;
|
|
@@ -0,0 +1,159 @@
|
|
|
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.formatMessage = formatMessage;
|
|
5
|
+
exports.defaultMessageCode = defaultMessageCode;
|
|
6
|
+
const chalk = require("chalk");
|
|
7
|
+
/**
|
|
8
|
+
* Internal helper that processes log inputs into a consistent format.
|
|
9
|
+
* Handles string interpolation, format strings, and object parameter styles.
|
|
10
|
+
* Applies optional styling and prepares the final message for logging.
|
|
11
|
+
*/
|
|
12
|
+
function formatMessage(msg, category = 'TOOLKIT') {
|
|
13
|
+
return {
|
|
14
|
+
time: new Date(),
|
|
15
|
+
level: msg.level,
|
|
16
|
+
code: msg.code ?? defaultMessageCode(msg.level, category),
|
|
17
|
+
message: msg.message,
|
|
18
|
+
data: msg.data,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Build a message code from level and category. The code must be valid for this function to pass.
|
|
23
|
+
* Otherwise it returns a ToolkitError.
|
|
24
|
+
*/
|
|
25
|
+
function defaultMessageCode(level, category = 'TOOLKIT') {
|
|
26
|
+
const levelIndicator = level === 'error' ? 'E' :
|
|
27
|
+
level === 'warn' ? 'W' :
|
|
28
|
+
'I';
|
|
29
|
+
return `CDK_${category}_${levelIndicator}0000`;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Requests a yes/no confirmation from the IoHost.
|
|
33
|
+
*/
|
|
34
|
+
const confirm = (code, question, motivation, defaultResponse, concurrency) => {
|
|
35
|
+
return (0, exports.prompt)(code, `${chalk.cyan(question)} (y/n)?`, defaultResponse, {
|
|
36
|
+
motivation,
|
|
37
|
+
concurrency,
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
exports.confirm = confirm;
|
|
41
|
+
/**
|
|
42
|
+
* Prompt for a a response from the IoHost.
|
|
43
|
+
*/
|
|
44
|
+
const prompt = (code, message, defaultResponse, payload) => {
|
|
45
|
+
return {
|
|
46
|
+
defaultResponse,
|
|
47
|
+
...formatMessage({
|
|
48
|
+
level: 'info',
|
|
49
|
+
code,
|
|
50
|
+
message,
|
|
51
|
+
data: payload,
|
|
52
|
+
}),
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
exports.prompt = prompt;
|
|
56
|
+
/**
|
|
57
|
+
* Creates an error level message.
|
|
58
|
+
* Errors must always have a unique code.
|
|
59
|
+
*/
|
|
60
|
+
const error = (message, code, payload) => {
|
|
61
|
+
return formatMessage({
|
|
62
|
+
level: 'error',
|
|
63
|
+
code,
|
|
64
|
+
message,
|
|
65
|
+
data: payload,
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
exports.error = error;
|
|
69
|
+
/**
|
|
70
|
+
* Creates a result level message and represents the most important message for a given action.
|
|
71
|
+
*
|
|
72
|
+
* They should be used sparsely, with an action usually having no or exactly one result.
|
|
73
|
+
* However actions that operate on Cloud Assemblies might include a result per Stack.
|
|
74
|
+
* Unlike other messages, results must always have a code and a payload.
|
|
75
|
+
*/
|
|
76
|
+
const result = (message, code, payload) => {
|
|
77
|
+
return formatMessage({
|
|
78
|
+
level: 'result',
|
|
79
|
+
code,
|
|
80
|
+
message,
|
|
81
|
+
data: payload,
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
exports.result = result;
|
|
85
|
+
/**
|
|
86
|
+
* Creates a warning level message.
|
|
87
|
+
*/
|
|
88
|
+
const warn = (message, code, payload) => {
|
|
89
|
+
return formatMessage({
|
|
90
|
+
level: 'warn',
|
|
91
|
+
code,
|
|
92
|
+
message,
|
|
93
|
+
data: payload,
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
exports.warn = warn;
|
|
97
|
+
/**
|
|
98
|
+
* Creates an info level message.
|
|
99
|
+
*/
|
|
100
|
+
const info = (message, code, payload) => {
|
|
101
|
+
return formatMessage({
|
|
102
|
+
level: 'info',
|
|
103
|
+
code,
|
|
104
|
+
message,
|
|
105
|
+
data: payload,
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
exports.info = info;
|
|
109
|
+
/**
|
|
110
|
+
* Creates a debug level message.
|
|
111
|
+
*/
|
|
112
|
+
const debug = (message, code, payload) => {
|
|
113
|
+
return formatMessage({
|
|
114
|
+
level: 'debug',
|
|
115
|
+
code,
|
|
116
|
+
message,
|
|
117
|
+
data: payload,
|
|
118
|
+
});
|
|
119
|
+
};
|
|
120
|
+
exports.debug = debug;
|
|
121
|
+
/**
|
|
122
|
+
* Creates a trace level message.
|
|
123
|
+
*/
|
|
124
|
+
const trace = (message, code, payload) => {
|
|
125
|
+
return formatMessage({
|
|
126
|
+
level: 'trace',
|
|
127
|
+
code,
|
|
128
|
+
message,
|
|
129
|
+
data: payload,
|
|
130
|
+
});
|
|
131
|
+
};
|
|
132
|
+
exports.trace = trace;
|
|
133
|
+
/**
|
|
134
|
+
* Creates an info level success message in green text.
|
|
135
|
+
* @deprecated
|
|
136
|
+
*/
|
|
137
|
+
const success = (message, code, payload) => {
|
|
138
|
+
return formatMessage({
|
|
139
|
+
level: 'info',
|
|
140
|
+
code,
|
|
141
|
+
message: chalk.green(message),
|
|
142
|
+
data: payload,
|
|
143
|
+
});
|
|
144
|
+
};
|
|
145
|
+
exports.success = success;
|
|
146
|
+
/**
|
|
147
|
+
* Creates an info level message in bold text.
|
|
148
|
+
* @deprecated
|
|
149
|
+
*/
|
|
150
|
+
const highlight = (message, code, payload) => {
|
|
151
|
+
return formatMessage({
|
|
152
|
+
level: 'info',
|
|
153
|
+
code,
|
|
154
|
+
message: chalk.bold(message),
|
|
155
|
+
data: payload,
|
|
156
|
+
});
|
|
157
|
+
};
|
|
158
|
+
exports.highlight = highlight;
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["messages.ts"],"names":[],"mappings":";;;AAUA,sCAQC;AAMD,gDAKC;AA7BD,+BAA+B;AAK/B;;;;GAIG;AACH,SAAgB,aAAa,CAAI,GAA2C,EAAE,WAAkC,SAAS;IACvH,OAAO;QACL,IAAI,EAAE,IAAI,IAAI,EAAE;QAChB,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,IAAI,EAAE,GAAG,CAAC,IAAI,IAAI,kBAAkB,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC;QACzD,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,IAAI,EAAE,GAAG,CAAC,IAAI;KACf,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,SAAgB,kBAAkB,CAAC,KAAqB,EAAE,WAAkC,SAAS;IACnG,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,MAAoB,CAAC;AAC/D,CAAC;AAED;;GAEG;AACI,MAAM,OAAO,GAAG,CACrB,IAAgB,EAChB,QAAgB,EAChB,UAAkB,EAClB,eAAwB,EACxB,WAAoB,EAIV,EAAE;IACZ,OAAO,IAAA,cAAM,EAAC,IAAI,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,eAAe,EAAE;QACrE,UAAU;QACV,WAAW;KACZ,CAAC,CAAC;AACL,CAAC,CAAC;AAdW,QAAA,OAAO,WAclB;AAEF;;GAEG;AACI,MAAM,MAAM,GAAG,CAAO,IAAgB,EAAE,OAAe,EAAE,eAAkB,EAAE,OAAW,EAA2B,EAAE;IAC1H,OAAO;QACL,eAAe;QACf,GAAG,aAAa,CAAC;YACf,KAAK,EAAE,MAAM;YACb,IAAI;YACJ,OAAO;YACP,IAAI,EAAE,OAAO;SACd,CAAC;KACH,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,MAAM,UAUjB;AAEF;;;GAGG;AACI,MAAM,KAAK,GAAG,CAAI,OAAe,EAAE,IAAgB,EAAE,OAAW,EAAE,EAAE;IACzE,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,OAAO;QACd,IAAI;QACJ,OAAO;QACP,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,KAAK,SAOhB;AAEF;;;;;;GAMG;AACI,MAAM,MAAM,GAAG,CAAI,OAAe,EAAE,IAAgB,EAAE,OAAU,EAAE,EAAE;IACzE,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,QAAQ;QACf,IAAI;QACJ,OAAO;QACP,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,MAAM,UAOjB;AAEF;;GAEG;AACI,MAAM,IAAI,GAAG,CAAI,OAAe,EAAE,IAAiB,EAAE,OAAW,EAAE,EAAE;IACzE,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,MAAM;QACb,IAAI;QACJ,OAAO;QACP,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,IAAI,QAOf;AAEF;;GAEG;AACI,MAAM,IAAI,GAAG,CAAI,OAAe,EAAE,IAAiB,EAAE,OAAW,EAAE,EAAE;IACzE,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,MAAM;QACb,IAAI;QACJ,OAAO;QACP,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,IAAI,QAOf;AAEF;;GAEG;AACI,MAAM,KAAK,GAAG,CAAI,OAAe,EAAE,IAAiB,EAAE,OAAW,EAAE,EAAE;IAC1E,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,OAAO;QACd,IAAI;QACJ,OAAO;QACP,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,KAAK,SAOhB;AAEF;;GAEG;AACI,MAAM,KAAK,GAAG,CAAI,OAAe,EAAE,IAAiB,EAAE,OAAW,EAAE,EAAE;IAC1E,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,OAAO;QACd,IAAI;QACJ,OAAO;QACP,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,KAAK,SAOhB;AAEF;;;GAGG;AACI,MAAM,OAAO,GAAG,CAAI,OAAe,EAAE,IAAiB,EAAE,OAAW,EAAE,EAAE;IAC5E,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,MAAM;QACb,IAAI;QACJ,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC;QAC7B,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,OAAO,WAOlB;AAEF;;;GAGG;AACI,MAAM,SAAS,GAAG,CAAI,OAAe,EAAE,IAAiB,EAAE,OAAW,EAAE,EAAE;IAC9E,OAAO,aAAa,CAAC;QACnB,KAAK,EAAE,MAAM;QACb,IAAI;QACJ,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,EAAE,OAAO;KACd,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,SAAS,aAOpB","sourcesContent":["import * as chalk from 'chalk';\nimport type { IoMessageLevel } from '../io-message';\nimport { type VALID_CODE } 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 */\nexport function 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),\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'): VALID_CODE {\n  const levelIndicator = level === 'error' ? 'E' :\n    level === 'warn' ? 'W' :\n      'I';\n  return `CDK_${category}_${levelIndicator}0000` as VALID_CODE;\n}\n\n/**\n * Requests a yes/no confirmation from the IoHost.\n */\nexport const confirm = (\n  code: VALID_CODE,\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 a response from the IoHost.\n */\nexport const prompt = <T, U>(code: VALID_CODE, message: string, defaultResponse: U, payload?: T): ActionLessRequest<T, U> => {\n  return {\n    defaultResponse,\n    ...formatMessage({\n      level: 'info',\n      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: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'error',\n    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: VALID_CODE, payload: T) => {\n  return formatMessage({\n    level: 'result',\n    code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a warning level message.\n */\nexport const warn = <T>(message: string, code?: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'warn',\n    code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates an info level message.\n */\nexport const info = <T>(message: string, code?: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'info',\n    code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a debug level message.\n */\nexport const debug = <T>(message: string, code?: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'debug',\n    code,\n    message,\n    data: payload,\n  });\n};\n\n/**\n * Creates a trace level message.\n */\nexport const trace = <T>(message: string, code?: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'trace',\n    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?: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'info',\n    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?: VALID_CODE, payload?: T) => {\n  return formatMessage({\n    level: 'info',\n    code,\n    message: chalk.bold(message),\n    data: payload,\n  });\n};\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Timer = void 0;
|
|
4
|
+
const messages_1 = require("./messages");
|
|
5
|
+
const aws_cdk_1 = require("../../aws-cdk");
|
|
6
|
+
/**
|
|
7
|
+
* Helper class to measure the time of code.
|
|
8
|
+
*/
|
|
9
|
+
class Timer {
|
|
10
|
+
/**
|
|
11
|
+
* Start the timer.
|
|
12
|
+
* @return the timer instance
|
|
13
|
+
*/
|
|
14
|
+
static start() {
|
|
15
|
+
return new Timer();
|
|
16
|
+
}
|
|
17
|
+
startTime;
|
|
18
|
+
constructor() {
|
|
19
|
+
this.startTime = new Date().getTime();
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* End the current timer.
|
|
23
|
+
* @returns the elapsed time
|
|
24
|
+
*/
|
|
25
|
+
end() {
|
|
26
|
+
const elapsedTime = new Date().getTime() - this.startTime;
|
|
27
|
+
return {
|
|
28
|
+
asMs: elapsedTime,
|
|
29
|
+
asSec: (0, aws_cdk_1.formatTime)(elapsedTime),
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Ends the current timer as a specified timing and notifies the IoHost.
|
|
34
|
+
* @returns the elapsed time
|
|
35
|
+
*/
|
|
36
|
+
async endAs(ioHost, type) {
|
|
37
|
+
const duration = this.end();
|
|
38
|
+
const { code, text } = timerMessageProps(type);
|
|
39
|
+
await ioHost.notify((0, messages_1.info)(`\n✨ ${text} time: ${duration.asSec}s\n`, code, {
|
|
40
|
+
duration: duration.asMs,
|
|
41
|
+
}));
|
|
42
|
+
return duration;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.Timer = Timer;
|
|
46
|
+
function timerMessageProps(type) {
|
|
47
|
+
switch (type) {
|
|
48
|
+
case 'synth': return { code: 'CDK_TOOLKIT_I1000', text: 'Synthesis' };
|
|
49
|
+
case 'deploy': return { code: 'CDK_TOOLKIT_I5000', text: 'Deployment' };
|
|
50
|
+
case 'rollback': return { code: 'CDK_TOOLKIT_I6000', text: 'Rollback' };
|
|
51
|
+
case 'destroy': return { code: 'CDK_TOOLKIT_I7000', text: 'Destroy' };
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0aW1lci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSx5Q0FBa0M7QUFFbEMsMkNBQTJDO0FBRTNDOztHQUVHO0FBQ0gsTUFBYSxLQUFLO0lBQ2hCOzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxLQUFLO1FBQ2pCLE9BQU8sSUFBSSxLQUFLLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRWdCLFNBQVMsQ0FBUztJQUVuQztRQUNFLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN4QyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksR0FBRztRQUNSLE1BQU0sV0FBVyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUMxRCxPQUFPO1lBQ0wsSUFBSSxFQUFFLFdBQVc7WUFDakIsS0FBSyxFQUFFLElBQUEsb0JBQVUsRUFBQyxXQUFXLENBQUM7U0FDL0IsQ0FBQztJQUNKLENBQUM7SUFFRDs7O09BR0c7SUFDSSxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQXlCLEVBQUUsSUFBaUQ7UUFDN0YsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQzVCLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFL0MsTUFBTSxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUEsZUFBSSxFQUFDLFFBQVEsSUFBSSxVQUFVLFFBQVEsQ0FBQyxLQUFLLEtBQUssRUFBRSxJQUFJLEVBQUU7WUFDeEUsUUFBUSxFQUFFLFFBQVEsQ0FBQyxJQUFJO1NBQ3hCLENBQUMsQ0FBQyxDQUFDO1FBRUosT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztDQUNGO0FBekNELHNCQXlDQztBQUVELFNBQVMsaUJBQWlCLENBQUMsSUFBZ0Q7SUFJekUsUUFBUSxJQUFJLEVBQUUsQ0FBQztRQUNiLEtBQUssT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxtQkFBbUIsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLENBQUM7UUFDdEUsS0FBSyxRQUFRLENBQUMsQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLG1CQUFtQixFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsQ0FBQztRQUN4RSxLQUFLLFVBQVUsQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsbUJBQW1CLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDO1FBQ3hFLEtBQUssU0FBUyxDQUFDLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxtQkFBbUIsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7SUFDeEUsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWQUxJRF9DT0RFIH0gZnJvbSAnLi9jb2Rlcyc7XG5pbXBvcnQgeyBpbmZvIH0gZnJvbSAnLi9tZXNzYWdlcyc7XG5pbXBvcnQgeyBBY3Rpb25Bd2FyZUlvSG9zdCB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgZm9ybWF0VGltZSB9IGZyb20gJy4uLy4uL2F3cy1jZGsnO1xuXG4vKipcbiAqIEhlbHBlciBjbGFzcyB0byBtZWFzdXJlIHRoZSB0aW1lIG9mIGNvZGUuXG4gKi9cbmV4cG9ydCBjbGFzcyBUaW1lciB7XG4gIC8qKlxuICAgKiBTdGFydCB0aGUgdGltZXIuXG4gICAqIEByZXR1cm4gdGhlIHRpbWVyIGluc3RhbmNlXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHN0YXJ0KCk6IFRpbWVyIHtcbiAgICByZXR1cm4gbmV3IFRpbWVyKCk7XG4gIH1cblxuICBwcml2YXRlIHJlYWRvbmx5IHN0YXJ0VGltZTogbnVtYmVyO1xuXG4gIHByaXZhdGUgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5zdGFydFRpbWUgPSBuZXcgRGF0ZSgpLmdldFRpbWUoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFbmQgdGhlIGN1cnJlbnQgdGltZXIuXG4gICAqIEByZXR1cm5zIHRoZSBlbGFwc2VkIHRpbWVcbiAgICovXG4gIHB1YmxpYyBlbmQoKSB7XG4gICAgY29uc3QgZWxhcHNlZFRpbWUgPSBuZXcgRGF0ZSgpLmdldFRpbWUoKSAtIHRoaXMuc3RhcnRUaW1lO1xuICAgIHJldHVybiB7XG4gICAgICBhc01zOiBlbGFwc2VkVGltZSxcbiAgICAgIGFzU2VjOiBmb3JtYXRUaW1lKGVsYXBzZWRUaW1lKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIEVuZHMgdGhlIGN1cnJlbnQgdGltZXIgYXMgYSBzcGVjaWZpZWQgdGltaW5nIGFuZCBub3RpZmllcyB0aGUgSW9Ib3N0LlxuICAgKiBAcmV0dXJucyB0aGUgZWxhcHNlZCB0aW1lXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZW5kQXMoaW9Ib3N0OiBBY3Rpb25Bd2FyZUlvSG9zdCwgdHlwZTogJ3N5bnRoJyB8ICdkZXBsb3knIHwgJ3JvbGxiYWNrJyB8ICdkZXN0cm95Jykge1xuICAgIGNvbnN0IGR1cmF0aW9uID0gdGhpcy5lbmQoKTtcbiAgICBjb25zdCB7IGNvZGUsIHRleHQgfSA9IHRpbWVyTWVzc2FnZVByb3BzKHR5cGUpO1xuXG4gICAgYXdhaXQgaW9Ib3N0Lm5vdGlmeShpbmZvKGBcXG7inKggICR7dGV4dH0gdGltZTogJHtkdXJhdGlvbi5hc1NlY31zXFxuYCwgY29kZSwge1xuICAgICAgZHVyYXRpb246IGR1cmF0aW9uLmFzTXMsXG4gICAgfSkpO1xuXG4gICAgcmV0dXJuIGR1cmF0aW9uO1xuICB9XG59XG5cbmZ1bmN0aW9uIHRpbWVyTWVzc2FnZVByb3BzKHR5cGU6ICdzeW50aCcgfCAnZGVwbG95JyB8ICdyb2xsYmFjayd8ICdkZXN0cm95Jyk6IHtcbiAgY29kZTogVkFMSURfQ09ERTtcbiAgdGV4dDogc3RyaW5nO1xufSB7XG4gIHN3aXRjaCAodHlwZSkge1xuICAgIGNhc2UgJ3N5bnRoJzogcmV0dXJuIHsgY29kZTogJ0NES19UT09MS0lUX0kxMDAwJywgdGV4dDogJ1N5bnRoZXNpcycgfTtcbiAgICBjYXNlICdkZXBsb3knOiByZXR1cm4geyBjb2RlOiAnQ0RLX1RPT0xLSVRfSTUwMDAnLCB0ZXh0OiAnRGVwbG95bWVudCcgfTtcbiAgICBjYXNlICdyb2xsYmFjayc6IHJldHVybiB7IGNvZGU6ICdDREtfVE9PTEtJVF9JNjAwMCcsIHRleHQ6ICdSb2xsYmFjaycgfTtcbiAgICBjYXNlICdkZXN0cm95JzogcmV0dXJuIHsgY29kZTogJ0NES19UT09MS0lUX0k3MDAwJywgdGV4dDogJ0Rlc3Ryb3knIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,25 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
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
|
package/lib/index.d.ts
ADDED
package/lib/index.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
// The main show
|
|
18
|
+
__exportStar(require("./toolkit"), exports);
|
|
19
|
+
__exportStar(require("./actions"), exports);
|
|
20
|
+
// Supporting acts
|
|
21
|
+
__exportStar(require("./api/aws-auth"), exports);
|
|
22
|
+
__exportStar(require("./api/cloud-assembly"), exports);
|
|
23
|
+
__exportStar(require("./api/io"), exports);
|
|
24
|
+
__exportStar(require("./api/errors"), exports);
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsZ0JBQWdCO0FBQ2hCLDRDQUEwQjtBQUMxQiw0Q0FBMEI7QUFFMUIsa0JBQWtCO0FBQ2xCLGlEQUErQjtBQUMvQix1REFBcUM7QUFDckMsMkNBQXlCO0FBQ3pCLCtDQUE2QiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFRoZSBtYWluIHNob3dcbmV4cG9ydCAqIGZyb20gJy4vdG9vbGtpdCc7XG5leHBvcnQgKiBmcm9tICcuL2FjdGlvbnMnO1xuXG4vLyBTdXBwb3J0aW5nIGFjdHNcbmV4cG9ydCAqIGZyb20gJy4vYXBpL2F3cy1hdXRoJztcbmV4cG9ydCAqIGZyb20gJy4vYXBpL2Nsb3VkLWFzc2VtYmx5JztcbmV4cG9ydCAqIGZyb20gJy4vYXBpL2lvJztcbmV4cG9ydCAqIGZyb20gJy4vYXBpL2Vycm9ycyc7XG4iXX0=
|
|
Binary file
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './toolkit';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./toolkit"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsNENBQTBCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90b29sa2l0JztcbiJdfQ==
|