|
|
name: Docker Publish |
|
|
|
|
|
on: |
|
|
push: |
|
|
branches: [main, stable] |
|
|
tags: ['v*', '*.*.*'] |
|
|
workflow_dispatch: |
|
|
|
|
|
concurrency: |
|
|
group: ${{ github.workflow }}-${{ github.ref }} |
|
|
cancel-in-progress: true |
|
|
|
|
|
permissions: |
|
|
packages: write |
|
|
contents: read |
|
|
|
|
|
env: |
|
|
REGISTRY: ghcr.io |
|
|
IMAGE_NAME: ${{ github.repository }} |
|
|
|
|
|
jobs: |
|
|
docker-build-publish: |
|
|
runs-on: ubuntu-latest |
|
|
|
|
|
steps: |
|
|
- name: Checkout code |
|
|
uses: actions/checkout@v4 |
|
|
|
|
|
- name: Set up Docker Buildx |
|
|
uses: docker/setup-buildx-action@v3 |
|
|
|
|
|
- name: Log in to GitHub Container Registry |
|
|
uses: docker/login-action@v3 |
|
|
with: |
|
|
registry: ${{ env.REGISTRY }} |
|
|
username: ${{ github.actor }} |
|
|
password: ${{ secrets.GITHUB_TOKEN }} |
|
|
|
|
|
- name: Extract metadata for Docker image |
|
|
id: meta |
|
|
uses: docker/metadata-action@v4 |
|
|
with: |
|
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} |
|
|
tags: | |
|
|
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/main' }} |
|
|
type=raw,value=stable,enable=${{ github.ref == 'refs/heads/stable' }} |
|
|
type=ref,event=tag |
|
|
type=sha,format=short |
|
|
type=raw,value=${{ github.ref_name }},enable=${{ startsWith(github.ref, 'refs/tags/') || github.ref == 'refs/heads/main' || github.ref == 'refs/heads/stable' }} |
|
|
|
|
|
- name: Build and push Docker image |
|
|
uses: docker/build-push-action@v6 |
|
|
with: |
|
|
context: . |
|
|
platforms: linux/amd64,linux/arm64 |
|
|
target: bolt-ai-production |
|
|
push: true |
|
|
tags: ${{ steps.meta.outputs.tags }} |
|
|
labels: ${{ steps.meta.outputs.labels }} |
|
|
|
|
|
- name: Check manifest |
|
|
run: docker buildx imagetools inspect ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ steps.meta.outputs.version }} |