diff --git a/local/README.md b/local/README.md new file mode 100644 index 000000000..09ee0ae23 --- /dev/null +++ b/local/README.md @@ -0,0 +1,3 @@ +# The Local Directory + +This directory is for scripts involved with building and testing Twoliter. diff --git a/local/alpha-sdk.dockerfile b/local/alpha-sdk.dockerfile new file mode 100644 index 000000000..2453e95d1 --- /dev/null +++ b/local/alpha-sdk.dockerfile @@ -0,0 +1,21 @@ +ARG SDK +ARG HOST_GOARCH + +FROM $SDK +FROM --platform=linux/${HOST_GOARCH} $SDK + +COPY build/rpms/ /twoliter/alpha/build/rpms/ + +# These may need to be moved to Twoliter, but for now we will access them from the Alpha SDK. +# They have been moved into the .cargo directory because they are otherwise .dockerignored. +COPY .cargo/sbkeys/generate-local-sbkeys /twoliter/alpha/sbkeys/generate-local-sbkeys +COPY .cargo/sbkeys/generate-aws-sbkeys /twoliter/alpha/sbkeys/generate-aws-sbkeys + +# These directories are needed by the build system's Dockerfile. To be eliminated later. +COPY sources/logdog/conf/current /twoliter/alpha/sources/logdog/conf/current +COPY sources/models/src/variant /twoliter/alpha/sources/models/src/variant + +# TODO - move these to an RPM package so we don't need to copy them here. +COPY LICENSE-APACHE /twoliter/alpha/licenses/LICENSE-APACHE +COPY LICENSE-MIT /twoliter/alpha/licenses/LICENSE-MIT +COPY COPYRIGHT /twoliter/alpha/licenses/COPYRIGHT diff --git a/local/alpha-sdk.sh b/local/alpha-sdk.sh new file mode 100755 index 000000000..7619e6896 --- /dev/null +++ b/local/alpha-sdk.sh @@ -0,0 +1,186 @@ +#!/usr/bin/env bash + +# The Alpha milestone (i.e. preceding Beta) represents a version of Twoliter that can build a +# customized variant before Kits have been implemented. See: +# - https://github.com/bottlerocket-os/twoliter/issues/74 +# - https://github.com/bottlerocket-os/twoliter/issues/56 +# +# This script builds a bottlerocket variant, then copies certain contents of the Bottlerocket build +# directory into a layer added to the SDK. Twoliter's build variant command will expect these to be +# available in the SDK at `/twoliter/alpha` until Kits have been implemented. + +# The directory this script is located in. +script_dir=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) + +# +# Common error handling +# + +exit_trap_cmds=() + +on_exit() { + exit_trap_cmds+=( "$1" ) +} + +run_exit_trap_cmds() { + for cmd in "${exit_trap_cmds[@]}"; do + eval "${cmd}" + done +} + +trap run_exit_trap_cmds EXIT + +warn() { + >&2 echo "Warning: $*" +} + +bail() { + if [[ $# -gt 0 ]]; then + >&2 echo "Error: $*" + fi + exit 1 +} + +usage() { + cat <&2 usage + bail "$1" +} + +# +# Parse arguments +# + +while [[ $# -gt 0 ]]; do + case $1 in + --bottlerocket-dir) + shift; bottlerocket_dir=$1 ;; + --variant) + shift; variant=$1 ;; + --sdk-version) + shift; sdk_version=$1 ;; + --sdk-name) + shift; sdk_name=$1 ;; + --sdk-registry) + shift; sdk_registry=$1 ;; + --alpha-registry) + shift; alpha_registry=$1 ;; + --alpha-name) + shift; alpha_name=$1 ;; + --alpha-version) + shift; alpha_version=$1 ;; + --skip-clean) + shift; skip_clean="true" ;; + -h|--help) + usage; exit 0 ;; + *) + usage_error "Invalid option '$1'" ;; + esac + shift +done + +set -e + +[[ -n ${bottlerocket_dir} ]] || usage_error 'required: --bottlerocket-dir' +[[ -n ${alpha_registry} ]] || usage_error 'required: --alpha-registry' +[[ -n ${alpha_version} ]] || usage_error 'required: --alpha-version' + +variant="${variant:=aws-dev}" +sdk_name="${sdk_name:=bottlerocket-sdk}" +sdk_registry="${sdk_registry:=public.ecr.aws/bottlerocket}" +sdk_repo="${sdk_registry}/${sdk_name}" +alpha_name="${alpha_name:=twoliter-alpha-sdk}" +skip_clean="${skip_clean:=false}" + +cd "${bottlerocket_dir}" + +if [ -z "${sdk_version}" ]; then + sdk_version=$(cat Twoliter.toml | grep bottlerocket-sdk -A1 | grep -Eoh '"[0-9.v]+"' | cut -d '"' -f2) + echo "SDK Version '${sdk_version}' parsed from Twoliter.toml" +fi + +for target_arch in x86_64 aarch64 +do + + if [ "${skip_clean}" = "false" ]; then + cargo make clean + fi + + # We need the sbkeys scripts in a location that is not .dockerignored but is .gitignored + rm -rf "${bottlerocket_dir}/build/sbkeys" + mkdir -p "${bottlerocket_dir}/build/sbkeys" + cp "${bottlerocket_dir}/sbkeys/generate-aws-sbkeys" "${bottlerocket_dir}/.cargo/sbkeys" + cp "${bottlerocket_dir}/sbkeys/generate-local-sbkeys" "${bottlerocket_dir}/.cargo/sbkeys" + + + cargo make \ + -e "BUILDSYS_VARIANT=${variant}" \ + -e "BUILDSYS_ARCH=${target_arch}" \ + build-variant + + for host_arch in amd64 arm64 + do + sdk="${sdk_repo}-${target_arch}:${sdk_version}" + tag="${alpha_registry}/${alpha_name}-${target_arch}:${alpha_version}-${host_arch}" + echo "creating image ${tag}" + + docker build \ + --tag "${tag}" \ + --build-arg "SDK=${sdk}" \ + --build-arg "HOST_GOARCH=${host_arch}" \ + --build-arg "TARGET_ARCH=${target_arch}" \ + --file "${script_dir}/alpha-sdk.dockerfile" \ + "${bottlerocket_dir}" +# docker push "${tag}" + done + + arm_host="${alpha_registry}/${alpha_name}-${target_arch}:${alpha_version}-arm64" + amd_host="${alpha_registry}/${alpha_name}-${target_arch}:${alpha_version}-amd64" + multiarch="${alpha_registry}/${alpha_name}-${target_arch}:${alpha_version}" + + echo "creating multiarch manifest ${multiarch}" + docker manifest create "${multiarch}" "${arm_host}" "${amd_host}" + echo "pushing multiarch manifest ${multiarch}" + docker manifest push "${multiarch}" + +done