Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EREGCSC-2902 - add app context for removal #1500

Merged
merged 2 commits into from
Dec 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
173 changes: 173 additions & 0 deletions .github/workflows/deploy-cdk-dev.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,173 @@
name: Deploy CDK to DEV

on:
workflow_dispatch:
push:
branches:
- main

permissions:
id-token: write
contents: read
actions: read

concurrency: ${{ github.workflow }}-${{ github.ref }}

jobs:
deploy-zip-lambdas-cdk:
strategy:
max-parallel: 1
matrix:
environment: ["dev"]
runs-on: ubuntu-22.04
environment:
name: ${{ matrix.environment }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: true
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_OIDC_ROLE_TO_ASSUME }}
aws-region: us-east-1

- name: Deploy ZIP-based Lambdas
env:
AWS_ACCOUNT_ID: ${{ secrets.AWS_ACCOUNT_ID }}
AWS_DEFAULT_REGION: ${{ secrets.AWS_DEFAULT_REGION }}
CDK_DEBUG: true
run: |
pushd cdk-eregs
npm install -g aws-cdk@latest @aws-sdk/client-ssm
npm install

# Get exact stack names
REDIRECT_STACK="cms-eregs-${{ matrix.environment }}-redirect-api"
MAINTENANCE_STACK="cms-eregs-${{ matrix.environment }}-maintenance-api"

cdk deploy ${REDIRECT_STACK} ${MAINTENANCE_STACK} \
-c environment=${{ matrix.environment }} \
--require-approval never \
--exclusively \
--app "npx ts-node bin/zip-lambdas.ts"
popd

deploy-text-extractor-cdk:
needs: deploy-zip-lambdas-cdk
strategy:
max-parallel: 1
matrix:
environment: ["dev"]
runs-on: ubuntu-22.04
environment:
name: ${{ matrix.environment }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: true
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_OIDC_ROLE_TO_ASSUME }}
aws-region: us-east-1

- name: Deploy Text Extractor
env:
AWS_ACCOUNT_ID: ${{ secrets.AWS_ACCOUNT_ID }}
AWS_DEFAULT_REGION: ${{ secrets.AWS_DEFAULT_REGION }}
CDK_DEBUG: true
run: |
pushd cdk-eregs
npm install -g aws-cdk@latest @aws-sdk/client-ssm
npm install

TEXT_EXTRACTOR_STACK="cms-eregs-${{ matrix.environment }}-text-extractor"

cdk deploy $TEXT_EXTRACTOR_STACK \
-c environment=${{ matrix.environment }} \
--require-approval never \
--exclusively \
--app "npx ts-node bin/docker-lambdas.ts"
popd

deploy-fr-parser-cdk:
needs: [deploy-zip-lambdas-cdk, deploy-text-extractor-cdk]
strategy:
max-parallel: 1
matrix:
environment: ["dev"]
runs-on: ubuntu-22.04
environment:
name: ${{ matrix.environment }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: true
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_OIDC_ROLE_TO_ASSUME }}
aws-region: us-east-1

- name: Deploy FR Parser
env:
AWS_ACCOUNT_ID: ${{ secrets.AWS_ACCOUNT_ID }}
AWS_DEFAULT_REGION: ${{ secrets.AWS_DEFAULT_REGION }}
CDK_DEBUG: true
run: |
pushd cdk-eregs
npm install -g aws-cdk@latest @aws-sdk/client-ssm
npm install

FR_PARSER_STACK="cms-eregs-${{ matrix.environment }}-fr-parser"

cdk deploy $FR_PARSER_STACK \
-c environment=${{ matrix.environment }} \
--require-approval never \
--exclusively \
--app "npx ts-node bin/docker-lambdas.ts"
popd

deploy-ecfr-parser-cdk:
needs: [deploy-zip-lambdas-cdk, deploy-text-extractor-cdk, deploy-fr-parser-cdk]
strategy:
max-parallel: 1
matrix:
environment: ["dev"]
runs-on: ubuntu-22.04
environment:
name: ${{ matrix.environment }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: true

- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_OIDC_ROLE_TO_ASSUME }}
aws-region: us-east-1

- name: Deploy ECFR Parser
env:
AWS_ACCOUNT_ID: ${{ secrets.AWS_ACCOUNT_ID }}
AWS_DEFAULT_REGION: ${{ secrets.AWS_DEFAULT_REGION }}
CDK_DEBUG: true
run: |
pushd cdk-eregs
npm install -g aws-cdk@latest @aws-sdk/client-ssm
npm install

ECFR_PARSER_STACK="cms-eregs-${{ matrix.environment }}-ecfr-parser"

cdk deploy $ECFR_PARSER_STACK \
-c environment=${{ matrix.environment }} \
--require-approval never \
--exclusively \
--app "npx ts-node bin/docker-lambdas.ts"
popd
16 changes: 13 additions & 3 deletions .github/workflows/remove-experimental.yml
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,9 @@ jobs:
echo "Destroying PR-specific stack: ${STACK_NAME}"
cdk destroy "${STACK_NAME}" \
-c environment=${{ env.ENVIRONMENT_NAME }} \
--force
--force \
--exclusively \
--app "npx ts-node bin/zip-lambdas.ts"

echo "Cleanup completed for stack: ${STACK_NAME}"
popd
Expand All @@ -132,7 +134,9 @@ jobs:
echo "Destroying PR-specific stack: ${STACK_NAME}"
cdk destroy "${STACK_NAME}" \
-c environment=${{ env.ENVIRONMENT_NAME }} \
--force
--force \
--exclusively \
--app "npx ts-node bin/zip-lambdas.ts"

echo "Cleanup completed for stack: ${STACK_NAME}"
popd
Expand All @@ -158,18 +162,24 @@ jobs:
cdk destroy "${TEXT_EXTRACTOR_STACK}" \
-c environment=${{ env.ENVIRONMENT_NAME }} \
--force
--exclusively \
--app "npx ts-node bin/docker-lambdas.ts"

# Destroy fr-parser stack
echo "Destroying PR-specific stack: ${FR_PARSER_STACK}"
cdk destroy "${FR_PARSER_STACK}" \
-c environment=${{ env.ENVIRONMENT_NAME }} \
--force
--force \
--exclusively \
--app "npx ts-node bin/docker-lambdas.ts"

# Destroy ecfr-parser stack
echo "Destroying PR-specific stack: ${ECFR_PARSER_STACK}"
cdk destroy "${ECFR_PARSER_STACK}" \
-c environment=${{ env.ENVIRONMENT_NAME }} \
--force
--exclusively \
--app "npx ts-node bin/docker-lambdas.ts"

echo "Cleanup completed for all Docker-based stacks"
popd
Expand Down
Loading