b3f1114a68
* Add Renovate configuration file * Delete .github/workflows/update-i18n.yaml * chore(deps): pin dependencies (#1) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): update codelytv/pr-size-labeler action to v1.10.3 (#2) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * Delete renovate.json --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
95 lines
3.6 KiB
YAML
95 lines
3.6 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@9bb56186c3b09b4f86b1c65136769dd318469633 # v4.1.2
|
|
with:
|
|
ref: "release"
|
|
|
|
- name: Checkout the staging branch
|
|
if: ${{ github.event_name == 'schedule' }}
|
|
uses: actions/checkout@9bb56186c3b09b4f86b1c65136769dd318469633 # 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@c7c53464625b32c7a7e944ae62b3e17d2b600130 # v3
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@8d2750c68a42422c14e847fe6c8ac0403b4cbd6f # v3
|
|
|
|
- name: Extract metadata (tags, labels) for the image
|
|
uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81 # 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@c94ce9fb468520275223c153574b00df6fe4bcc9 # 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@2cdde995de11925a030ce8070c3d77a52ffcf1c0 # v5.3.0
|
|
with:
|
|
context: .
|
|
platforms: linux/amd64,linux/arm64
|
|
file: Dockerfile
|
|
push: true
|
|
tags: ${{ steps.metadata.outputs.tags }}
|
|
labels: ${{ steps.metadata.outputs.labels }}
|