From 63a42def17080f22aa137c97cd4b78b11bd5e4aa Mon Sep 17 00:00:00 2001 From: vdovhanych Date: Tue, 20 Jul 2021 11:07:03 +0200 Subject: [PATCH] feat(ci): add sha checksum for alpine download and change to https --- build-docker.sh | 19 ++++++++++++++++++- ci/environment.yml | 4 +++- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/build-docker.sh b/build-docker.sh index 3380fc8ef..5a727faa2 100755 --- a/build-docker.sh +++ b/build-docker.sh @@ -18,8 +18,22 @@ if [ -z "$ALPINE_ARCH" ]; then esac fi +if [ -z "$ALPINE_CHECKSUM" ]; then + case "$ALPINE_ARCH" in + aarch64) + ALPINE_CHECKSUM="bc541e148463b3dde10fdbb1af8eac4e34706eae8883c6d126263db07a9a9c42" + ;; + x86_64) + ALPINE_CHECKSUM="bcdf5a4e58637b9228f8e474547a3de9ea02a05a5fa68a2495b0657ada7e65f6" + ;; + *) + exit + esac + fi + + CONTAINER_NAME=${CONTAINER_NAME:-trezor-firmware-env.nix} -ALPINE_CDN=${ALPINE_CDN:-http://dl-cdn.alpinelinux.org/alpine} +ALPINE_CDN=${ALPINE_CDN:-https://dl-cdn.alpinelinux.org/alpine} ALPINE_RELEASE=${ALPINE_RELEASE:-3.14} ALPINE_VERSION=${ALPINE_VERSION:-3.14.0} ALPINE_TARBALL=${ALPINE_FILE:-alpine-minirootfs-$ALPINE_VERSION-$ALPINE_ARCH.tar.gz} @@ -59,6 +73,9 @@ else fi fi +# check alpine checksum +echo "${ALPINE_CHECKSUM} ci/${ALPINE_TARBALL}" | sha256sum -c + docker build --build-arg ALPINE_VERSION="$ALPINE_VERSION" --build-arg ALPINE_ARCH="$ALPINE_ARCH" --build-arg NIX_VERSION="$NIX_VERSION" -t "$CONTAINER_NAME" ci/ # stat under macOS has slightly different cli interface diff --git a/ci/environment.yml b/ci/environment.yml index 8b6f9d344..47d533e4c 100644 --- a/ci/environment.yml +++ b/ci/environment.yml @@ -8,13 +8,15 @@ environment: ALPINE_RELEASE: "3.14" ALPINE_ARCH: "x86_64" ALPINE_VERSION: "3.14.0" + ALPINE_CHECKSUM: "bcdf5a4e58637b9228f8e474547a3de9ea02a05a5fa68a2495b0657aaa7e65f6" NIX_VERSION: "2.3.14" services: - docker:dind before_script: - docker login $CI_REGISTRY -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD script: - - wget -nc -P ci/ http://dl-cdn.alpinelinux.org/alpine/v$ALPINE_RELEASE/releases/$ALPINE_ARCH/alpine-minirootfs-$ALPINE_VERSION-$ALPINE_ARCH.tar.gz + - wget -nc -P ci/ https://dl-cdn.alpinelinux.org/alpine/v$ALPINE_RELEASE/releases/$ALPINE_ARCH/alpine-minirootfs-$ALPINE_VERSION-$ALPINE_ARCH.tar.gz + - echo "${ALPINE_CHECKSUM} ci/alpine-minirootfs-$ALPINE_VERSION-$ALPINE_ARCH.tar.gz" | sha256sum -c - docker build --tag $CONTAINER_NAME:$CI_COMMIT_SHA --tag $CONTAINER_NAME:latest --build-arg ALPINE_VERSION="$ALPINE_VERSION" --build-arg ALPINE_ARCH="$ALPINE_ARCH" --build-arg NIX_VERSION="$NIX_VERSION" --build-arg FULLDEPS_TESTING=1 ci/ - docker push $CONTAINER_NAME:$CI_COMMIT_SHA - docker push $CONTAINER_NAME:latest