Build and Push Backend Image on Tag #38
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build and Push Backend Image on Tag | |
on: | |
push: | |
tags: | |
- '*' | |
env: | |
REGISTRY_IMAGE: ghcr.io/stackhpc/danswer/danswer-backend | |
LATEST_TAG: ${{ contains(github.ref_name, 'latest') }} | |
jobs: | |
build-and-push: | |
# TODO: investigate a matrix build like the web container | |
# See https://runs-on.com/runners/linux/ | |
# NOTE(sd109): Can't use Danswer custom runners here | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@v5 | |
with: | |
images: ${{ env.REGISTRY_IMAGE }} | |
tags: | | |
type=raw,value=${{ github.ref_name }} | |
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/main' }} | |
- name: Install build-essential | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y build-essential | |
- name: Backend Image Docker Build and Push | |
uses: docker/build-push-action@v5 | |
with: | |
context: ./backend | |
file: ./backend/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: | | |
${{ env.REGISTRY_IMAGE }}:${{ github.ref_name }} | |
${{ env.LATEST_TAG == 'true' && format('{0}:latest', env.REGISTRY_IMAGE) || '' }} | |
build-args: | | |
DANSWER_VERSION=${{ github.ref_name }} | |
cache-from: type=registry,ref=${{ env.REGISTRY_IMAGE }}:buildcache | |
cache-to: type=registry,ref=${{ env.REGISTRY_IMAGE}}:buildcache,mode=max | |
# trivy has their own rate limiting issues causing this action to flake | |
# we worked around it by hardcoding to different db repos in env | |
# can re-enable when they figure it out | |
# https://github.com/aquasecurity/trivy/discussions/7538 | |
# https://github.com/aquasecurity/trivy-action/issues/389 | |
- name: Run Trivy vulnerability scanner | |
uses: aquasecurity/trivy-action@master | |
env: | |
TRIVY_DB_REPOSITORY: 'public.ecr.aws/aquasecurity/trivy-db:2' | |
TRIVY_JAVA_DB_REPOSITORY: 'public.ecr.aws/aquasecurity/trivy-java-db:1' | |
with: | |
# To run locally: trivy image --severity HIGH,CRITICAL danswer/danswer-backend | |
image-ref: ${{ env.REGISTRY_IMAGE }}:${{ github.ref_name }} | |
severity: 'CRITICAL,HIGH' | |
trivyignores: ./backend/.trivyignore |