Skip to content

Build and deploy frontend Dev #107

Build and deploy frontend Dev

Build and deploy frontend Dev #107

name: Build and deploy frontend Dev
on:
workflow_dispatch:
jobs:
pr-data:
name: Get data for merged PR
permissions:
contents: read
pull-requests: read
uses: ./.github/workflows/call_get_pr_data.yml
build-frontend:
name: Build and push Frontend
permissions:
id-token: write
contents: read
uses: ./.github/workflows/call_build-push-docker-image.yml
with:
aws-region: eu-west-2
secrets:
dynatrace_registry: ${{ secrets.DYNATRACE_REGISTRY_NAME }}
dynatrace_token: ${{ secrets.DYNATRACE_PAAS_TOKEN }}
deployer_role: ${{ secrets.DEV_DEPLOYER_ROLE }}
ecr_repo: ${{ secrets.DEV_TOOLING_ECR_FRONTEND_REPO }}
build-sidecar:
name: Build and push Basic Auth Sidecar
permissions:
id-token: write
contents: read
uses: ./.github/workflows/call_build-push-docker-image.yml
with:
aws-region: eu-west-2
context: basic-auth-sidecar
secrets:
dynatrace_registry: ${{ secrets.DYNATRACE_REGISTRY_NAME }}
dynatrace_token: ${{ secrets.DYNATRACE_PAAS_TOKEN }}
deployer_role: ${{ secrets.DEV_DEPLOYER_ROLE }}
ecr_repo: ${{ secrets.DEV_BASIC_SIDECAR_ECR_REPO }}
build-service-down:
name: Build and push Service Down Page
permissions:
id-token: write
contents: read
uses: ./.github/workflows/call_build-push-docker-image.yml
with:
aws-region: eu-west-2
context: service-down-page-config
secrets:
dynatrace_registry: ${{ secrets.DYNATRACE_REGISTRY_NAME }}
dynatrace_token: ${{ secrets.DYNATRACE_PAAS_TOKEN }}
deployer_role: ${{ secrets.DEV_DEPLOYER_ROLE }}
ecr_repo: ${{ secrets.DEV_SERVICE_DOWN_ECR_REPO }}
deploy:
needs:
- build-frontend
- build-sidecar
- build-service-down
- pr-data
runs-on: ubuntu-latest
timeout-minutes: 60
permissions:
id-token: write
contents: read
steps:
- name: Checkout
uses: actions/checkout@eef61447b9ff4aafe5dcd4e0bbf5d482be7e7871 # v4.2.1
- name: Set up AWS credentials
uses: aws-actions/configure-aws-credentials@e3dd6a429d7300a6a4c196c26e071d42e0343502 # v4.0.2
with:
role-to-assume: ${{ secrets.DEV_DEPLOY_ROLE }}
aws-region: eu-west-2
- name: Upload frontend Terraform files
working-directory: ci/terraform
env:
METADATA: ${{ needs.pr-data.outputs.data }}
run: |
echo "::group::Zip up frontend terraform"
zip -r frontend.zip .
echo "::endgroup::"
echo "::group::Upload artifact to S3"
OBJECT_VERSION="$(aws s3api put-object \
--bucket ${{ secrets.DEV_ARTIFACT_BUCKET }} \
--key frontend.zip \
--body frontend.zip \
--metadata "${METADATA}" \
--query VersionId --output text)"
echo "::endgroup::"
echo "::notice title=Final artifact uploaded to S3::object: frontend.zip, version: ${OBJECT_VERSION}"