privatebin-docker-nginx-fpm.../buildx.sh

100 lines
2.5 KiB
Bash
Raw Normal View History

#!/bin/bash
# exit immediately on non-zero return code, including during a pipe stage or on
# accessing an uninitialized variable and print commands before executing them
set -euxo pipefail
EVENT=$1
2021-09-29 20:03:42 +02:00
IMAGE=$2
EDGE=false
2021-09-29 20:03:42 +02:00
[ "$3" = edge ] && EDGE=true
build_image() {
# shellcheck disable=SC2068
docker build \
2021-07-14 20:24:07 +02:00
--pull \
--no-cache \
2021-10-14 20:56:14 +02:00
$@ \
.
}
push_image() {
# shellcheck disable=SC2068
docker buildx build \
--platform linux/amd64,linux/386,linux/arm/v6,linux/arm/v7,linux/arm64,linux/ppc64le \
2021-07-14 20:24:07 +02:00
--progress plain \
--pull \
--no-cache \
--push \
2021-10-14 20:56:14 +02:00
$@ \
2021-07-14 20:24:07 +02:00
.
}
2021-07-14 20:24:07 +02:00
docker_login() {
printenv DOCKER_PASSWORD | docker login \
--username "$DOCKER_USERNAME" \
--password-stdin
}
is_image_push_required() {
2021-07-14 20:24:07 +02:00
[ "$EVENT" != pull_request ] && { \
[ "$GITHUB_REF" != refs/heads/master ] || \
[ "$EVENT" = schedule ]
}
}
main() {
local TAG BUILD_ARGS
2021-07-14 21:32:17 +02:00
if [ "$EVENT" = schedule ] ; then
2021-07-14 20:24:07 +02:00
TAG=nightly
else
TAG=${GITHUB_REF##*/}
fi
2021-09-29 20:03:42 +02:00
case "$IMAGE" in
fs)
BUILD_ARGS="--build-arg ALPINE_PACKAGES= --build-arg COMPOSER_PACKAGES="
;;
pdo)
BUILD_ARGS="--build-arg ALPINE_PACKAGES=php8-pdo_mysql,php8-pdo_pgsql --build-arg COMPOSER_PACKAGES="
;;
gcs)
BUILD_ARGS="--build-arg ALPINE_PACKAGES=php8-openssl"
;;
*)
BUILD_ARGS=""
;;
esac
IMAGE="privatebin/$IMAGE"
2021-09-30 05:11:53 +02:00
if [ "$EDGE" = true ] ; then
sed -e 's/^FROM alpine:.*$/FROM alpine:edge/' Dockerfile > Dockerfile.edge
BUILD_ARGS="-f Dockerfile.edge --tag $IMAGE:edge $BUILD_ARGS"
IMAGE="$IMAGE:edge"
2021-09-30 05:11:53 +02:00
else
2021-10-14 21:13:11 +02:00
BUILD_ARGS="--tag $IMAGE:$TAG --tag ${IMAGE}:${TAG%%-*} --tag $IMAGE:latest $BUILD_ARGS"
IMAGE="$IMAGE:latest"
fi
build_image "$BUILD_ARGS"
docker run -d --rm -p 127.0.0.1:8080:8080 --read-only --name smoketest "$IMAGE"
sleep 5 # give the services time to start up and the log to collect any errors that might occur
test "$(docker inspect --format="{{.State.Running}}" smoketest)" = true
curl --silent --show-error -o /dev/null http://127.0.0.1:8080/
if docker logs smoketest 2>&1 | grep -E "warn|emerg|fatal|panic"
then
exit 1
fi
docker stop smoketest
if is_image_push_required ; then
docker_login
push_image "$BUILD_ARGS"
fi
2021-07-14 20:24:07 +02:00
rm -f Dockerfile.edge "$HOME/.docker/config.json"
}
2021-07-14 20:24:07 +02:00
[ "$(basename "$0")" = 'buildx.sh' ] && main