Skip to content

Build and Push FileChecker #1

Build and Push FileChecker

Build and Push FileChecker #1

name: Build and Push FileChecker
on:
push:
branches: [master]
paths:
- 'src/**'
- '.github/workflows/build-and-push.yml'
workflow_dispatch:
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository_owner }}/safeturned-filechecker
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout
uses: actions/checkout@v6
- name: Generate version
id: version
run: |
# Numeric version for AssemblyVersion (year.month.day.runnumber)
NUMERIC_VERSION="$(date +'%Y.%-m.%-d').${{ github.run_number }}"
# Suffix with commit hash for InformationalVersion
VERSION_SUFFIX="+${GITHUB_SHA::7}"
# Display version (for tags)
DISPLAY_VERSION="${NUMERIC_VERSION}"
echo "numeric_version=$NUMERIC_VERSION" >> $GITHUB_OUTPUT
echo "version_suffix=$VERSION_SUFFIX" >> $GITHUB_OUTPUT
echo "display_version=$DISPLAY_VERSION" >> $GITHUB_OUTPUT
echo "Generated version: $NUMERIC_VERSION$VERSION_SUFFIX"
- name: Log in to Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=raw,value=latest
type=raw,value=${{ steps.version.outputs.display_version }}
type=sha,prefix=
- name: Build and push
uses: docker/build-push-action@v6
with:
context: ./src
file: ./src/Safeturned.FileChecker.Service/Dockerfile
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
build-args: |
CHECKER_VERSION=${{ steps.version.outputs.numeric_version }}
CHECKER_VERSION_SUFFIX=${{ steps.version.outputs.version_suffix }}