2022-10-19 07:10:15 -04:00
|
|
|
#!/usr/bin/env bash
|
2022-10-11 05:34:57 -04:00
|
|
|
# Copyright (c) Edgeless Systems GmbH
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2022-10-19 07:10:15 -04:00
|
|
|
set -euo pipefail
|
2022-11-10 04:28:35 -05:00
|
|
|
shopt -s inherit_errexit
|
2022-10-19 07:10:15 -04:00
|
|
|
|
|
|
|
# Show progress on pipes if `pv` is installed
|
|
|
|
# Otherwise use plain cat
|
2022-11-10 08:17:04 -05:00
|
|
|
if ! command -v pv &> /dev/null; then
|
|
|
|
PV="cat"
|
2022-10-19 07:10:15 -04:00
|
|
|
else
|
2022-11-10 08:17:04 -05:00
|
|
|
PV="pv"
|
2022-10-19 07:10:15 -04:00
|
|
|
fi
|
|
|
|
|
2022-11-10 08:17:04 -05:00
|
|
|
pack() {
|
|
|
|
local cloudprovider=$1
|
|
|
|
local unpacked_image=$2
|
|
|
|
local packed_image=$3
|
|
|
|
local unpacked_image_dir
|
|
|
|
unpacked_image_dir=$(mktemp -d)
|
|
|
|
local unpacked_image_filename
|
|
|
|
unpacked_image_filename=disk.raw
|
|
|
|
local tmp_tar_file
|
|
|
|
tmp_tar_file=$(mktemp -t verity.XXXXXX.tar)
|
|
|
|
cp "${unpacked_image}" "${unpacked_image_dir}/${unpacked_image_filename}"
|
|
|
|
|
|
|
|
case ${cloudprovider} in
|
|
|
|
|
|
|
|
gcp)
|
|
|
|
echo "📥 Packing GCP image..."
|
|
|
|
tar --owner=0 --group=0 -C "${unpacked_image_dir}" -Sch --format=oldgnu -f "${tmp_tar_file}" "${unpacked_image_filename}"
|
|
|
|
"${PV}" "${tmp_tar_file}" | pigz -9c > "${packed_image}"
|
|
|
|
rm "${tmp_tar_file}"
|
|
|
|
echo " Repacked image stored in ${packed_image}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
azure)
|
|
|
|
echo "📥 Packing Azure image..."
|
2023-12-08 08:40:31 -05:00
|
|
|
# Disk Images on Azure have to be a multiple of 1MiB in size.
|
2022-11-10 08:17:04 -05:00
|
|
|
truncate -s %1MiB "${unpacked_image_dir}/${unpacked_image_filename}"
|
|
|
|
qemu-img convert -p -f raw -O vpc -o force_size,subformat=fixed "${unpacked_image_dir}/${unpacked_image_filename}" "${packed_image}"
|
|
|
|
echo " Repacked image stored in ${packed_image}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
|
|
|
echo "unknown cloud provider"
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
rm -r "${unpacked_image_dir}"
|
2022-10-19 07:10:15 -04:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-11-10 04:28:35 -05:00
|
|
|
if [[ $# -ne 3 ]]; then
|
2022-11-10 08:17:04 -05:00
|
|
|
echo "Usage: $0 <cloudprovider> <unpacked_image> <packed_image>"
|
|
|
|
exit 1
|
2022-10-19 07:10:15 -04:00
|
|
|
fi
|
|
|
|
|
|
|
|
pack "${1}" "${2}" "${3}"
|