Mercurial > hg > beaglert
diff scripts/setup-ssh.sh @ 73:6bfd95cb5744
Added setup-ssh scripts, borrowed from digital-foley
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Fri, 17 Jul 2015 20:18:22 +0100 |
parents | |
children | f03d68f18d7f |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/scripts/setup-ssh.sh Fri Jul 17 20:18:22 2015 +0100 @@ -0,0 +1,87 @@ +#!/bin/bash +IP_ADDRESS="192.168.7.2" +PRIVATE_KEY_FILENAME=$HOME/.ssh/id_rsa #if you change this to something like bbb_rsa it will be safer when cleaning but if you don't have the config file you will have to + # ssh -i $HOME/.ssh/bbb_rsa root@192.168.7.2 + # in order to log in +CONFIG_FILENAME=$HOME/.ssh/config +CLEAN=0 +if [ $# -gt 0 ]; then + while (( "$#" )); do + if [ $1 = "-k" ]; then + if [[ $2 == "/"* ]]; then + #it's full path + PRIVATE_KEY_FILENAME=$2 + else + #assume it's a key in .ssh + PRIVATE_KEY_FILENAME=$HOME'/.ssh/'$2 + fi + shift + shift + continue + fi + if [ $1 = "-i" ]; then + IP_ADDRESS=$2 + shift + shift + continue + fi + if [ $1 = "clean" ] ; then + CLEAN=1 + shift + continue + fi + #if we get here, then a wrong number or type of parameters have been passed + echo "Generates a key pair (if does not exist) and copies it over to the host, saving the settings in the /.ssh/config file + Usage: + -i [ipAddress] sets the host to authenticate to (default: 192.168.7.1) + -k [filename] sets the key file to use for autentication + (default: ~/.ssh/id_rsa)" + exit 1; + done; +fi + +if [ $CLEAN -eq 1 ] ; then + printf "Cleaning ${PRIVATE_KEY_FILENAME}, ${PRIVATE_KEY_FILENAME}.pub, ${CONFIG_FILENAME} and bbb:~/.ssh/ . Are you sure? This might prevent you from accessing other services that use the same key or config files (y/n) " + read sure + if [ $sure = "y" ] ; then + ssh root@192.168.7.2 rm -rf .ssh &&\ + rm $PRIVATE_KEY_FILENAME ${PRIVATE_KEY_FILENAME}.pub $CONFIG_FILENAME + if [ $? -ne 0 ] ; then + printf "ERROR: error while cleaning" + exit 4 + fi + printf "Cleaning succesful" + exit 0 + fi +fi +#printf "Pinging the Beaglebone on $IP_ADDRESS\n" +#ping $IP_ADDRESS -w 1000 -c &>/dev/null 1 #returns 1 if ping is unsuccesful +#if [ $? -ne 0 ] ; then # $? is the return value of the last command +# echo "Error: the Beaglebone is not alive, make sure it is connected and drivers are installed (MacOs and Windows only) or try again later" ; +# exit 1 +#fi; +#printf "...done\n" + +mkdir -p $HOME/.ssh # create the ssh folder if it does not exist +printf '\nHost bbb\nHostname '$IP_ADDRESS'\nUser root\nIdentityFile '$PRIVATE_KEY_FILENAME'\n' >> $HOME/.ssh/config + +printf "Generating key $PRIVATE_KEY_FILENAME if it does not exist" +ls $PRIVATE_KEY_FILENAME &>/dev/null || ssh-keygen -t rsa -f $PRIVATE_KEY_FILENAME -q -P "" # the command after || will be executed only if the previous command fails (i.e. if id_rsa does not exist) +if [ $? -ne 0 ] ; then + printf "\nERROR: an error occurred while creating key pair $PRIVATE_KEY_FILENAME\n" + exit 2 +fi +printf "...Done\n" + +printf "Type 'a' (without quotes) when prompted for a password: \n" + +# StrictHostKeyChecking=no below will prevent the following message upon the first connection: +# "The authenticity of host '192.168.1.2' can't be established." +# which would require the user to type 'yes' +cat ${PRIVATE_KEY_FILENAME}.pub | (ssh -q -o StrictHostKeyChecking=no bbb 'mkdir -p .ssh; cat > .ssh/authorized_keys') +if [ $? -ne 0 ] ; then + printf "ERROR: An error occurred while copying the public key to the BBB\n" + exit 3 +fi +printf "SSH setup complete. You can now ssh into the beaglebone with command: ssh bbb\n" +exit 0