aws-cdk 2.1001.0 → 2.1002.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/README.md +15 -0
- package/THIRD_PARTY_LICENSES +41 -41
- package/build-info.json +2 -2
- package/lib/api/bootstrap/bootstrap-template.yaml +3 -1
- package/lib/api/deployments/deploy-stack.d.ts +0 -20
- package/lib/api/deployments/deploy-stack.js +25 -20
- package/lib/api/deployments/deployments.d.ts +0 -27
- package/lib/api/deployments/deployments.js +13 -13
- package/lib/api/resource-import/importer.d.ts +0 -8
- package/lib/api/resource-import/importer.js +1 -1
- package/lib/api/resource-import/migrator.js +1 -2
- package/lib/api/stack-events/stack-activity-monitor.d.ts +87 -165
- package/lib/api/stack-events/stack-activity-monitor.js +61 -445
- package/lib/api/stack-events/stack-event-poller.d.ts +6 -0
- package/lib/api/stack-events/stack-event-poller.js +1 -1
- package/lib/api/stack-events/stack-progress-monitor.d.ts +61 -0
- package/lib/api/stack-events/stack-progress-monitor.js +94 -0
- package/lib/api/work-graph/work-graph-builder.js +4 -4
- package/lib/cli/activity-printer/base.d.ts +51 -0
- package/lib/cli/activity-printer/base.js +115 -0
- package/lib/cli/activity-printer/current.d.ts +25 -0
- package/lib/cli/activity-printer/current.js +122 -0
- package/lib/cli/activity-printer/history.d.ts +31 -0
- package/lib/cli/activity-printer/history.js +109 -0
- package/lib/cli/activity-printer/index.d.ts +3 -0
- package/lib/cli/activity-printer/index.js +20 -0
- package/lib/cli/cdk-toolkit.d.ts +1 -1
- package/lib/cli/cdk-toolkit.js +10 -9
- package/lib/cli/cli-config.js +5 -4
- package/lib/cli/cli.js +3 -1
- package/lib/cli/convert-to-user-input.js +18 -16
- package/lib/cli/parse-command-line-arguments.js +7 -1
- package/lib/cli/user-input.d.ts +8 -0
- package/lib/cli/user-input.js +1 -1
- package/lib/commands/deploy.d.ts +13 -0
- package/lib/commands/deploy.js +18 -0
- package/lib/context-providers/cc-api-provider.js +2 -2
- package/lib/index.js +18101 -16933
- package/lib/init.d.ts +5 -1
- package/lib/init.js +11 -8
- package/lib/legacy-exports-source.d.ts +1 -1
- package/lib/legacy-exports-source.js +2 -2
- package/lib/notices.js +2 -2
- package/lib/toolkit/cli-io-host.d.ts +28 -0
- package/lib/toolkit/cli-io-host.js +74 -2
- package/lib/toolkit/error.d.ts +1 -44
- package/lib/toolkit/error.js +16 -76
- package/lib/util/cloudformation.d.ts +12 -0
- package/lib/util/cloudformation.js +27 -1
- package/lib/util/string-manipulation.d.ts +5 -1
- package/lib/util/string-manipulation.js +11 -5
- package/package.json +25 -24
- /package/lib/{api/stack-events → cli/activity-printer}/display.d.ts +0 -0
- /package/lib/{api/stack-events → cli/activity-printer}/display.js +0 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CurrentActivityPrinter = void 0;
|
|
4
|
+
const util = require("util");
|
|
5
|
+
const chalk = require("chalk");
|
|
6
|
+
const base_1 = require("./base");
|
|
7
|
+
const display_1 = require("./display");
|
|
8
|
+
const util_1 = require("../../util");
|
|
9
|
+
/**
|
|
10
|
+
* Activity Printer which shows the resources currently being updated
|
|
11
|
+
*
|
|
12
|
+
* It will continuously re-update the terminal and show only the resources
|
|
13
|
+
* that are currently being updated, in addition to a progress bar which
|
|
14
|
+
* shows how far along the deployment is.
|
|
15
|
+
*
|
|
16
|
+
* Resources that have failed will always be shown, and will be recapitulated
|
|
17
|
+
* along with their stack trace when the monitoring ends.
|
|
18
|
+
*
|
|
19
|
+
* Resources that failed deployment because they have been cancelled are
|
|
20
|
+
* not included.
|
|
21
|
+
*/
|
|
22
|
+
class CurrentActivityPrinter extends base_1.ActivityPrinterBase {
|
|
23
|
+
constructor(props) {
|
|
24
|
+
super(props);
|
|
25
|
+
this.block = new display_1.RewritableBlock(this.stream);
|
|
26
|
+
}
|
|
27
|
+
print() {
|
|
28
|
+
var _a;
|
|
29
|
+
const lines = [];
|
|
30
|
+
// Add a progress bar at the top
|
|
31
|
+
const progressWidth = Math.max(Math.min(((_a = this.block.width) !== null && _a !== void 0 ? _a : 80) - PROGRESSBAR_EXTRA_SPACE - 1, MAX_PROGRESSBAR_WIDTH), MIN_PROGRESSBAR_WIDTH);
|
|
32
|
+
const prog = this.progressBar(progressWidth);
|
|
33
|
+
if (prog) {
|
|
34
|
+
lines.push(' ' + prog, '');
|
|
35
|
+
}
|
|
36
|
+
// Normally we'd only print "resources in progress", but it's also useful
|
|
37
|
+
// to keep an eye on the failures and know about the specific errors asquickly
|
|
38
|
+
// as possible (while the stack is still rolling back), so add those in.
|
|
39
|
+
const toPrint = [...this.failures, ...Object.values(this.resourcesInProgress)];
|
|
40
|
+
toPrint.sort((a, b) => a.event.Timestamp.getTime() - b.event.Timestamp.getTime());
|
|
41
|
+
lines.push(...toPrint.map((res) => {
|
|
42
|
+
var _a, _b, _c;
|
|
43
|
+
const color = colorFromStatusActivity(res.event.ResourceStatus);
|
|
44
|
+
const resourceName = (_c = (_b = (_a = res.metadata) === null || _a === void 0 ? void 0 : _a.constructPath) !== null && _b !== void 0 ? _b : res.event.LogicalResourceId) !== null && _c !== void 0 ? _c : '';
|
|
45
|
+
return util.format('%s | %s | %s | %s%s', (0, util_1.padLeft)(CurrentActivityPrinter.TIMESTAMP_WIDTH, new Date(res.event.Timestamp).toLocaleTimeString()), color((0, util_1.padRight)(CurrentActivityPrinter.STATUS_WIDTH, (res.event.ResourceStatus || '').slice(0, CurrentActivityPrinter.STATUS_WIDTH))), (0, util_1.padRight)(this.resourceTypeColumnWidth, res.event.ResourceType || ''), color(chalk.bold(shorten(40, resourceName))), this.failureReasonOnNextLine(res));
|
|
46
|
+
}));
|
|
47
|
+
this.block.displayLines(lines);
|
|
48
|
+
}
|
|
49
|
+
stop() {
|
|
50
|
+
var _a, _b, _c;
|
|
51
|
+
super.stop();
|
|
52
|
+
// Print failures at the end
|
|
53
|
+
const lines = new Array();
|
|
54
|
+
for (const failure of this.failures) {
|
|
55
|
+
// Root stack failures are not interesting
|
|
56
|
+
if (this.isActivityForTheStack(failure)) {
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
lines.push(util.format(chalk.red('%s | %s | %s | %s%s') + '\n', (0, util_1.padLeft)(CurrentActivityPrinter.TIMESTAMP_WIDTH, new Date(failure.event.Timestamp).toLocaleTimeString()), (0, util_1.padRight)(CurrentActivityPrinter.STATUS_WIDTH, (failure.event.ResourceStatus || '').slice(0, CurrentActivityPrinter.STATUS_WIDTH)), (0, util_1.padRight)(this.resourceTypeColumnWidth, failure.event.ResourceType || ''), shorten(40, (_a = failure.event.LogicalResourceId) !== null && _a !== void 0 ? _a : ''), this.failureReasonOnNextLine(failure)));
|
|
60
|
+
const trace = (_c = (_b = failure.metadata) === null || _b === void 0 ? void 0 : _b.entry) === null || _c === void 0 ? void 0 : _c.trace;
|
|
61
|
+
if (trace) {
|
|
62
|
+
lines.push(chalk.red(`\t${trace.join('\n\t\\_ ')}\n`));
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
// Display in the same block space, otherwise we're going to have silly empty lines.
|
|
66
|
+
this.block.displayLines(lines);
|
|
67
|
+
this.block.removeEmptyLines();
|
|
68
|
+
}
|
|
69
|
+
progressBar(width) {
|
|
70
|
+
if (!this.stackProgress || !this.stackProgress.total) {
|
|
71
|
+
return '';
|
|
72
|
+
}
|
|
73
|
+
const fraction = Math.min(this.stackProgress.completed / this.stackProgress.total, 1);
|
|
74
|
+
const innerWidth = Math.max(1, width - 2);
|
|
75
|
+
const chars = innerWidth * fraction;
|
|
76
|
+
const remainder = chars - Math.floor(chars);
|
|
77
|
+
const fullChars = FULL_BLOCK.repeat(Math.floor(chars));
|
|
78
|
+
const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];
|
|
79
|
+
const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));
|
|
80
|
+
const color = this.rollingBack ? chalk.yellow : chalk.green;
|
|
81
|
+
return '[' + color(fullChars + partialChar) + filler + `] (${this.stackProgress.completed}/${this.stackProgress.total})`;
|
|
82
|
+
}
|
|
83
|
+
failureReasonOnNextLine(activity) {
|
|
84
|
+
var _a, _b;
|
|
85
|
+
return (0, util_1.stackEventHasErrorMessage)((_a = activity.event.ResourceStatus) !== null && _a !== void 0 ? _a : '')
|
|
86
|
+
? `\n${' '.repeat(CurrentActivityPrinter.TIMESTAMP_WIDTH + CurrentActivityPrinter.STATUS_WIDTH + 6)}${chalk.red((_b = this.failureReason(activity)) !== null && _b !== void 0 ? _b : '')}`
|
|
87
|
+
: '';
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.CurrentActivityPrinter = CurrentActivityPrinter;
|
|
91
|
+
const FULL_BLOCK = '█';
|
|
92
|
+
const PARTIAL_BLOCK = ['', '▏', '▎', '▍', '▌', '▋', '▊', '▉'];
|
|
93
|
+
const MAX_PROGRESSBAR_WIDTH = 60;
|
|
94
|
+
const MIN_PROGRESSBAR_WIDTH = 10;
|
|
95
|
+
const PROGRESSBAR_EXTRA_SPACE = 2 /* leading spaces */ + 2 /* brackets */ + 4 /* progress number decoration */ + 6; /* 2 progress numbers up to 999 */
|
|
96
|
+
function colorFromStatusActivity(status) {
|
|
97
|
+
if (!status) {
|
|
98
|
+
return chalk.reset;
|
|
99
|
+
}
|
|
100
|
+
if (status.endsWith('_FAILED')) {
|
|
101
|
+
return chalk.red;
|
|
102
|
+
}
|
|
103
|
+
if (status.startsWith('CREATE_') || status.startsWith('UPDATE_') || status.startsWith('IMPORT_')) {
|
|
104
|
+
return chalk.green;
|
|
105
|
+
}
|
|
106
|
+
// For stacks, it may also be 'UPDDATE_ROLLBACK_IN_PROGRESS'
|
|
107
|
+
if (status.indexOf('ROLLBACK_') !== -1) {
|
|
108
|
+
return chalk.yellow;
|
|
109
|
+
}
|
|
110
|
+
if (status.startsWith('DELETE_')) {
|
|
111
|
+
return chalk.yellow;
|
|
112
|
+
}
|
|
113
|
+
return chalk.reset;
|
|
114
|
+
}
|
|
115
|
+
function shorten(maxWidth, p) {
|
|
116
|
+
if (p.length <= maxWidth) {
|
|
117
|
+
return p;
|
|
118
|
+
}
|
|
119
|
+
const half = Math.floor((maxWidth - 3) / 2);
|
|
120
|
+
return p.slice(0, half) + '...' + p.slice(-half);
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"current.js","sourceRoot":"","sources":["current.ts"],"names":[],"mappings":"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","sourcesContent":["import * as util from 'util';\nimport * as chalk from 'chalk';\nimport { ActivityPrinterBase, ActivityPrinterProps } from './base';\nimport { RewritableBlock } from './display';\nimport type { StackActivity } from '../../api/stack-events';\nimport { padLeft, padRight, stackEventHasErrorMessage } from '../../util';\n\n/**\n * Activity Printer which shows the resources currently being updated\n *\n * It will continuously re-update the terminal and show only the resources\n * that are currently being updated, in addition to a progress bar which\n * shows how far along the deployment is.\n *\n * Resources that have failed will always be shown, and will be recapitulated\n * along with their stack trace when the monitoring ends.\n *\n * Resources that failed deployment because they have been cancelled are\n * not included.\n */\nexport class CurrentActivityPrinter extends ActivityPrinterBase {\n  /**\n   * Continuously write to the same output block.\n   */\n  private block: RewritableBlock;\n\n  constructor(props: ActivityPrinterProps) {\n    super(props);\n    this.block = new RewritableBlock(this.stream);\n  }\n\n  protected print(): void {\n    const lines = [];\n\n    // Add a progress bar at the top\n    const progressWidth = Math.max(\n      Math.min((this.block.width ?? 80) - PROGRESSBAR_EXTRA_SPACE - 1, MAX_PROGRESSBAR_WIDTH),\n      MIN_PROGRESSBAR_WIDTH,\n    );\n    const prog = this.progressBar(progressWidth);\n    if (prog) {\n      lines.push('  ' + prog, '');\n    }\n\n    // Normally we'd only print \"resources in progress\", but it's also useful\n    // to keep an eye on the failures and know about the specific errors asquickly\n    // as possible (while the stack is still rolling back), so add those in.\n    const toPrint: StackActivity[] = [...this.failures, ...Object.values(this.resourcesInProgress)];\n    toPrint.sort((a, b) => a.event.Timestamp!.getTime() - b.event.Timestamp!.getTime());\n\n    lines.push(\n      ...toPrint.map((res) => {\n        const color = colorFromStatusActivity(res.event.ResourceStatus);\n        const resourceName = res.metadata?.constructPath ?? res.event.LogicalResourceId ?? '';\n\n        return util.format(\n          '%s | %s | %s | %s%s',\n          padLeft(CurrentActivityPrinter.TIMESTAMP_WIDTH, new Date(res.event.Timestamp!).toLocaleTimeString()),\n          color(padRight(CurrentActivityPrinter.STATUS_WIDTH, (res.event.ResourceStatus || '').slice(0, CurrentActivityPrinter.STATUS_WIDTH))),\n          padRight(this.resourceTypeColumnWidth, res.event.ResourceType || ''),\n          color(chalk.bold(shorten(40, resourceName))),\n          this.failureReasonOnNextLine(res),\n        );\n      }),\n    );\n\n    this.block.displayLines(lines);\n  }\n\n  public stop() {\n    super.stop();\n\n    // Print failures at the end\n    const lines = new Array<string>();\n    for (const failure of this.failures) {\n      // Root stack failures are not interesting\n      if (this.isActivityForTheStack(failure)) {\n        continue;\n      }\n\n      lines.push(\n        util.format(\n          chalk.red('%s | %s | %s | %s%s') + '\\n',\n          padLeft(CurrentActivityPrinter.TIMESTAMP_WIDTH, new Date(failure.event.Timestamp!).toLocaleTimeString()),\n          padRight(CurrentActivityPrinter.STATUS_WIDTH, (failure.event.ResourceStatus || '').slice(0, CurrentActivityPrinter.STATUS_WIDTH)),\n          padRight(this.resourceTypeColumnWidth, failure.event.ResourceType || ''),\n          shorten(40, failure.event.LogicalResourceId ?? ''),\n          this.failureReasonOnNextLine(failure),\n        ),\n      );\n\n      const trace = failure.metadata?.entry?.trace;\n      if (trace) {\n        lines.push(chalk.red(`\\t${trace.join('\\n\\t\\\\_ ')}\\n`));\n      }\n    }\n\n    // Display in the same block space, otherwise we're going to have silly empty lines.\n    this.block.displayLines(lines);\n    this.block.removeEmptyLines();\n  }\n\n  private progressBar(width: number) {\n    if (!this.stackProgress || !this.stackProgress.total) {\n      return '';\n    }\n    const fraction = Math.min(this.stackProgress.completed / this.stackProgress.total, 1);\n    const innerWidth = Math.max(1, width - 2);\n    const chars = innerWidth * fraction;\n    const remainder = chars - Math.floor(chars);\n\n    const fullChars = FULL_BLOCK.repeat(Math.floor(chars));\n    const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];\n    const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));\n\n    const color = this.rollingBack ? chalk.yellow : chalk.green;\n\n    return '[' + color(fullChars + partialChar) + filler + `] (${this.stackProgress.completed}/${this.stackProgress.total})`;\n  }\n\n  private failureReasonOnNextLine(activity: StackActivity) {\n    return stackEventHasErrorMessage(activity.event.ResourceStatus ?? '')\n      ? `\\n${' '.repeat(CurrentActivityPrinter.TIMESTAMP_WIDTH + CurrentActivityPrinter.STATUS_WIDTH + 6)}${chalk.red(this.failureReason(activity) ?? '')}`\n      : '';\n  }\n}\n\nconst FULL_BLOCK = '█';\nconst PARTIAL_BLOCK = ['', '▏', '▎', '▍', '▌', '▋', '▊', '▉'];\nconst MAX_PROGRESSBAR_WIDTH = 60;\nconst MIN_PROGRESSBAR_WIDTH = 10;\nconst PROGRESSBAR_EXTRA_SPACE =\n    2 /* leading spaces */ + 2 /* brackets */ + 4 /* progress number decoration */ + 6; /* 2 progress numbers up to 999 */\n\nfunction colorFromStatusActivity(status?: string) {\n  if (!status) {\n    return chalk.reset;\n  }\n\n  if (status.endsWith('_FAILED')) {\n    return chalk.red;\n  }\n\n  if (status.startsWith('CREATE_') || status.startsWith('UPDATE_') || status.startsWith('IMPORT_')) {\n    return chalk.green;\n  }\n  // For stacks, it may also be 'UPDDATE_ROLLBACK_IN_PROGRESS'\n  if (status.indexOf('ROLLBACK_') !== -1) {\n    return chalk.yellow;\n  }\n  if (status.startsWith('DELETE_')) {\n    return chalk.yellow;\n  }\n\n  return chalk.reset;\n}\n\nfunction shorten(maxWidth: number, p: string) {\n  if (p.length <= maxWidth) {\n    return p;\n  }\n  const half = Math.floor((maxWidth - 3) / 2);\n  return p.slice(0, half) + '...' + p.slice(-half);\n}\n\n"]}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ActivityPrinterBase, ActivityPrinterProps } from './base';
|
|
2
|
+
import type { StackActivity } from '../../api/stack-events';
|
|
3
|
+
/**
|
|
4
|
+
* Activity Printer which shows a full log of all CloudFormation events
|
|
5
|
+
*
|
|
6
|
+
* When there hasn't been activity for a while, it will print the resources
|
|
7
|
+
* that are currently in progress, to show what's holding up the deployment.
|
|
8
|
+
*/
|
|
9
|
+
export declare class HistoryActivityPrinter extends ActivityPrinterBase {
|
|
10
|
+
/**
|
|
11
|
+
* Last time we printed something to the console.
|
|
12
|
+
*
|
|
13
|
+
* Used to measure timeout for progress reporting.
|
|
14
|
+
*/
|
|
15
|
+
private lastPrintTime;
|
|
16
|
+
private lastPrinted?;
|
|
17
|
+
/**
|
|
18
|
+
* Number of ms of change absence before we tell the user about the resources that are currently in progress.
|
|
19
|
+
*/
|
|
20
|
+
private readonly inProgressDelay;
|
|
21
|
+
private readonly printable;
|
|
22
|
+
constructor(props: ActivityPrinterProps);
|
|
23
|
+
activity(activity: StackActivity): void;
|
|
24
|
+
stop(): void;
|
|
25
|
+
protected print(): void;
|
|
26
|
+
private printOne;
|
|
27
|
+
/**
|
|
28
|
+
* If some resources are taking a while to create, notify the user about what's currently in progress
|
|
29
|
+
*/
|
|
30
|
+
private printInProgress;
|
|
31
|
+
}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HistoryActivityPrinter = void 0;
|
|
4
|
+
const util = require("util");
|
|
5
|
+
const chalk = require("chalk");
|
|
6
|
+
const base_1 = require("./base");
|
|
7
|
+
const util_1 = require("../../util");
|
|
8
|
+
/**
|
|
9
|
+
* Activity Printer which shows a full log of all CloudFormation events
|
|
10
|
+
*
|
|
11
|
+
* When there hasn't been activity for a while, it will print the resources
|
|
12
|
+
* that are currently in progress, to show what's holding up the deployment.
|
|
13
|
+
*/
|
|
14
|
+
class HistoryActivityPrinter extends base_1.ActivityPrinterBase {
|
|
15
|
+
constructor(props) {
|
|
16
|
+
super(props);
|
|
17
|
+
/**
|
|
18
|
+
* Last time we printed something to the console.
|
|
19
|
+
*
|
|
20
|
+
* Used to measure timeout for progress reporting.
|
|
21
|
+
*/
|
|
22
|
+
this.lastPrintTime = Date.now();
|
|
23
|
+
/**
|
|
24
|
+
* Number of ms of change absence before we tell the user about the resources that are currently in progress.
|
|
25
|
+
*/
|
|
26
|
+
this.inProgressDelay = 30000;
|
|
27
|
+
this.printable = new Array();
|
|
28
|
+
}
|
|
29
|
+
activity(activity) {
|
|
30
|
+
this.printable.push(activity);
|
|
31
|
+
super.activity(activity);
|
|
32
|
+
}
|
|
33
|
+
stop() {
|
|
34
|
+
super.stop();
|
|
35
|
+
// Print failures at the end
|
|
36
|
+
if (this.failures.length > 0) {
|
|
37
|
+
this.stream.write('\nFailed resources:\n');
|
|
38
|
+
for (const failure of this.failures) {
|
|
39
|
+
// Root stack failures are not interesting
|
|
40
|
+
if (this.isActivityForTheStack(failure)) {
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
this.printOne(failure, false);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
print() {
|
|
48
|
+
var _a;
|
|
49
|
+
for (const activity of this.printable) {
|
|
50
|
+
this.printOne(activity);
|
|
51
|
+
this.lastPrinted = activity;
|
|
52
|
+
}
|
|
53
|
+
this.printable.splice(0, this.printable.length);
|
|
54
|
+
this.printInProgress((_a = this.lastPrinted) === null || _a === void 0 ? void 0 : _a.progress.formatted);
|
|
55
|
+
}
|
|
56
|
+
printOne(activity, progress) {
|
|
57
|
+
const event = activity.event;
|
|
58
|
+
const color = colorFromStatusResult(event.ResourceStatus);
|
|
59
|
+
let reasonColor = chalk.cyan;
|
|
60
|
+
let stackTrace = '';
|
|
61
|
+
const metadata = activity.metadata;
|
|
62
|
+
if (event.ResourceStatus && event.ResourceStatus.indexOf('FAILED') !== -1) {
|
|
63
|
+
if (progress == undefined || progress) {
|
|
64
|
+
event.ResourceStatusReason = event.ResourceStatusReason ? this.failureReason(activity) : '';
|
|
65
|
+
}
|
|
66
|
+
if (metadata) {
|
|
67
|
+
stackTrace = metadata.entry.trace ? `\n\t${metadata.entry.trace.join('\n\t\\_ ')}` : '';
|
|
68
|
+
}
|
|
69
|
+
reasonColor = chalk.red;
|
|
70
|
+
}
|
|
71
|
+
const resourceName = metadata ? metadata.constructPath : event.LogicalResourceId || '';
|
|
72
|
+
const logicalId = resourceName !== event.LogicalResourceId ? `(${event.LogicalResourceId}) ` : '';
|
|
73
|
+
this.stream.write(util.format('%s | %s%s | %s | %s | %s %s%s%s\n', event.StackName, progress !== false ? `${activity.progress.formatted} | ` : '', new Date(event.Timestamp).toLocaleTimeString(), color((0, util_1.padRight)(HistoryActivityPrinter.STATUS_WIDTH, (event.ResourceStatus || '').slice(0, HistoryActivityPrinter.STATUS_WIDTH))), // pad left and trim
|
|
74
|
+
(0, util_1.padRight)(this.resourceTypeColumnWidth, event.ResourceType || ''), color(chalk.bold(resourceName)), logicalId, reasonColor(chalk.bold(event.ResourceStatusReason ? event.ResourceStatusReason : '')), reasonColor(stackTrace)));
|
|
75
|
+
this.lastPrintTime = Date.now();
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* If some resources are taking a while to create, notify the user about what's currently in progress
|
|
79
|
+
*/
|
|
80
|
+
printInProgress(progress) {
|
|
81
|
+
if (!progress || Date.now() < this.lastPrintTime + this.inProgressDelay) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
if (Object.keys(this.resourcesInProgress).length > 0) {
|
|
85
|
+
this.stream.write(util.format('%s Currently in progress: %s\n', progress, chalk.bold(Object.keys(this.resourcesInProgress).join(', '))));
|
|
86
|
+
}
|
|
87
|
+
// We cheat a bit here. To prevent printInProgress() from repeatedly triggering,
|
|
88
|
+
// we set the timestamp into the future. It will be reset whenever a regular print
|
|
89
|
+
// occurs, after which we can be triggered again.
|
|
90
|
+
this.lastPrintTime = +Infinity;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
exports.HistoryActivityPrinter = HistoryActivityPrinter;
|
|
94
|
+
function colorFromStatusResult(status) {
|
|
95
|
+
if (!status) {
|
|
96
|
+
return chalk.reset;
|
|
97
|
+
}
|
|
98
|
+
if (status.indexOf('FAILED') !== -1) {
|
|
99
|
+
return chalk.red;
|
|
100
|
+
}
|
|
101
|
+
if (status.indexOf('ROLLBACK') !== -1) {
|
|
102
|
+
return chalk.yellow;
|
|
103
|
+
}
|
|
104
|
+
if (status.indexOf('COMPLETE') !== -1) {
|
|
105
|
+
return chalk.green;
|
|
106
|
+
}
|
|
107
|
+
return chalk.reset;
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"history.js","sourceRoot":"","sources":["history.ts"],"names":[],"mappings":"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","sourcesContent":["import * as util from 'util';\nimport * as chalk from 'chalk';\nimport { ActivityPrinterBase, ActivityPrinterProps } from './base';\nimport type { StackActivity } from '../../api/stack-events';\nimport { padRight } from '../../util';\n\n/**\n * Activity Printer which shows a full log of all CloudFormation events\n *\n * When there hasn't been activity for a while, it will print the resources\n * that are currently in progress, to show what's holding up the deployment.\n */\nexport class HistoryActivityPrinter extends ActivityPrinterBase {\n  /**\n   * Last time we printed something to the console.\n   *\n   * Used to measure timeout for progress reporting.\n   */\n  private lastPrintTime = Date.now();\n\n  private lastPrinted?: StackActivity;\n\n  /**\n   * Number of ms of change absence before we tell the user about the resources that are currently in progress.\n   */\n  private readonly inProgressDelay = 30_000;\n\n  private readonly printable = new Array<StackActivity>();\n\n  constructor(props: ActivityPrinterProps) {\n    super(props);\n  }\n\n  public activity(activity: StackActivity) {\n    this.printable.push(activity);\n    super.activity(activity);\n  }\n\n  public stop() {\n    super.stop();\n\n    // Print failures at the end\n    if (this.failures.length > 0) {\n      this.stream.write('\\nFailed resources:\\n');\n      for (const failure of this.failures) {\n        // Root stack failures are not interesting\n        if (this.isActivityForTheStack(failure)) {\n          continue;\n        }\n\n        this.printOne(failure, false);\n      }\n    }\n  }\n\n  protected print() {\n    for (const activity of this.printable) {\n      this.printOne(activity);\n      this.lastPrinted = activity;\n    }\n    this.printable.splice(0, this.printable.length);\n    this.printInProgress(this.lastPrinted?.progress.formatted);\n  }\n\n  private printOne(activity: StackActivity, progress?: boolean) {\n    const event = activity.event;\n    const color = colorFromStatusResult(event.ResourceStatus);\n    let reasonColor = chalk.cyan;\n\n    let stackTrace = '';\n    const metadata = activity.metadata;\n\n    if (event.ResourceStatus && event.ResourceStatus.indexOf('FAILED') !== -1) {\n      if (progress == undefined || progress) {\n        event.ResourceStatusReason = event.ResourceStatusReason ? this.failureReason(activity) : '';\n      }\n      if (metadata) {\n        stackTrace = metadata.entry.trace ? `\\n\\t${metadata.entry.trace.join('\\n\\t\\\\_ ')}` : '';\n      }\n      reasonColor = chalk.red;\n    }\n\n    const resourceName = metadata ? metadata.constructPath : event.LogicalResourceId || '';\n    const logicalId = resourceName !== event.LogicalResourceId ? `(${event.LogicalResourceId}) ` : '';\n\n    this.stream.write(\n      util.format(\n        '%s | %s%s | %s | %s | %s %s%s%s\\n',\n        event.StackName,\n        progress !== false ? `${activity.progress.formatted} | ` : '',\n        new Date(event.Timestamp!).toLocaleTimeString(),\n        color(padRight(HistoryActivityPrinter.STATUS_WIDTH, (event.ResourceStatus || '').slice(0, HistoryActivityPrinter.STATUS_WIDTH))), // pad left and trim\n        padRight(this.resourceTypeColumnWidth, event.ResourceType || ''),\n        color(chalk.bold(resourceName)),\n        logicalId,\n        reasonColor(chalk.bold(event.ResourceStatusReason ? event.ResourceStatusReason : '')),\n        reasonColor(stackTrace),\n      ),\n    );\n\n    this.lastPrintTime = Date.now();\n  }\n\n  /**\n   * If some resources are taking a while to create, notify the user about what's currently in progress\n   */\n  private printInProgress(progress?: string) {\n    if (!progress || Date.now() < this.lastPrintTime + this.inProgressDelay) {\n      return;\n    }\n\n    if (Object.keys(this.resourcesInProgress).length > 0) {\n      this.stream.write(\n        util.format(\n          '%s Currently in progress: %s\\n',\n          progress,\n          chalk.bold(Object.keys(this.resourcesInProgress).join(', ')),\n        ),\n      );\n    }\n\n    // We cheat a bit here. To prevent printInProgress() from repeatedly triggering,\n    // we set the timestamp into the future. It will be reset whenever a regular print\n    // occurs, after which we can be triggered again.\n    this.lastPrintTime = +Infinity;\n  }\n}\n\nfunction colorFromStatusResult(status?: string) {\n  if (!status) {\n    return chalk.reset;\n  }\n\n  if (status.indexOf('FAILED') !== -1) {\n    return chalk.red;\n  }\n  if (status.indexOf('ROLLBACK') !== -1) {\n    return chalk.yellow;\n  }\n  if (status.indexOf('COMPLETE') !== -1) {\n    return chalk.green;\n  }\n\n  return chalk.reset;\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
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("./base"), exports);
|
|
18
|
+
__exportStar(require("./history"), exports);
|
|
19
|
+
__exportStar(require("./current"), exports);
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCO0FBQ3ZCLDRDQUEwQjtBQUMxQiw0Q0FBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9oaXN0b3J5JztcbmV4cG9ydCAqIGZyb20gJy4vY3VycmVudCc7XG4iXX0=
|
package/lib/cli/cdk-toolkit.d.ts
CHANGED
|
@@ -6,8 +6,8 @@ import { CloudExecutable } from '../api/cxapp/cloud-executable';
|
|
|
6
6
|
import { type Deployments, DeploymentMethod } from '../api/deployments';
|
|
7
7
|
import { HotswapMode } from '../api/hotswap/common';
|
|
8
8
|
import { CloudWatchLogEventMonitor } from '../api/logs/logs-monitor';
|
|
9
|
-
import { StackActivityProgress } from '../api/stack-events';
|
|
10
9
|
import { type Tag } from '../api/tags';
|
|
10
|
+
import { StackActivityProgress } from '../commands/deploy';
|
|
11
11
|
import { FromScan } from '../commands/migrate';
|
|
12
12
|
import { RequireApproval } from '../diff';
|
|
13
13
|
import { CliIoHost } from '../toolkit/cli-io-host';
|