Skip to content

feat(ci): initial attempt at cd manifest deployment #18

feat(ci): initial attempt at cd manifest deployment

feat(ci): initial attempt at cd manifest deployment #18

Workflow file for this run

name: Build and push image
on:
push:
branches:
- master
pull_request:
branches:
- master
permissions:
contents: read
id-token: write
jobs:
build:
runs-on: ubuntu-latest
outputs:
image: '${{ vars.ECR_URL }}/${{ vars.IMAGE_NAME }}'
tag: '${{ steps.vars.outputs.image-tag }}'
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v2
with:
role-to-assume: ${{ vars.ECR_PUSH_ROLE_ARN }}
aws-region: ap-northeast-2
- name: Set variables
id: vars
env:
REV: ${{ github.ref }}
run: |
date="$(date -u date -u +%Y%m%d)"
short_rev="$(git rev-parse --short "$REV")"
echo "date=$date" >> $GITHUB_OUTPUT
echo "short-rev=$short_rev" >> $GITHUB_OUTPUT
echo "image-tag=${date}-${short_rev}"
- name: Login to Amazon ECR
id: login-ecr
uses: aws-actions/amazon-ecr-login@v1
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Build and push
uses: docker/build-push-action@v4
with:
context: .
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ vars.ECR_URL }}/${{ vars.IMAGE_NAME }}:${{ steps.vars.outputs.image-tag }}
cache-from: type=gha
cache-to: type=gha,mode=max
deploy:
needs: build
uses: bacchus-snu/cd-manifests/.github/workflows/deploy-application.yaml@main
with:
application: bacchus-snu/id/dev
image: ${{ needs.build.outputs.image }}
tag: ${{ needs.build.outputs.tag }}
secrets:
app-id: '${{ secrets.CD_GITHUB_APP_ID }}'
app-private-key: '${{ secrets.CD_GITHUB_APP_SECRET_KEY }}'