misskey/.forgejo/workflows/docker-forgejo.yml
2026-06-23 17:31:44 +09:00

64 lines
1.9 KiB
YAML

name: Publish Docker image (Forgejo)
on:
workflow_dispatch:
inputs:
registry:
description: 'Forgejo container registry host (e.g. codeberg.org)'
required: true
type: string
default: 'codeberg.org'
image:
description: 'Image path within the registry (e.g. owner/misskey)'
required: true
type: string
default: 'misskey/misskey'
tag:
description: 'Tag to publish (e.g. latest, develop, 2025.x.x)'
required: true
type: string
default: 'latest'
platforms:
description: 'Target platforms to build'
required: true
type: choice
default: 'linux/amd64,linux/arm64'
options:
- 'linux/amd64,linux/arm64'
- 'linux/amd64'
- 'linux/arm64'
env:
REGISTRY_IMAGE: ${{ inputs.registry }}/${{ inputs.image }}
jobs:
build:
name: Build and push
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v6.0.2
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v4
- name: Log in to Forgejo container registry
uses: docker/login-action@v4
with:
registry: ${{ inputs.registry }}
username: ${{ secrets.REGISTRY_USER }}
password: ${{ secrets.REGISTRY_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v7
with:
context: .
push: true
platforms: ${{ inputs.platforms }}
provenance: false
tags: ${{ env.REGISTRY_IMAGE }}:${{ inputs.tag }}
labels: ${{ inputs.tag }}
cache-from: type=gha
cache-to: type=gha,mode=max
- name: Inspect image
run: |
docker buildx imagetools inspect ${{ env.REGISTRY_IMAGE }}:${{ inputs.tag }}