Adguardhome/scripts/make/build-docker.sh
Dimitry Kolyshev 82f2ac68ab Pull request: ADG-11407-add-docker-ci
Squashed commit of the following:

commit f9344df7c9f76a76135c21d200003338c3cb3282
Merge: 563f46c18 94a3a4fa6
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Fri Feb 20 09:45:05 2026 +0700

    Merge remote-tracking branch 'origin/master' into ADG-11407-add-docker-ci

commit 563f46c18a31817a53d97b8395706551826a4c43
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Thu Feb 19 11:44:15 2026 +0700

    docker: fix e2e

commit bcb68f6cee616983cd55e297f5d06a9fa389230a
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Wed Feb 18 13:10:48 2026 +0700

    docker: rm info e2e

commit b48cc46b7c7126f87266edac73f1135f5fffd6a2
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Wed Feb 18 12:59:50 2026 +0700

    docker: info e2e

commit 9cb7ec0a7d27a2cf0c1a3424061b88296bcabc10
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Wed Feb 18 12:15:32 2026 +0700

    docker: fix e2e

commit e6e0d7f65c71cb7cc926011fb1012b31d7070084
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Tue Feb 17 12:18:06 2026 +0700

    docker: artifacts

commit 2a28805f213b48ce601eebed00588450893d93e8
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Tue Feb 17 12:16:28 2026 +0700

    Revert "docker: fix e2e"
    
    This reverts commit e31a4d9056ffe4f03398a83bfb73f262324963fa.

commit a6548ee9204f316b00663dd164d0b9627a6d5a6c
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Tue Feb 17 12:11:56 2026 +0700

    docker: artifacts

commit e31a4d9056ffe4f03398a83bfb73f262324963fa
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Tue Feb 17 12:06:40 2026 +0700

    docker: fix e2e

commit 66aa5a33330ec6b07e9754678a2c4bb6f280bccb
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Tue Feb 17 11:12:29 2026 +0700

    docker: fix e2e

commit 1947763317d5822db16e1ae0611bf78d274da441
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 15:58:26 2026 +0700

    docker: fix

commit 537a97239529540e6e850b4df8c28122c247812b
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 15:45:24 2026 +0700

    docker: imp

commit a3894cef0c3c6e38c04a55c3a859b501d7f481d6
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 15:42:27 2026 +0700

    docker: imp

commit c835a768fd6c7786c812b6f207810ae7d33d5f68
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 15:38:37 2026 +0700

    docker: imp

commit 74cfdd0ec9706ac9f963a484920a0d3046d739e6
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 15:35:56 2026 +0700

    docker: imp

commit 02219a3e9c35e1d3e9a852a5e55f6549b69fdff2
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 15:33:20 2026 +0700

    docker: ci frontend

commit 120f0b8afb9f30ac9b664108c9fcaa915cea5bf3
Merge: d31272bb0 a165cdb68
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Mon Feb 16 09:58:58 2026 +0700

    Merge remote-tracking branch 'refs/remotes/origin/master' into ADG-11407-add-docker-ci
    
    # Conflicts:
    #	bamboo-specs/test.yaml

commit d31272bb0e77f560d9ca7109d5285f2af50bb309
Author: Dimitry Kolyshev <dkolyshev@adguard.com>
Date:   Wed Jan 28 11:05:06 2026 +0700

    all: add docker ci
2026-02-20 03:37:47 +00:00

148 lines
3.8 KiB
Bash

