Você pode remover a solicitação de "senha" assim. No PC com o arquivo (Servidor A), em um tipo de terminal:
ssh-keygen -t rsa -b 2048
Enter file in which to save the key (/<user>/.ssh/id_rsa): [Hit Enter]
Enter passphrase (empty for no passphrase): [Hit Enter]
Enter same passphrase again: [Hit Enter]
Your identification has been saved in /<user>/.ssh/id_rsa.
Your public key has been saved in /<user>/.ssh/id_rsa.pub.
Então você precisa copiar /<user>/.ssh/id_rsa.pub
para o Servidor B e C. No Servidor B e C, faça o seguinte. NOTA: O mkdir -p ~/.ssh
pode não ser necessário.
mkdir -p ~/.ssh
cat id_rsa.pub >> ~/.ssh/authorized_keys
rm id_rsa.pub
Agora você pode se conectar do Servidor A ao B e C sem uma senha. Por exemplo, seu script agora seria tão simples quanto (com uma verificação de arquivo básica):
#!/bin/sh
ask () {
echo -n "Enter Package Name: "
read package
if [ ! -f "$package" ]
then
echo "
${package} is not a file. Try again.
"
ask
else
upload "$package"
fi
}
upload () {
echo "put \"$1\" \"/tmp/$1\" > sftp.cmd
sftp User@serverB < sftp.cmd
sftp User@serverC < sftp.cmd
rm -f sftp.cmd
}
ask
exit