Skip to content

Made a docker file for the frontend (#28) #10

Made a docker file for the frontend (#28)

Made a docker file for the frontend (#28) #10

Workflow file for this run

name: Delivery
on:
push:
branches: [main]
release:
# Note: a current limitation is that when a release is edited after publication, then the Docker tags are not automatically updated.
types: [published]
schedule:
# Run every monday on 9:00 in the morning (UTC).
- cron: '0 9 * * 0'
workflow_dispatch:
permissions:
contents: write
packages: write
security-events: write
jobs:
publish-docker-image:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Check whether this event is the HEAD of main
continue-on-error: true
id: is-head-main
run: git rev-parse HEAD | grep -x ${{ github.sha }}
shell: bash
- name: Docker meta
id: meta
uses: docker/metadata-action@v5
with:
images: ghcr.io/${{ github.repository }}
tags: |
type=semver,pattern={{major}}.{{minor}}.{{patch}}
type=edge,enable=${{ steps.is-head-main.outcome == 'success' }}
type=ref,event=branch,enable=${{ github.event_name == 'workflow_dispatch' }}
- 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: Build container and export to local Docker
uses: docker/build-push-action@v5
with:
context: .
file: backend.Dockerfile
load: true
tags: local/postguard-backend:scan
cache-from: type=gha
cache-to: type=gha,mode=max
- name: Scan Image
uses: anchore/scan-action@v4
id: scan
with:
image: local/postguard-backend:scan
only-fixed: true
fail-build: true
severity-cutoff: critical
output-format: sarif
- name: Upload Anchore scan SARIF report
uses: github/codeql-action/upload-sarif@v4
if: ${{ !cancelled() }}
with:
sarif_file: ${{ steps.scan.outputs.sarif }}
- name: Push image to GitHub Container Registry
uses: docker/build-push-action@v5
if: ${{ github.event_name == 'release' || github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
with:
context: .
file: backend.Dockerfile
push: true
tags: ${{ steps.meta.outputs.tags || 'edge' }}
labels: ${{ steps.meta.outputs.labels }}