mirror of
https://github.com/AdguardTeam/AdGuardHome.git
synced 2026-06-28 03:41:19 +00:00
Squashed commit of the following: commit f9344df7c9f76a76135c21d200003338c3cb3282 Merge: 563f46c1894a3a4fa6Author: 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: d31272bb0a165cdb68Author: 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
148 lines
3.8 KiB
Bash
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
|