Skip to content

feat: add cross-PCAP comparison with joint topology diagram (#187) #4

feat: add cross-PCAP comparison with joint topology diagram (#187)

feat: add cross-PCAP comparison with joint topology diagram (#187) #4

Workflow file for this run

name: Publish to GHCR
on:
# Triggers minor version ( vX.Y.Z-ShortHash )
push:
branches:
- main
# Triggers major version ( vX.Y.Z )
release:
types: [created]
workflow_dispatch:
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
strategy:
matrix:
include:
- name: tracepcap-backend
context: ./backend
dockerfile: ./backend/Dockerfile
- name: tracepcap-nginx
context: .
dockerfile: ./nginx/Dockerfile
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Extract metadata
id: meta
run: |
SHORT_SHA=$(git rev-parse --short HEAD)
echo "SHORT_SHA=$SHORT_SHA" >> $GITHUB_ENV
# Convert repository owner to lowercase for Docker image naming
REPO_OWNER_LOWER=$(echo "${{ github.repository_owner }}" | tr '[:upper:]' '[:lower:]')
echo "REPO_OWNER_LOWER=$REPO_OWNER_LOWER" >> $GITHUB_ENV
# Use the input tag or default to 'latest'
TAG="${{ github.event.inputs.tag }}"
if [ -z "$TAG" ]; then
TAG="latest"
fi
echo "IMAGE_TAG=$TAG" >> $GITHUB_ENV
# Also create a tag with the commit SHA
echo "SHA_TAG=${TAG}-${SHORT_SHA}" >> $GITHUB_ENV
- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: ${{ matrix.context }}
file: ${{ matrix.dockerfile }}
push: true
platforms: linux/amd64
tags: |
ghcr.io/${{ env.REPO_OWNER_LOWER }}/${{ matrix.name }}:${{ env.IMAGE_TAG }}
ghcr.io/${{ env.REPO_OWNER_LOWER }}/${{ matrix.name }}:${{ env.SHA_TAG }}
cache-from: type=gha
cache-to: type=gha,mode=max
- name: Log out of GitHub Container Registry
if: always()
run: docker logout ghcr.io