VMM_remote-control/vm_control.sh

149 lines
5.8 KiB
Bash

#!/bin/bash
# ./vm_control.sh [start|stop]
# DIESES SKRIPT KOMMT IN EIN PRIVATES VERZEICHNIS
# VMM verlangt root-Rechte, weshalb dieses Skript von root aufgerufen werden muss.
vm_control_php_path="/volume1/web/vm_control.php" # der Pfad im Web-Verzeichnis von vm_control.php
################################################################################
# ab hier nichts mehr ändern
# ------------------------------------------------------------------------------
vm_state_path="$(dirname "$vm_control_php_path")/vm_state.php"
if [ ! $(which inotifywait) ]; then
echo "inotify-tools nicht installiert"
exit 1
elif [ $(whoami) != "root" ]; then
echo "ERROR: du bist nicht root!"
exit 1
fi
inotify_start() {
PROZESSID=$(ps aux | grep -v "grep" | grep -E "inotifywait.*vm_state.php" | awk -F' ' '{print $2}')
echo "..."
if [[ -z $PROZESSID ]];then
echo "Überwachung von ${vm_state_path} wird gestartet"
# initial Web-Status auslesen:
web_state=$(cat "$vm_state_path" | grep "=>" "$vm_state_path" | grep -v "LOG:")
declare -A vm_states
while read line ; do
vm=$(awk -F\' '{print $2}' <<<"$line")
vms+=( "$vm" )
vm_states[$vm]=$(echo "$line" | grep "$vm" | awk -F\' '{print $4}')
done <<<"$web_state"
inotifywait "${vm_state_path}" --monitor --event close_write --timeout -1 --format %e |
while read line ; do
unset vm_states_saved
declare -A vm_states_saved
# associative array umschreiben / umbenennen:
for key in "${!vm_states[@]}"; do # make sure you include the quotes there
vm_states_saved+=( ["$key"]="${vm_states["$key"]}" )
# or:
# vm_states_saved["$key"]="${vm_states["$key"]}"
done
unset vm_states
unset vms
# neu einlesen:
web_state=$(cat "$vm_state_path" | grep "=>" "$vm_state_path" | grep -v "LOG:")
declare -A vm_states
while read line ; do
vm=$(awk -F\' '{print $2}' <<<"$line")
vms+=( "$vm" )
vm_states[$vm]=$(echo "$line" | grep "$vm" | awk -F\' '{print $4}')
printf "%-25s %s\n" "Name: $vm" "Status: $(echo "$line" | grep "$vm" | awk -F\' '{print $4}')"
done <<<"$web_state"
echo "-----------------------------------------"
echo "MODIFIKATION ERKANNT ..."
echo "online Status:"
for i in "${!vm_states[@]}" ; do
printf "%-25s ➜ %s\n" "$i" "${vm_states[$i]}"
done
echo -e
echo "gespeicherte Status:"
for i in "${!vm_states_saved[@]}" ; do
printf "%-25s ➜ %s\n" "$i" "${vm_states_saved[$i]}"
done
echo "-----------------------------------------"
# Änderungen filtern / Aktion ausführen:
for vm in "${vms[@]}"; do
vm_host_status=$(synowebapi --exec api=SYNO.Virtualization.API.Guest version=1 method=get runner=admin guest_name="$vm" 2>/dev/null | jq -r .data.status )
if [ "${vm_states[$vm]}" = "${vm_states_saved[$vm]}" ]; then
echo "keine Änderung für $vm (web_state online: $(echo "${vm_states[$vm]}" | awk -F_ '{print $1}') / web_state saved: $(echo "${vm_states_saved[$vm]}" | awk -F_ '{print $1}'))"
continue
fi
# wenn Änderung gefunden wurde:
echo "Änderung für $vm (web_state online: $(echo "${vm_states[$vm]}" | awk -F_ '{print $1}') / web_state saved: $(echo "${vm_states_saved[$vm]}" | awk -F_ '{print $1}'))"
case $(echo "${vm_states[$vm]}" | awk -F_ '{print $1}') in
on)
if [ "$vm_host_status" = "shutdown" ]; then
echo "starte $vm ..."
synowebapi --exec api=SYNO.Virtualization.API.Guest.Action version=1 method=poweron runner=admin guest_name="$vm" > /dev/null 2>&1
else
echo "VM $vm hat folgenden Status und kann nicht gestartet werden: $vm_host_status"
fi
;;
off)
if [ "$vm_host_status" = "running" ]; then
echo "beende $vm ..."
synowebapi --exec api=SYNO.Virtualization.API.Guest.Action version=1 method=shutdown runner=admin guest_name="$vm" > /dev/null 2>&1
else
echo "VM $vm hat folgenden Status und kann nicht beendet werden: $vm_host_status"
fi
;;
esac
done
done &
else
echo "läuft bereits …"
fi
}
inotify_stop()
{
# Überwachung stoppem:
# --------------------------------------------------------------
PROZESSID=$(ps aux | grep -v "grep" | grep -E "inotifywait.*vm_state.php" | awk -F' ' '{print $2}')
if [[ ! -z $PROZESSID ]];then
kill $PROZESSID
if [ $? = 0 ]; then
echo "Überwachung beendet"
exit 0
else
echo "FEHLER beim Beenden der Überwachung!"
exit 1
fi
else
echo "läuft nicht … "
fi
}
# start-stop-Überwachung:
case "$1" in
start)
inotify_start
echo "läuft … "
exit 0
;;
stop)
inotify_stop
exit 0
;;
esac
exit 0