Skip to content

Commit

Permalink
refactor: simplify cfn output logic (#212)
Browse files Browse the repository at this point in the history
#### Motivation

Use syntatical sugar to reduce the number of explicit checks needed

#### Modification

- Uses modern javascript syntax sugar  
- Avoids using `!object` or `if(object)` to prevent type conversions

#### Checklist

_If not applicable, provide explanation of why._

- [ ] Tests updated
- [ ] Docs updated
- [ ] Issue linked in Title
  • Loading branch information
blacha authored and amfage committed Oct 30, 2023
1 parent 4db3623 commit 104a5ea
Showing 1 changed file with 3 additions and 12 deletions.
15 changes: 3 additions & 12 deletions infra/util/cloud.formation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,21 +3,12 @@ import { CloudFormation } from '@aws-sdk/client-cloudformation';
export async function getCfnOutputs(stackName: string): Promise<Record<string, string>> {
const cfn = new CloudFormation();
const searchStacks = await cfn.describeStacks({ StackName: stackName });
cfn.listExports;
const outputs: Record<string, string> = {};
const stacks = (searchStacks && searchStacks.Stacks) || [];
const stack = stacks.find((s) => s.StackName === stackName);
const stack = searchStacks?.Stacks?.find((s) => s.StackName === stackName);
if (stack?.Outputs == null) throw new Error(`Unable to find stack "${stackName}"`);

if (!stack) {
throw new Error(`Unable to find stack "${stackName}"`);
}
if (!stack.Outputs) {
throw new Error(`There is no output for stack "${stackName}"`);
}
stack.Outputs.forEach(({ OutputKey, OutputValue }) => {
if (OutputKey && OutputValue) {
outputs[OutputKey] = OutputValue;
}
if (OutputKey != null && OutputValue != null) outputs[OutputKey] = OutputValue;
});
return outputs;
}

0 comments on commit 104a5ea

Please sign in to comment.