mirror of
https://github.com/YunoHost/package_check.git
synced 2024-09-03 20:06:20 +02:00
84 lines
3.1 KiB
Bash
Executable file
84 lines
3.1 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
ARG_SSH="-t"
|
|
PLAGE_IP=$(cat "$script_dir/sub_scripts/lxc_build.sh" | grep PLAGE_IP= | cut -d '"' -f2)
|
|
|
|
echo -e "Chargement des fonctions de lxc_launcher.sh"
|
|
|
|
LXC_INIT () {
|
|
# Activation du bridge réseau
|
|
echo "Initialisation du réseau pour le conteneur."
|
|
sudo ifup lxc-pchecker --interfaces=/etc/network/interfaces.d/lxc-pchecker | tee -a "$RESULT" 2>&1
|
|
|
|
# Activation des règles iptables
|
|
sudo iptables -A FORWARD -i lxc-pchecker -o eth0 -j ACCEPT | tee -a "$RESULT" 2>&1
|
|
sudo iptables -A FORWARD -i eth0 -o lxc-pchecker -j ACCEPT | tee -a "$RESULT" 2>&1
|
|
sudo iptables -t nat -A POSTROUTING -s $PLAGE_IP.0/24 -j MASQUERADE | tee -a "$RESULT" 2>&1
|
|
|
|
if [ "$no_lxc" -eq 0 ]; then
|
|
YUNOHOST_LOG=/var/lib/lxc/$LXC_NAME/rootfs$YUNOHOST_LOG #Prend le log de la machine lxc plutôt que celui de l'hôte
|
|
fi
|
|
}
|
|
|
|
LXC_START () {
|
|
if [ "$no_lxc" -eq 0 ]
|
|
then
|
|
# Démarrage de la machine
|
|
sudo lxc-start -n $LXC_NAME -d | tee -a "$RESULT" 2>&1
|
|
for i in `seq 1 10`
|
|
do # Vérifie que la machine est accessible en ssh avant de commencer. Il lui faut le temps de démarrer.
|
|
echo -n .
|
|
if ssh $ARG_SSH $LXC_NAME "exit 0" > /dev/null 2>&1; then
|
|
break
|
|
fi
|
|
sleep 1
|
|
done
|
|
sudo lxc-ls -f | grep $LXC_NAME | sed 's/- NO//'
|
|
if [ $(sudo lxc-info --name $LXC_NAME | grep -c "STOPPED") -ne 0 ]; then
|
|
ECHO_FORMAT "Le conteneur n'a pas démarré correctement...\n" "lred" "bold"
|
|
return 1
|
|
fi
|
|
scp -rq "$APP_CHECK" "$LXC_NAME": >> "$RESULT" 2>&1
|
|
ssh $ARG_SSH $LXC_NAME "$1 > /dev/null 2>> debug_output.log; exit \$?" >> "$RESULT" 2>&1 # Exécute la commande dans la machine LXC
|
|
sudo cat "/var/lib/lxc/$LXC_NAME/rootfs/home/pchecker/debug_output.log" >> "$OUTPUTD" # Récupère le contenu du OUTPUTD distant pour le réinjecter dans le local
|
|
return "$?"
|
|
else # Sinon exécute la commande directement.
|
|
eval "$1" > /dev/null 2>> "$OUTPUTD"
|
|
fi
|
|
}
|
|
|
|
LXC_STOP () {
|
|
if [ "$no_lxc" -eq 0 ]
|
|
then
|
|
# Arrêt de la machine virtualisée
|
|
if [ $(sudo lxc-info --name $LXC_NAME | grep -c "STOPPED") -eq 0 ]; then
|
|
echo "Arrêt du conteneur LXC" | tee -a "$RESULT"
|
|
sudo lxc-stop -n $LXC_NAME | tee -a "$RESULT" 2>&1
|
|
fi
|
|
# Restaure le snapshot.
|
|
echo "Restauration du snapshot de la machine lxc" | tee -a "$RESULT"
|
|
sudo rsync -aEAX --delete -i /var/lib/lxcsnaps/$LXC_NAME/snap0/rootfs/ /var/lib/lxc/$LXC_NAME/rootfs/ > /dev/null 2>> "$RESULT"
|
|
fi
|
|
}
|
|
|
|
LXC_TURNOFF () {
|
|
echo "Arrêt du réseau pour le conteneur."
|
|
# Suppression des règles de parefeu
|
|
if sudo iptables -C FORWARD -i lxc-pchecker -o eth0 -j ACCEPT 2> /dev/null
|
|
then
|
|
sudo iptables -D FORWARD -i lxc-pchecker -o eth0 -j ACCEPT >> "$RESULT" 2>&1
|
|
fi
|
|
if sudo iptables -C FORWARD -i eth0 -o lxc-pchecker -j ACCEPT 2> /dev/null
|
|
then
|
|
sudo iptables -D FORWARD -i eth0 -o lxc-pchecker -j ACCEPT | tee -a "$RESULT" 2>&1
|
|
fi
|
|
if sudo iptables -t nat -C POSTROUTING -s $PLAGE_IP.0/24 -j MASQUERADE 2> /dev/null
|
|
then
|
|
sudo iptables -t nat -D POSTROUTING -s $PLAGE_IP.0/24 -j MASQUERADE | tee -a "$RESULT" 2>&1
|
|
fi
|
|
# Et arrêt du bridge
|
|
if sudo ifquery lxc-pchecker --state > /dev/null
|
|
then
|
|
sudo ifdown --force lxc-pchecker | tee -a "$RESULT" 2>&1
|
|
fi
|
|
}
|