Skip to content

Publish by Manual

Publish by Manual #3

Workflow file for this run

name: Publish by Manual
on:
workflow_dispatch:
inputs:
branch:
description: 'Select the branch to deploy'
required: true
default: 'master'
env:
REGISTRY: ghcr.io
NAME: koreanbots/core
jobs:
image-push:
name: Push docker image
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- uses: actions/checkout@v2
with:
ref: ${{ github.event.inputs.branch }}
submodules: true
- name: Parse image tag
run: |
parsed=${GITHUB_REF#refs/*/}
echo "RELEASE_TAG=${parsed//\//-}" >> $GITHUB_ENV
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to the Container registry
uses: docker/login-action@v2
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Get metadata for Docker
uses: docker/metadata-action@v4
id: meta
with:
images: ${{ env.REGISTRY }}/${{ env.NAME }}
tags: |
type=raw,value=latest,priority=100
type=sha,prefix=,suffix=,format=short,priority=300
type=schedule,pattern={{date 'YYYYMMDD-hhmmss' tz='Asia/Seoul'}}
- name: Build and push
uses: docker/build-push-action@v4
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: |
SENTRY_AUTH_TOKEN=${{ secrets.SENTRY_AUTH_TOKEN }}
NEXT_PUBLIC_SENTRY_DSN=${{ secrets.SENTRY_DSN }}
SENTRY_DSN=${{ secrets.SENTRY_DSN }}
NEXT_PUBLIC_HCAPTCHA_SITEKEY=${{ secrets.NEXT_PUBLIC_HCAPTCHA_SITEKEY }}
SOURCE_COMMIT=${{ github.sha }}
TAG=${{ env.RELEASE_TAG }}