| 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 }} |