deploy.pl/launch.sh

115 lines
2.9 KiB
Bash
Raw Normal View History

2020-05-26 22:54:10 +02:00
#!/bin/sh
#
# Copyright (c) 2019-2023 Mischa Peters <mischa @ openbsd.amsterdam>
2020-05-26 22:54:10 +02:00
#
# Permission to use, copy, modify, and distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#
CONF_FILE="${PWD}/_deploy.conf"
if [[ -f "${CONF_FILE}" ]]; then
. "${CONF_FILE}"
else
echo "unable to find _deploy.conf"
exit 1
fi
if [[ -z ${1} ]]; then
echo "usage: ${0##*/} vmXX"
exit 1
fi
if [[ ! -f "${VMS}/${1}.txt" ]]; then
2022-12-01 17:23:20 +01:00
echo "unable to find ${VMS}/${1}.txt"
if [[ -f "${VMS}/${1}.txt.free" ]]; then
echo "found ${VMS}/${1}.txt.free"
mv ${VMS}/${1}.txt.free ${VMS}/${1}.txt
else
exit 1
fi
else
chown mischa ${VMS}/${1}.txt
chmod 600 ${VMS}/${1}.txt
fi
INSTANCE=$(awk -F'=' '/instance/ {print $2}' ${VMS}/${1}.txt | tr -d '"')
if [[ -z ${INSTANCE} ]]; then
INSTANCE=${1}
fi
2022-12-01 17:23:20 +01:00
if [[ "${SERVER}" == server* ]]; then
HOST="s${SERVER#server}"
elif [[ "${SERVER}" == mega* ]]; then
HOST="m${SERVER#mega}"
fi
if [[ "${SERVER}" == server* ]] || [[ "${SERVER}" == mega* ]]; then
openrsync -va --del /home/mischa/vms/ mischa@wm1.obsda.ms:vms/${HOST}/
ssh wm1.obsda.ms "doas ./create-user.pl ${HOST}${1}"
openrsync -va --del /home/mischa/vms/ mischa@rx.high5.nl:vms/${HOST}/
fi
2022-12-01 17:23:20 +01:00
2020-05-26 22:54:10 +02:00
deploy.pl
sleep 10
if [[ -z ${DHCPD} ]]; then
rcctl restart dhcpd
fi
2020-05-26 22:54:10 +02:00
vmctl reload
sleep 10
mkfifo -m 600 /tmp/pipe_${1}
2022-12-03 13:43:20 +01:00
install -g mischa -m 600 -o mischa /dev/null ${LOGS}/${1}.log
echo -n "autoinstall(8) ${INSTANCE}, log output ${LOGS}/${1}.log... "
vmctl start -c ${INSTANCE} < /tmp/pipe_${1} | while read line; do
printf '%s\n' "$line" >&2
case $line in
*rebooting...*)
vmctl stop -f ${INSTANCE}
break
;;
#Response file location\?*)
#vmctl stop -f ${1}
#rm -rf /tmp/pipe_${1}
#rm -rf /var/vmm/${1}.qcow2
2022-12-01 17:23:20 +01:00
#pushover.pl -m "${SERVER} ${1} failed deploy" -t "OpenBSD Amsterdam" -p 1
#exit 1
#;;
esac
2022-12-03 13:43:20 +01:00
done > /tmp/pipe_${1} 2> ${LOGS}/${1}.log
echo "completed"
2020-05-26 22:54:10 +02:00
deploy.pl
sleep 10
if [[ -z ${DHCPD} ]]; then
rcctl restart dhcpd
fi
2020-05-26 22:54:10 +02:00
vmctl reload
sleep 10
echo "booting ${INSTANCE}"
vmctl start -c ${INSTANCE} < /tmp/pipe_${1} | while read line; do
printf '%s\n' "$line" >&2
case $line in
*tty00*)
break
;;
esac
2022-12-03 13:43:20 +01:00
done > /tmp/pipe_${1} 2>> ${LOGS}/${1}.log
rm -rf /tmp/pipe_${1}
echo
echo "SUCCES! - deployed ${INSTANCE}"
notify.pl deployed ${1}
pushover.pl -m "${SERVER} ${INSTANCE} deployed" -t "OpenBSD Amsterdam"