Skip to content

chore: remove feat branch trigger #108

chore: remove feat branch trigger

chore: remove feat branch trigger #108

Workflow file for this run

name: "Backend"
on:
push:
branches: [master, next]
paths:
- 'backend/**'
pull_request:
branches: [master, next]
paths:
- 'backend/**'
jobs:
build-signaling:
name: "🧦 Build Signaling"
runs-on: ubuntu-latest
defaults:
run:
working-directory: backend/signaling
steps:
- uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build and export
uses: docker/build-push-action@v5
with:
context: backend/signaling
tags: signaling:latest
outputs: type=docker,dest=/tmp/signaling.tar
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: signaling
path: /tmp/signaling.tar
build-worker:
name: "🧦 Build Worker"
runs-on: ubuntu-latest
defaults:
run:
working-directory: backend/client
steps:
- uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build and export
uses: docker/build-push-action@v5
with:
context: backend/client
tags: worker:latest
outputs: type=docker,dest=/tmp/worker.tar
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: worker
path: /tmp/worker.tar
infrastructure:
needs:
- build-signaling
- build-worker
uses: ./.github/workflows/infrastructure.yml
secrets: inherit
deploy:
name: "πŸƒβ€β™‚οΈ Deploy"
runs-on: ubuntu-latest
if: github.event_name == 'push'
needs:
- build-signaling
- build-worker
- infrastructure
permissions:
id-token: write
contents: read
steps:
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v2
with:
aws-region: us-east-1
role-to-assume: ${{ needs.infrastructure.outputs.deploy_role }}
role-session-name: DeploySession
- name: Login to Amazon ECR
uses: aws-actions/amazon-ecr-login@v1
- name: Download artifact
uses: actions/download-artifact@v3
with:
name: signaling
path: /tmp
- name: Tag and upload image to ECR
env:
ECR_REPOSITORY: ${{ needs.infrastructure.outputs.signaling_ecr_url }}
IMAGE_TAG: ${{ github.sha }}
run: |
docker load --input /tmp/signaling.tar
docker tag signaling:latest $ECR_REPOSITORY:$IMAGE_TAG
docker tag signaling:latest $ECR_REPOSITORY:latest
docker push $ECR_REPOSITORY --all-tags
- name: Deploy image to EC2
run: |
aws ssm send-command \
--document-name "${{ needs.infrastructure.outputs.signaling_deploy_doc }}" \
--instance-id "${{ needs.infrastructure.outputs.instance_id }}"
- name: Download artifact
uses: actions/download-artifact@v3
with:
name: worker
path: /tmp
- name: Tag and upload image to ECR
env:
ECR_REPOSITORY: ${{ needs.infrastructure.outputs.worker_ecr_url }}
IMAGE_TAG: ${{ github.sha }}
run: |
docker load --input /tmp/worker.tar
docker tag worker:latest $ECR_REPOSITORY:$IMAGE_TAG
docker tag worker:latest $ECR_REPOSITORY:latest
docker push $ECR_REPOSITORY --all-tags
- name: Deploy image to EC2
run: |
aws ssm send-command \
--document-name "${{ needs.infrastructure.outputs.worker_deploy_doc }}" \
--instance-id "${{ needs.infrastructure.outputs.instance_id }}"
concurrency:
group: "${{ github.ref }}-backend"
cancel-in-progress: true