91 lines
2.2 KiB
Bash
Executable File
91 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -eo pipefail
|
|
|
|
hasunset=0
|
|
|
|
if [ "$UID" != "0" ]; then
|
|
echo "This script must be run in root."
|
|
exit 2
|
|
fi
|
|
|
|
PATH="$PWD/scripts:$PATH"
|
|
|
|
if [[ "$CLOUD_CONFIG_REPO" -eq "" ]]; then
|
|
echo "CLOUD_CONFIG_REPO is not set."
|
|
CLOUD_CONFIG_REPO="https://git.sfclub.cc/cloud/bearnet"
|
|
hasunset=1
|
|
fi
|
|
|
|
if [[ "$CLOUD_CONFIG_REVISION" -eq "" ]]; then
|
|
echo "CLOUD_CONFIG_REVISION is not set."
|
|
CLOUD_CONFIG_REVISION="wish"
|
|
hasunset=1
|
|
fi
|
|
|
|
if [[ "$CLOUD_GATEWAY_ADDRESS" -eq "" ]]; then
|
|
echo "CLOUD_GATEWAY_ADDRESS is not set."
|
|
CLOUD_GATEWAY_ADDRESS="10.0.0.119"
|
|
hasunset=1
|
|
fi
|
|
|
|
if [[ "$hasunset" -ne 0 ]]; then
|
|
echo ""
|
|
echo "Default values will be used for unset environments:"
|
|
echo ""
|
|
set | grep -E "^CLOUD_"
|
|
fi
|
|
|
|
# TMP_DIR=$(mktemp -d)
|
|
# cleanup_() {
|
|
# rm -rf $TMP_DIR
|
|
# }
|
|
|
|
# trap cleanup_ INT TERM EXIT
|
|
|
|
IMAGE_TAG=$(git rev-parse --short HEAD)
|
|
IMAGE_NAME=${IMAGE_NAME:-bearcloud}
|
|
|
|
echo "Image tag: $IMAGE_NAME:$IMAGE_TAG and $IMAGE_NAME:latest"
|
|
echo "Additional arguments for VM image: $VM_OPTS"
|
|
echo "Additional arguments for Hypervisor Image: $HY_OPTS"
|
|
echo "Continue?"
|
|
read
|
|
|
|
# rm -rf "$TMP_DIR"
|
|
# cp -r ./image $TMP_DIR
|
|
# sed -i "s#_REPO_#$CLOUD_CONFIG_REPO#g" $TMP_DIR/overlay/daemon/update-keys.sh && \
|
|
# sed -i "s#_REVISION_#$CLOUD_CONFIG_REVISION#g" $TMP_DIR/overlay/daemon/update-keys.sh && \
|
|
# sed -i "s#GATEWAY_ADDRESS#$CLOUD_GATEWAY_ADDRESS#g" $TMP_DIR/overlay/etc/dhcp/dhclient.conf
|
|
|
|
# pushd $PWD >/dev/null
|
|
|
|
# cd $TMP_DIR
|
|
# export IMAGE_ARTIFACT="$PWD/vm.raw"
|
|
# rm -f vm.raw && ./build-image.sh
|
|
# if [ ! -f $IMAGE_ARTIFACT ]; then
|
|
# exit 2
|
|
# fi
|
|
|
|
# popd > /dev/null
|
|
|
|
# mv $IMAGE_ARTIFACT ./data/
|
|
# IMAGE_ARTIFACT="$PWD/data/vm.raw"
|
|
|
|
BUILDERS=$(docker buildx ls)
|
|
if ! (echo $BUILDERS | grep -q "bearcloud"); then
|
|
docker buildx create --name bearcloud --buildkitd-flags '--allow-insecure-entitlement security.insecure'
|
|
fi
|
|
echo "BUILDING VM DISK IMAGE"
|
|
docker build \
|
|
--builder bearcloud \
|
|
--allow security.insecure \
|
|
-f vm.Dockerfile \
|
|
--target export \
|
|
--output type=local,dest=./data \
|
|
$VM_OPTS .
|
|
|
|
echo "BUILDING HYPERVISOR IMAGE"
|
|
docker build -t "$IMAGE_NAME:$IMAGE_TAG" -t "$IMAGE_NAME:latest" \
|
|
-f hypervisor.Dockerfile $HY_OPTS .
|