lambda-live-debugger
Version:
Debug Lambda functions locally like it is running in the cloud
148 lines (147 loc) • 5.65 kB
JavaScript
import { checkExceptions, createWaiter, WaiterState } from "@smithy/util-waiter";
import { DescribeStacksCommand } from "../commands/DescribeStacksCommand";
const checkState = async (client, input) => {
let reason;
try {
const result = await client.send(new DescribeStacksCommand(input));
reason = result;
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
let allStringEq_5 = returnComparator().length > 0;
for (const element_4 of returnComparator()) {
allStringEq_5 = allStringEq_5 && element_4 == "DELETE_COMPLETE";
}
if (allStringEq_5) {
return { state: WaiterState.SUCCESS, reason };
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "DELETE_FAILED") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "CREATE_FAILED") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "ROLLBACK_FAILED") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "UPDATE_ROLLBACK_IN_PROGRESS") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "UPDATE_ROLLBACK_FAILED") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "UPDATE_ROLLBACK_COMPLETE") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
try {
const returnComparator = () => {
const flat_1 = [].concat(...result.Stacks);
const projection_3 = flat_1.map((element_2) => {
return element_2.StackStatus;
});
return projection_3;
};
for (const anyStringEq_4 of returnComparator()) {
if (anyStringEq_4 == "UPDATE_COMPLETE") {
return { state: WaiterState.FAILURE, reason };
}
}
}
catch (e) { }
}
catch (exception) {
reason = exception;
if (exception.name && exception.name == "ValidationError") {
return { state: WaiterState.SUCCESS, reason };
}
}
return { state: WaiterState.RETRY, reason };
};
export const waitForStackDeleteComplete = async (params, input) => {
const serviceDefaults = { minDelay: 30, maxDelay: 120 };
return createWaiter({ ...serviceDefaults, ...params }, input, checkState);
};
export const waitUntilStackDeleteComplete = async (params, input) => {
const serviceDefaults = { minDelay: 30, maxDelay: 120 };
const result = await createWaiter({ ...serviceDefaults, ...params }, input, checkState);
return checkExceptions(result);
};