2019-01-04 13:51:05 +01:00
|
|
|
#!/bin/sh
|
2019-01-07 14:47:05 +01:00
|
|
|
#
|
|
|
|
# Sync jail <jailname> or all to another node
|
|
|
|
# Usage: sync <jailname>|all
|
|
|
|
#
|
2019-01-04 13:51:05 +01:00
|
|
|
|
2020-04-02 13:44:13 +02:00
|
|
|
# shellcheck source=./includes
|
2020-04-02 00:31:57 +02:00
|
|
|
LIBDIR="$(dirname $0)" && . "${LIBDIR}/includes"
|
2019-01-04 13:51:05 +01:00
|
|
|
|
2020-04-02 13:44:13 +02:00
|
|
|
jail_name="${1:?}"
|
2020-04-02 01:07:12 +02:00
|
|
|
if [ -z "${jail_name}" ]; then
|
2019-01-07 14:47:05 +01:00
|
|
|
"${LIBDIR}/bkctld-help" && exit 1
|
|
|
|
fi
|
2020-04-02 01:07:12 +02:00
|
|
|
jail_path=$(jail_path "${jail_name}")
|
2020-04-02 18:40:27 +02:00
|
|
|
jail_config_dir=$(jail_config_dir "${jail_name}")
|
2020-04-02 01:07:12 +02:00
|
|
|
|
2020-05-01 09:51:09 +02:00
|
|
|
test -d "${jail_path}" || error "${jail_name}: jail not found" 2
|
2019-01-04 13:51:05 +01:00
|
|
|
|
|
|
|
[ -n "${NODE}" ] || error "Sync need config of \$NODE in /etc/default/bkctld !"
|
|
|
|
|
2020-05-01 10:31:20 +02:00
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-is-on ${jail_name} 2>/dev/null"
|
|
|
|
# return code 2 is for "missing jail" error
|
|
|
|
if [ "$?" -eq 2 ]; then
|
|
|
|
# Init jail on remote server
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-init ${jail_name}" | debug
|
|
|
|
fi
|
2020-04-02 18:40:27 +02:00
|
|
|
|
2020-05-03 11:03:04 +02:00
|
|
|
# Sync jail structure and configuration on remote server
|
2020-04-02 01:07:12 +02:00
|
|
|
rsync -a "${jail_path}/" "${NODE}:${jail_path}/" --exclude proc/* --exclude sys/* --exclude dev/* --exclude run --exclude var/backup/*
|
2020-05-03 11:03:04 +02:00
|
|
|
# Sync config (new structure)
|
|
|
|
if [ -d "${jail_config_dir}" ]; then
|
2020-05-28 10:22:34 +02:00
|
|
|
rsync -a --delete "${jail_config_dir}/" "${NODE}:${jail_config_dir}/"
|
2020-04-02 18:40:27 +02:00
|
|
|
else
|
2020-05-03 11:03:04 +02:00
|
|
|
ssh "${NODE}" "rm -rf ${jail_config_dir}" | debug
|
|
|
|
fi
|
|
|
|
# Sync config (legacy structure)
|
|
|
|
if [ -e "${CONFDIR}/${jail_name}" ]; then
|
|
|
|
rsync -a "${CONFDIR}/${jail_name}" "${NODE}:${CONFDIR}/${jail_name}"
|
|
|
|
else
|
|
|
|
ssh "${NODE}" "rm -f ${CONFDIR}/${jail_name}" | debug
|
2020-04-02 18:40:27 +02:00
|
|
|
fi
|
2020-04-02 01:07:12 +02:00
|
|
|
|
2019-01-04 13:51:05 +01:00
|
|
|
if [ -n "${FIREWALL_RULES}" ]; then
|
2020-05-01 10:33:06 +02:00
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-firewall ${jail_name}" | debug
|
2020-05-03 11:03:04 +02:00
|
|
|
ssh "${NODE}" "test -x /etc/init.d/minifirewall && /etc/init.d/minifirewall restart" | debug
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Sync state on remote server
|
|
|
|
if "${LIBDIR}/bkctld-is-on" "${jail_name}"; then
|
|
|
|
# fetch state of remote jail
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-is-on ${jail_name} 2>/dev/null"
|
|
|
|
case "$?" in
|
|
|
|
0)
|
|
|
|
# jail is already running : reload it
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-reload ${jail_name}" | debug
|
|
|
|
;;
|
|
|
|
100)
|
|
|
|
# jail is stopped : start it
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-start ${jail_name}" | debug
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
error "Error evaluating jail \`${jail_name}' state. bkctld-is-on exited with \`$?'"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
else
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-stop ${jail_name}" | debug
|
2019-01-04 13:51:05 +01:00
|
|
|
fi
|