Skip to content

Commit

Permalink
Remove Codenotary CAS (#182)
Browse files Browse the repository at this point in the history
* Remove Codenotary CAS

* Fix text

* fix other stuff
  • Loading branch information
pvizeli authored Sep 23, 2023
1 parent 866aaae commit 2cb6859
Show file tree
Hide file tree
Showing 3 changed files with 7 additions and 76 deletions.
15 changes: 1 addition & 14 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ FROM $BUILD_FROM

ARG \
BUILD_ARCH \
CAS_VERSION \
YQ_VERSION \
COSIGN_VERSION

Expand All @@ -14,15 +13,7 @@ RUN \
docker \
docker-cli-buildx \
coreutils \
&& apk add --no-cache --virtual .build-dependencies \
build-base \
go \
\
&& git clone -b v${CAS_VERSION} --depth 1 \
https://github.com/codenotary/cas \
&& cd cas \
&& make cas \
&& mv cas /usr/bin/cas \
&& if [ "${BUILD_ARCH}" = "armhf" ] || [ "${BUILD_ARCH}" = "armv7" ]; then \
wget -q -O /usr/bin/yq "https://github.com/mikefarah/yq/releases/download/${YQ_VERSION}/yq_linux_arm"; \
wget -q -O /usr/bin/cosign "https://github.com/home-assistant/cosign/releases/download/${COSIGN_VERSION}/cosign_armhf"; \
Expand All @@ -39,11 +30,7 @@ RUN \
exit 1; \
fi \
&& chmod +x /usr/bin/yq \
&& chmod +x /usr/bin/cosign \
\
&& apk del .build-dependencies \
&& rm -rf /root/go /root/.cache \
&& rm -rf /usr/src/cas
&& chmod +x /usr/bin/cosign

COPY builder.sh /usr/bin/

Expand Down
4 changes: 0 additions & 4 deletions build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,10 @@ build_from:
armhf: "ghcr.io/home-assistant/armhf-base:3.18"
amd64: "ghcr.io/home-assistant/amd64-base:3.18"
i386: "ghcr.io/home-assistant/i386-base:3.18"
codenotary:
signer: notary@home-assistant.io
base_image: notary@home-assistant.io
cosign:
base_identity: https://github.com/home-assistant/docker-base/.*
identity: https://github.com/home-assistant/builder/.*
args:
CAS_VERSION: "1.0.1"
YQ_VERSION: "v4.13.2"
COSIGN_VERSION: "2.0.2"
labels:
Expand Down
64 changes: 6 additions & 58 deletions builder.sh
Original file line number Diff line number Diff line change
Expand Up @@ -226,7 +226,6 @@ function run_build() {
local cosign_base_issuer=
local cosign_identity=
local cosign_issuer=
local codenotary_sign=

# Overwrites
if bashio::var.has_value "${DOCKER_HUB}"; then repository="${DOCKER_HUB@L}"; fi
Expand All @@ -253,9 +252,6 @@ function run_build() {
cosign_base_issuer="$(jq --raw-output '.cosign.base_issuer // "https://token.actions.githubusercontent.com"' "/tmp/build_config/build.json")"
cosign_identity="$(jq --raw-output '.cosign.identity // empty' "/tmp/build_config/build.json")"
cosign_issuer="$(jq --raw-output '.cosign.issuer // "https://token.actions.githubusercontent.com"' "/tmp/build_config/build.json")"

# remove later
codenotary_sign="$(jq --raw-output '.codenotary.signer // empty' "/tmp/build_config/build.json")"
fi

# Adjust Qemu CPU
Expand Down Expand Up @@ -365,9 +361,6 @@ function run_build() {
push_images+=("${shadow_repository}/${image}:${version}")
fi

# Singing image (cas)
codenotary_sign "${codenotary_sign}" "${repository}/${image}:${version}"

# Push images
if bashio::var.true "${DOCKER_PUSH}"; then
for i in "${push_images[@]}"; do
Expand Down Expand Up @@ -581,7 +574,6 @@ function build_generic() {
local shadow_repository=
local raw_image=
local args=
local codenotary_sign=
local docker_cli=()
local docker_tags=()

Expand All @@ -592,7 +584,6 @@ function build_generic() {
labels="$(jq --raw-output '.labels // empty | keys[]' "/tmp/build_config/build.json")"
raw_image="$(jq --raw-output '.image // empty' "/tmp/build_config/build.json")"
shadow_repository="$(jq --raw-output '.shadow_repository // empty' "/tmp/build_config/build.json")"
codenotary_sign="$(jq --raw-output '.codenotary.signer // empty' "/tmp/build_config/build.json")"
fi

# Set defaults build things
Expand Down Expand Up @@ -730,48 +721,6 @@ function init_crosscompile() {
> /dev/null 2>&1 || bashio::log.warning "Can't enable crosscompiling feature"
}

#### Security CodeNotary ####

function codenotary_setup() {
if bashio::var.false "${DOCKER_PUSH}" || bashio::var.is_empty "${CAS_API_KEY+x}"; then
return 0
fi

for j in {1..15}; do
if cas login > /dev/null 2>&1; then
return 0
fi
sleep $((5 * j))
done

bashio::exit.nok "Login to Codenotary fails!"
}

function codenotary_sign() {
local trust=$1
local image=$2

local success=false

if bashio::var.false "${DOCKER_PUSH}" || bashio::var.is_empty "${CAS_API_KEY+x}"; then
return 0
fi

for j in {1..15}; do
if ! cas authenticate --signerID "${trust}" --silent "docker://${image}"; then
cas notarize --ci-attr "docker://${image}" || true
else
success=true
break
fi
sleep $((5 * j))
done

if bashio::var.false "${success}"; then
bashio::exit.nok "Failed to sign the image (cas)"
fi
bashio::log.info "Signed ${image} with ${trust} (cas)"
}

#### Security cosign ####

Expand All @@ -793,9 +742,9 @@ function cosign_sign() {
done

if bashio::var.false "${success}"; then
bashio::exit.nok "Failed to sign the image (cosign)"
bashio::exit.nok "Failed to sign the image with cosign"
fi
bashio::log.info "Signed ${image} with ${trust} (cosign)"
bashio::log.info "Signed ${image} with cosign"
}

function cosign_verify() {
Expand All @@ -809,7 +758,7 @@ function cosign_verify() {

# Support scratch image
if [ "$image" == "scratch" ]; then
bashio::log.info "Scratch image, skiping validation (cosign)"
bashio::log.info "Scratch image, skiping validation with cosign"
return 0
fi

Expand All @@ -834,13 +783,13 @@ function cosign_verify() {
done

if bashio::var.false "${success}"; then
bashio::log.warning "Validation of ${image} fails (cosign)!"
bashio::log.warning "Validation of ${image} fails with cosign!"
if bashio::var.true "${pull}"; then
docker rmi "${image}" > /dev/null 2>&1 || true
fi
return 1
fi
bashio::log.info "Image ${image} is trusted (cosign)"
bashio::log.info "Image ${image} is trusted by cosign"
}


Expand Down Expand Up @@ -1002,11 +951,10 @@ convert_to_json
# Copy configuration files to tmp
copy_config_tmp

# Login into dockerhub & setup CodeNotary
# Login into dockerhub
if [ -n "$DOCKER_USER" ] && [ -n "$DOCKER_PASSWORD" ]; then
docker login -u "$DOCKER_USER" -p "$DOCKER_PASSWORD"
fi
codenotary_setup

# Select arch build
if [ "${#BUILD_LIST[@]}" -ne 0 ]; then
Expand Down

0 comments on commit 2cb6859

Please sign in to comment.