mirror of
https://github.com/immich-app/immich.git
synced 2025-01-24 04:32:45 +01:00
98 lines
No EOL
3 KiB
YAML
98 lines
No EOL
3 KiB
YAML
name: Build and Push Docker Images
|
|
|
|
on:
|
|
workflow_dispatch:
|
|
push:
|
|
branches: [main]
|
|
pull_request:
|
|
branches: [main]
|
|
release:
|
|
types: [published]
|
|
|
|
# Explicitly configure permissions
|
|
# This lets pull requests from forks push images to pr- tags
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
|
|
jobs:
|
|
build_and_push:
|
|
runs-on: ubuntu-latest
|
|
strategy:
|
|
# Prevent a failure in one image from stopping the other builds
|
|
fail-fast: false
|
|
matrix:
|
|
include:
|
|
- context: "server"
|
|
image: "immich-server"
|
|
- context: "web"
|
|
image: "immich-web"
|
|
- context: "machine-learning"
|
|
image: "immich-machine-learning"
|
|
- context: "nginx"
|
|
image: "immich-proxy"
|
|
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v3
|
|
with:
|
|
fetch-depth: 0
|
|
|
|
- name: Set up QEMU
|
|
uses: docker/setup-qemu-action@v2.1.0
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v2.2.1
|
|
# Workaround to fix two buildkit regressions
|
|
# first one: failed to push: failed to copy: io: read/write on closed pipe
|
|
# See https://github.com/docker/build-push-action/issues/761
|
|
# second one: random cache misses
|
|
# See https://github.com/docker/build-push-action/issues/735
|
|
with:
|
|
driver-opts: |
|
|
image=moby/buildkit:v0.9.3
|
|
|
|
- name: Login to Docker Hub
|
|
# Only push to Docker Hub when making a release
|
|
if: ${{ github.event_name == 'release' }}
|
|
uses: docker/login-action@v2
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
|
- name: Login to GitHub Container Registry
|
|
uses: docker/login-action@v2
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Generate docker image tags
|
|
id: metadata
|
|
uses: docker/metadata-action@v4
|
|
with:
|
|
flavor: |
|
|
# Disable latest tag
|
|
latest=false
|
|
images: |
|
|
name=ghcr.io/${{ github.repository_owner }}/${{matrix.image}}
|
|
name=altran1502/${{matrix.image}},enable=${{ github.event_name == 'release' }}
|
|
tags: |
|
|
# Tag with branch name
|
|
type=ref,event=branch
|
|
# Tag with pr-number
|
|
type=ref,event=pr
|
|
# Tag with git tag on release
|
|
# TBD: I don't know if this will work on the release_publish run?
|
|
type=ref,event=tag
|
|
type=raw,value=release,enable=${{ github.event_name == 'release' }}
|
|
|
|
- name: Build and push image
|
|
uses: docker/build-push-action@v3.3.0
|
|
with:
|
|
context: ${{ matrix.context }}
|
|
platforms: linux/arm/v7,linux/amd64,linux/arm64
|
|
push: true
|
|
cache-from: type=gha
|
|
cache-to: type=gha,mode=max
|
|
tags: ${{ steps.metadata.outputs.tags }} |