Criei uma função para registrar os resultados de um script e adicionei um argumento ao script. Você pode vê-lo em https://docs.laswitchtech.com/doku.php?id=documentations:linux:pxelinux
Neste script, adicionei um argumento --screen
para iniciar o mesmo script com todos os argumentos em uma tela com o -L
switch.
Enable_Screen(){
Check_Package screen
ScreenCMD="./pxelinux.sh"
CMDOptions="$@"
CMDOptions=${CMDOptions// --screen/}
CMD="$ScreenCMD $CMDOptions"
if [ $debug = "true" ]; then
echo -e "${ORANGE}[DEBUG][EXECUTE] screen -S PXE_Linux -L $CMD ${NORM}"
fi
screen -S PXE_Linux -L $CMD
mv screenlog.0 pxelinux.screen.log
exit 0
}
Agora eu gostaria de adicionar uma opção ao argumento para anexar o log.
um exemplo de como executo o script:
./pxelinux.sh --debug --screen --install-pxelinux
Agora este é o exemplo que eu gostaria de usar
./pxelinux.sh --debug --screen append --install-pxelinux
Como esta é uma opção da função tela, não quero que ela seja encaminhada para a tela que estou criando. Na função screen, você pode ver que removi o --screen
da lista de argumentos e agora precisaria remover append
também caso apareça nos argumentos. Mas só se estiver nas opções do --screen
argumento. Porque append
é uma opção para o argumento --screen
e pode ou não estar habilitado.
Basicamente, usei esta convenção para meus argumentos:
--argument
=> executar uma função no script
argument
=> opção para o indicado anteriormente--argument
Simplificando:
script.sh
#!/bin/bash
Config_Network(){
echo -e "
source /etc/network/interfaces.d/*
# The loopback network interface
auto lo
iface lo inet loopback
# The primary network interface
allow-hotplug eth0
auto eth0
iface eth0 inet static
address $1
netmask $2
gateway $3
" | tee -a /etc/network/interfaces
}
Update_System(){
Command="apt-get update"; Executing "$Command"
Command="apt-get upgrade -y"; Executing "$Command"
}
Restart_System(){
shutdown -r now
}
Check_Package(){
if [ $(dpkg-query -W -f='${Status}' $1 2>/dev/null | grep -c "ok installed") -eq 0 ];
then
Command="apt-get install $1 -y"; Executing "$Command"
fi
}
Executing(){
if [ $debug = "true" ]; then
if eval $1;then
echo -e "${GREEN}[DEBUG ][$(date)][SUCCESS][EXECUTING] $1 ${NORM}" | tee -a $logfile
else
echo -e "${RED}[DEBUG ][$(date)][ERROR ][EXECUTING] $1 ${NORM}" | tee -a $logfile
fi
else
if eval $1;then
echo -e "${GREEN}[DEBUG ][$(date)][SUCCESS][EXECUTING] $1 ${NORM}"
else
echo -e "${RED}[DEBUG ][$(date)][ERROR ][EXECUTING] $1 ${NORM}"
fi
fi
}
while test $# -gt 0
do
case "$1" in
--config-network)
netconf
;;
--update)
Update_System
;;
--restart)
Restart_System
;;
--*)
exit
;;
esac
shift
done
exit 0
agora, quando executo o script.sh, quero poder passar $ 1 $ 2 $ 3 para a função netconf, não importa onde esteja na instrução.
./script.sh --config-network 10.10.10.10 255.255.255.0 10.10.10.1 --update --restart
./script.sh --restart --config-network 10.10.10.10 255.255.255.0 10.10.10.1 --update
./script.sh --update --restart --config-network 10.10.10.10 255.255.255.0 10.10.10.1 --update
Encontrei uma solução para o meu problema testando os 3 argumentos a seguir, se eles estivessem contidos
--
neles. E como neste caso eu estava procurando por IPs e máscara, adicionei um segundo teste para isso. Então o primeiroif
valida que os seguintes argumentos não são funções do script e depois o segundoif
valida os argumentos que quero passar para a função.