95 lines
3.3 KiB
YAML
95 lines
3.3 KiB
YAML
# This workflow will publish a docker image for every full release to the GitHub package repository
|
|
|
|
name: Create Docker Image (Release and Staging)
|
|
|
|
on:
|
|
release:
|
|
# Allow pre-releases
|
|
types: [published]
|
|
schedule:
|
|
# Build the staging image everyday at 00:00 UTC
|
|
- cron: "0 0 * * *"
|
|
push:
|
|
# Temporary workaround
|
|
branches:
|
|
- release
|
|
|
|
env:
|
|
# This should allow creation of docker images even in forked repositories
|
|
REPO: ${{ github.repository }}
|
|
REGISTRY: ghcr.io
|
|
|
|
jobs:
|
|
build:
|
|
if: github.repository == 'SillyTavern/SillyTavern'
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
# Workaround for GitHub repo names containing uppercase characters
|
|
- name: Set lowercase repo name
|
|
run: |
|
|
echo "IMAGE_NAME=${REPO,,}" >> ${GITHUB_ENV}
|
|
|
|
# Using the following workaround because currently GitHub Actions
|
|
# does not support logical AND/OR operations on triggers
|
|
# It's currently not possible to have `branches` under the `schedule` trigger
|
|
- name: Checkout the release branch (on release)
|
|
if: ${{ github.event_name == 'release' || github.event_name == 'push' }}
|
|
uses: actions/checkout@v4.1.2
|
|
with:
|
|
ref: "release"
|
|
|
|
- name: Checkout the staging branch
|
|
if: ${{ github.event_name == 'schedule' }}
|
|
uses: actions/checkout@v4.1.2
|
|
with:
|
|
ref: "staging"
|
|
|
|
# Get current branch name
|
|
# This is also part of the workaround for Actions not allowing logical
|
|
# AND/OR operators on triggers
|
|
# Otherwise the action triggered by schedule always has ref_name = release
|
|
- name: Get the current branch name
|
|
run: |
|
|
echo "BRANCH_NAME=$(git rev-parse --abbrev-ref HEAD)" >> ${GITHUB_ENV}
|
|
|
|
# Setting up QEMU for multi-arch image build
|
|
- name: Set up QEMU
|
|
uses: docker/setup-qemu-action@v3
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
|
|
- name: Extract metadata (tags, labels) for the image
|
|
uses: docker/metadata-action@v5.5.1
|
|
id: metadata
|
|
with:
|
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
|
# Release version tag if the workflow is triggered by a release
|
|
# Branch name tag if the workflow is triggered by a push
|
|
# Latest tag if the branch is release and the workflow is triggered by a push
|
|
tags: |
|
|
${{ github.event_name == 'release' && github.ref_name || env.BRANCH_NAME }}
|
|
${{ github.event_name == 'push' && env.BRANCH_NAME == 'release' && 'latest' || '' }}
|
|
|
|
# Login into package repository as the person who created the release
|
|
- name: Log in to the Container registry
|
|
uses: docker/login-action@v3
|
|
with:
|
|
registry: ${{ env.REGISTRY }}
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
# Build docker image using dockerfile for amd64 and arm64
|
|
# Tag it with branch name
|
|
# Assumes branch name is the version number
|
|
- name: Build and push
|
|
uses: docker/build-push-action@v5.3.0
|
|
with:
|
|
context: .
|
|
platforms: linux/amd64,linux/arm64
|
|
file: Dockerfile
|
|
push: true
|
|
tags: ${{ steps.metadata.outputs.tags }}
|
|
labels: ${{ steps.metadata.outputs.labels }}
|