@ -52,10 +52,19 @@ jobs:
# build performance and the ability to copy extended file attributes
# (e.g., for executable capabilities) across build phases.
DOCKER_BUILDKIT : 1
# DOCKER_REPO/secrets.DOCKERHUB_REPO needs to be 'index.docker.io/<user>/<repo>'
DOCKER_REPO : ${{ secrets.DOCKERHUB_REPO }}
SOURCE_COMMIT : ${{ github.sha }}
SOURCE_REPOSITORY_URL : "https://github.com/${{ github.repository }}"
# The *_REPO variables need to be configured as repository variables
# Append `/settings/variables/actions` to your repo url
# DOCKERHUB_REPO needs to be 'index.docker.io/<user>/<repo>'
# Check for Docker hub credentials in secrets
HAVE_DOCKERHUB_LOGIN : ${{ vars.DOCKERHUB_REPO != '' && secrets.DOCKERHUB_USERNAME != '' && secrets.DOCKERHUB_TOKEN != '' }}
# GHCR_REPO needs to be 'ghcr.io/<user>/<repo>'
# Check for Github credentials in secrets
HAVE_GHCR_LOGIN : ${{ vars.GHCR_REPO != '' && github.repository_owner != '' && secrets.GITHUB_TOKEN != '' }}
# QUAY_REPO needs to be 'quay.io/<user>/<repo>'
# Check for Quay.io credentials in secrets
HAVE_QUAY_LOGIN : ${{ vars.QUAY_REPO != '' && secrets.QUAY_USERNAME != '' && secrets.QUAY_TOKEN != '' }}
if : ${{ needs.skip_check.outputs.should_skip != 'true' && github.repository == 'dani-garcia/vaultwarden' }}
strategy:
matrix:
@ -64,17 +73,10 @@ jobs:
steps:
# Checkout the repo
- name : Checkout
uses : actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3 .0
uses : actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3.4 .0
with:
fetch-depth : 0
# Login to Docker Hub
- name : Login to Docker Hub
uses : docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a # v2.1.0
with:
username : ${{ secrets.DOCKERHUB_USERNAME }}
password : ${{ secrets.DOCKERHUB_TOKEN }}
# Determine Docker Tag
- name : Init Variables
id : vars
@ -88,34 +90,146 @@ jobs:
fi
# End Determine Docker Tag
- name : Build Debian based images
# Login to Docker Hub
- name : Login to Docker Hub
uses : docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a # v2.1.0
with:
username : ${{ secrets.DOCKERHUB_USERNAME }}
password : ${{ secrets.DOCKERHUB_TOKEN }}
if : ${{ env.HAVE_DOCKERHUB_LOGIN == 'true' }}
# Login to GitHub Container Registry
- name : Login to GitHub Container Registry
uses : docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a # v2.1.0
with:
registry : ghcr.io
username : ${{ github.repository_owner }}
password : ${{ secrets.GITHUB_TOKEN }}
if : ${{ env.HAVE_GHCR_LOGIN == 'true' }}
# Login to Quay.io
- name : Login to Quay.io
uses : docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a # v2.1.0
with:
registry : quay.io
username : ${{ secrets.QUAY_USERNAME }}
password : ${{ secrets.QUAY_TOKEN }}
if : ${{ env.HAVE_QUAY_LOGIN == 'true' }}
# Debian
# Docker Hub
- name : Build Debian based images (docker.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.DOCKERHUB_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}"
run : |
./hooks/build
if : ${{ matrix.base_image == 'debian' && env.HAVE_DOCKERHUB_LOGIN == 'true' }}
- name : Push Debian based images (docker.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.DOCKERHUB_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}"
run : |
./hooks/push
if : ${{ matrix.base_image == 'debian' && env.HAVE_DOCKERHUB_LOGIN == 'true' }}
# GitHub Container Registry
- name : Build Debian based images (ghcr.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.GHCR_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}"
run : |
./hooks/build
if : ${{ matrix.base_image == 'debian' && env.HAVE_GHCR_LOGIN == 'true' }}
- name : Push Debian based images (ghcr.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.GHCR_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}"
run : |
./hooks/push
if : ${{ matrix.base_image == 'debian' && env.HAVE_GHCR_LOGIN == 'true' }}
# Quay.io
- name : Build Debian based images (quay.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.QUAY_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}"
run : |
./hooks/build
if : ${{ matrix.base_image == 'debian' }}
if : ${{ matrix.base_image == 'debian' && env.HAVE_QUAY_LOGIN == 'true' }}
- name : Push Debian based images
- name : Push Debian based images (quay.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.QUAY_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}"
run : |
./hooks/push
if : ${{ matrix.base_image == 'debian' }}
if : ${{ matrix.base_image == 'debian' && env.HAVE_QUAY_LOGIN == 'true' }}
# Alpine
# Docker Hub
- name : Build Alpine based images (docker.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.DOCKERHUB_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}-alpine"
run : |
./hooks/build
if : ${{ matrix.base_image == 'alpine' && env.HAVE_DOCKERHUB_LOGIN == 'true' }}
- name : Push Alpine based images (docker.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.DOCKERHUB_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}-alpine"
run : |
./hooks/push
if : ${{ matrix.base_image == 'alpine' && env.HAVE_DOCKERHUB_LOGIN == 'true' }}
# GitHub Container Registry
- name : Build Alpine based images (ghcr.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.GHCR_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}-alpine"
run : |
./hooks/build
if : ${{ matrix.base_image == 'alpine' && env.HAVE_GHCR_LOGIN == 'true' }}
- name : Push Alpine based images (ghcr.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.GHCR_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}-alpine"
run : |
./hooks/push
if : ${{ matrix.base_image == 'alpine' && env.HAVE_GHCR_LOGIN == 'true' }}
- name : Build Alpine based images
# Quay.io
- name : Build Alpine based images (quay.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.QUAY_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}-alpine"
run : |
./hooks/build
if : ${{ matrix.base_image == 'alpine' }}
if : ${{ matrix.base_image == 'alpine' && env.HAVE_QUAY_LOGIN == 'true' }}
- name : Push Alpine based images
- name : Push Alpine based images (quay.io)
shell : bash
env:
DOCKER_REPO : "${{ vars.QUAY_REPO }}"
DOCKER_TAG : "${{steps.vars.outputs.DOCKER_TAG}}-alpine"
run : |
./hooks/push
if : ${{ matrix.base_image == 'alpine' }}
if : ${{ matrix.base_image == 'alpine' && env.HAVE_QUAY_LOGIN == 'true' }}