2015-12-22 15:30:23 +00:00
|
|
|
#! /bin/sh
|
|
|
|
|
|
|
|
# nix-shell -p gnumake jq openssh cac cacpanel
|
2015-12-22 22:37:12 +00:00
|
|
|
set -eufx
|
2015-12-22 15:30:23 +00:00
|
|
|
|
|
|
|
# 2 secrets are required:
|
2015-12-22 22:37:12 +00:00
|
|
|
|
2015-12-22 15:30:23 +00:00
|
|
|
krebs_cred=${krebs_cred-./cac.json}
|
|
|
|
retiolum_key=${retiolum_key-./retiolum.rsa_key.priv}
|
|
|
|
|
2015-12-28 12:23:34 +00:00
|
|
|
clear_defer(){
|
|
|
|
echo "${trapstr:-exit}"
|
|
|
|
trap - INT TERM EXIT KILL
|
|
|
|
}
|
|
|
|
defer(){
|
|
|
|
if test -z "${debug:-}"; then
|
|
|
|
trapstr="$1;${trapstr:-exit}"
|
|
|
|
trap "$trapstr" INT TERM EXIT KILL
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2015-12-22 15:30:23 +00:00
|
|
|
# Sanity
|
|
|
|
if test ! -r "$krebs_cred";then
|
|
|
|
echo "\$krebs_cred=$krebs_cred must be readable"; exit 1
|
|
|
|
fi
|
|
|
|
if test ! -r "$retiolum_key";then
|
|
|
|
echo "\$retiolum_key=$retiolum_key must be readable"; exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
krebs_secrets=$(mktemp -d)
|
|
|
|
sec_file=$krebs_secrets/cac_config
|
|
|
|
krebs_ssh=$krebs_secrets/tempssh
|
2015-12-22 23:06:27 +00:00
|
|
|
export cac_resources_cache=$krebs_secrets/res_cache.json
|
|
|
|
export cac_servers_cache=$krebs_secrets/servers_cache.json
|
|
|
|
export cac_tasks_cache=$krebs_secrets/tasks_cache.json
|
|
|
|
export cac_templates_cache=$krebs_secrets/templates_cache.json
|
2015-12-22 15:30:23 +00:00
|
|
|
# we need to receive this key from buildmaster to speed up tinc bootstrap
|
2015-12-28 12:23:34 +00:00
|
|
|
defer "trap - INT TERM EXIT"
|
|
|
|
defer "rm -r $krebs_secrets"
|
2015-12-22 15:30:23 +00:00
|
|
|
|
|
|
|
cat > $sec_file <<EOF
|
|
|
|
cac_login="$(jq -r .email $krebs_cred)"
|
2015-12-24 19:37:04 +00:00
|
|
|
cac_key="$(cac-cli --config $krebs_cred panel settings | jq -r .apicode)"
|
2015-12-22 15:30:23 +00:00
|
|
|
EOF
|
|
|
|
|
|
|
|
export cac_secrets=$sec_file
|
2015-12-24 19:37:04 +00:00
|
|
|
cac-cli --config $krebs_cred panel add-api-ip
|
2015-12-22 15:30:23 +00:00
|
|
|
|
|
|
|
# test login:
|
|
|
|
cac update
|
|
|
|
cac servers
|
|
|
|
|
2015-12-28 12:23:34 +00:00
|
|
|
# preserve old trap
|
|
|
|
old_trapstr=$(clear_defer)
|
|
|
|
while true;do
|
|
|
|
# Template 26: CentOS7
|
|
|
|
# TODO: use cac templates to determine the real Centos7 template in case it changes
|
2016-01-02 20:36:51 +00:00
|
|
|
out=$(cac build cpu=1 ram=512 storage=10 os=26 2>&1)
|
|
|
|
if name=$(echo "$out" | jq -r .servername);then
|
|
|
|
id=servername:$name
|
|
|
|
echo "got a working machine, id=$id"
|
|
|
|
else
|
|
|
|
echo "Unable to build a virtual machine, retrying in 15 seconds" >&2
|
|
|
|
echo "Output of build program: $out" >&2
|
|
|
|
sleep 15
|
|
|
|
continue
|
|
|
|
fi
|
2015-12-22 15:30:23 +00:00
|
|
|
|
2015-12-28 12:23:34 +00:00
|
|
|
clear_defer >/dev/null
|
|
|
|
defer "cac delete $id"
|
2015-12-22 15:30:23 +00:00
|
|
|
|
2015-12-28 12:23:34 +00:00
|
|
|
# TODO: timeout?
|
|
|
|
|
|
|
|
wait_login_cac(){
|
2016-01-02 20:36:51 +00:00
|
|
|
# we wait for 30 minutes
|
|
|
|
for t in `seq 180`;do
|
2015-12-28 12:23:34 +00:00
|
|
|
# now we have a working cac server
|
|
|
|
if cac ssh $1 -o ConnectTimeout=10 \
|
|
|
|
cat /etc/redhat-release | \
|
|
|
|
grep CentOS ;then
|
|
|
|
return 0
|
|
|
|
fi
|
|
|
|
sleep 10
|
|
|
|
done
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
# die on timeout
|
|
|
|
if ! wait_login_cac $id;then
|
|
|
|
echo "unable to boot a working system within time frame, retrying..." >&2
|
|
|
|
echo "Cleaning up old image,last status: $(cac update;cac getserver $id | jq -r .status)"
|
2015-12-30 03:56:53 +00:00
|
|
|
eval "$(clear_defer | sed 's/;exit//')"
|
2016-01-02 20:36:51 +00:00
|
|
|
sleep 15
|
2015-12-28 12:23:34 +00:00
|
|
|
else
|
|
|
|
echo "got a working system" >&2
|
2015-12-30 03:56:53 +00:00
|
|
|
break
|
2015-12-28 12:23:34 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
clear_defer >/dev/null
|
|
|
|
defer "cac delete $id;$old_trapstr"
|
2015-12-22 15:30:23 +00:00
|
|
|
|
|
|
|
mkdir -p shared/2configs/temp
|
|
|
|
cac generatenetworking $id > \
|
|
|
|
shared/2configs/temp/networking.nix
|
|
|
|
# new temporary ssh key we will use to log in after infest
|
|
|
|
ssh-keygen -f $krebs_ssh -N ""
|
|
|
|
cp $retiolum_key $krebs_secrets/retiolum.rsa_key.priv
|
|
|
|
# we override the directories for secrets and stockholm
|
|
|
|
# additionally we set the ssh key we generated
|
|
|
|
ip=$(cac getserver $id | jq -r .ip)
|
|
|
|
|
|
|
|
cat > shared/2configs/temp/dirs.nix <<EOF
|
|
|
|
_: {
|
|
|
|
krebs.build.source.dir = {
|
|
|
|
secrets.path = "$krebs_secrets";
|
|
|
|
stockholm.path = "$(pwd)";
|
|
|
|
};
|
|
|
|
users.extraUsers.root.openssh.authorizedKeys.keys = [
|
|
|
|
"$(cat ${krebs_ssh}.pub)"
|
|
|
|
];
|
|
|
|
krebs.build.target = "$ip";
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
LOGNAME=shared make eval get=krebs.infest \
|
|
|
|
target=derp system=test-centos7 filter=json \
|
|
|
|
| sed -e "s#^ssh.*<<#cac ssh $id<<#" \
|
|
|
|
-e "/^rsync/a -e 'cac ssh $id' \\\\" \
|
|
|
|
-e "s#root.derp:#:#" > $krebs_secrets/infest
|
|
|
|
sh -x $krebs_secrets/infest
|
|
|
|
|
|
|
|
# TODO: generate secrets directory $krebs_secrets for nix import
|
|
|
|
cac powerop $id reset
|
|
|
|
|
|
|
|
wait_login(){
|
|
|
|
# timeout
|
2015-12-24 01:20:24 +00:00
|
|
|
for t in `seq 90`;do
|
2015-12-22 15:30:23 +00:00
|
|
|
# now we have a working cac server
|
|
|
|
if ssh -o StrictHostKeyChecking=no \
|
|
|
|
-o UserKnownHostsFile=/dev/null \
|
|
|
|
-i $krebs_ssh \
|
|
|
|
-o ConnectTimeout=10 \
|
|
|
|
-o BatchMode=yes \
|
|
|
|
root@$1 nixos-version ;then
|
|
|
|
return 0
|
|
|
|
fi
|
|
|
|
sleep 10
|
|
|
|
done
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
wait_login $ip
|