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
|
|
|
|
|
|
|
LIBDIR="$(dirname $0)" && . "${LIBDIR}/config"
|
|
|
|
|
|
|
|
jail="${1:-}"
|
2019-01-07 14:47:05 +01:00
|
|
|
if [ ! -n "${jail}" ]; then
|
|
|
|
"${LIBDIR}/bkctld-help" && exit 1
|
|
|
|
fi
|
2019-01-04 13:51:05 +01:00
|
|
|
check_jail "${jail}" || error "${jail} : trying to sync inexistant jail"
|
|
|
|
|
|
|
|
[ -n "${NODE}" ] || error "Sync need config of \$NODE in /etc/default/bkctld !"
|
|
|
|
|
|
|
|
jail="${1}"
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-init" "${jail}" | debug
|
|
|
|
rsync -a "${JAILDIR}/${jail}/" "${NODE}:${JAILDIR}/${jail}/" --exclude proc/* --exclude sys/* --exclude dev/* --exclude run --exclude var/backup/*
|
|
|
|
rsync -a "${CONFDIR}/${jail}" "${NODE}:${CONFDIR}/${jail}"
|
|
|
|
if ( check_jail_on "${jail}" ); then
|
|
|
|
ssh "${NODE}" "${LIBDIR}/bkctld-start" "${jail}" | debug
|
|
|
|
fi
|
|
|
|
if [ -n "${FIREWALL_RULES}" ]; then
|
|
|
|
rsync -a "${FIREWALL_RULES}" "${NODE}:${FIREWALL_RULES}"
|
|
|
|
ssh "${NODE}" /etc/init.d/minifirewall restart | debug
|
|
|
|
fi
|