#!/bin/sh
verbose="${VERBOSE:-0}"
if [ "$verbose" -gt '0' ]; then
set -x
else
set +x
fi
set -e -f -u
# Require these to be set. The channel value is validated later.
channel="${CHANNEL:?please set CHANNEL}"
commit="${REVISION:?please set REVISION}"
dist_dir="${DIST_DIR:?please set DIST_DIR}"
readonly channel commit dist_dir
if [ "${VERSION:-}" = 'v0.0.0' ] || [ "${VERSION:-}" = '' ]; then
version="$(sh ./scripts/make/version.sh)"
else
version="$VERSION"
fi
readonly version
# Allow users to use sudo.
sudo_cmd="${SUDO:-}"
readonly sudo_cmd
# Make sure that those are built using something like:
# make ARCH='386 amd64 arm arm64 ppc64le' OS=linux VERBOSE=1 build-release
docker_platforms="\
linux/386,\
linux/amd64,\
linux/arm/v6,\
linux/arm/v7,\
linux/arm64,\
linux/ppc64le"
readonly docker_platforms
build_date="$(date -u +'%Y-%m-%dT%H:%M:%SZ')"
readonly build_date
# Set DOCKER_IMAGE_NAME to 'adguard/adguard-home' if you want (and are allowed)
# to push to DockerHub.
docker_image_name="${DOCKER_IMAGE_NAME:-adguardhome-dev}"
readonly docker_image_name
# Set DOCKER_PUSH to '1' if you want (and are allowed) to push to DockerHub.
docker_push="${DOCKER_PUSH:-0}"
readonly docker_push
case "$channel" in
'release')
docker_version_tag="--tag=${docker_image_name}:${version}"
docker_channel_tag="--tag=${docker_image_name}:latest"
;;
'beta')
docker_version_tag="--tag=${docker_image_name}:${version}"
docker_channel_tag="--tag=${docker_image_name}:beta"
;;
'edge')
# Set the version tag to an empty string when pushing to the edge channel.
docker_version_tag=''
docker_channel_tag="--tag=${docker_image_name}:edge"
;;
'development')
# Set both tags to an empty string for development builds.
docker_version_tag=''
docker_channel_tag=''
;;
*)
echo "invalid channel '$channel', supported values are\
'development', 'edge', 'beta', and 'release'" 1>&2
exit 1
;;
esac
readonly docker_version_tag docker_channel_tag
# Copy the binaries into a new directory under new names, so that it's easier to
# COPY them later. DO NOT remove the trailing underscores. See file
# docker/Dockerfile.
dist_docker="${dist_dir}/docker"
readonly dist_docker
mkdir -p "$dist_docker"
cp "${dist_dir}/AdGuardHome_linux_386/AdGuardHome/AdGuardHome" \
"${dist_docker}/AdGuardHome_linux_386_"
cp "${dist_dir}/AdGuardHome_linux_amd64/AdGuardHome/AdGuardHome" \
"${dist_docker}/AdGuardHome_linux_amd64_"
cp "${dist_dir}/AdGuardHome_linux_arm64/AdGuardHome/AdGuardHome" \
"${dist_docker}/AdGuardHome_linux_arm64_"
cp "${dist_dir}/AdGuardHome_linux_arm_6/AdGuardHome/AdGuardHome" \
"${dist_docker}/AdGuardHome_linux_arm_v6"
cp "${dist_dir}/AdGuardHome_linux_arm_7/AdGuardHome/AdGuardHome" \
"${dist_docker}/AdGuardHome_linux_arm_v7"
cp "${dist_dir}/AdGuardHome_linux_ppc64le/AdGuardHome/AdGuardHome" \
"${dist_docker}/AdGuardHome_linux_ppc64le_"
# docker_build_opt_tag is a function that wraps the call of docker build command
# with optionally --tag flags.
docker_build_opt_tag() {
if [ "$sudo_cmd" != '' ]; then
set -- "$sudo_cmd"
fi
# Set the initial parameters.
set -- \
"$@" \
docker \
buildx \
build \
--build-arg BUILD_DATE="$build_date" \
--build-arg DIST_DIR="$dist_dir" \
--build-arg VCS_REF="$commit" \
--build-arg VERSION="$version" \
--platform "$docker_platforms" \
--progress 'plain' \
;
# Append the channel tag, if any.
if [ "$docker_channel_tag" != '' ]; then
set -- "$@" "$docker_channel_tag"
fi
# Append the version tag, if any.
if [ "$docker_version_tag" != '' ]; then
set -- "$@" "$docker_version_tag"
fi
# Push to DockerHub, if requested.
if [ "$docker_push" -eq 1 ]; then
set -- "$@" '--push'
fi
# Append the rest.
set -- \
"$@" \
-f \
./docker/build.Dockerfile \
. \
;
# Call the command with the assembled parameters.
"$@"
}
docker_build_opt_tag