Thomas Vachuska | 12bf445 | 2015-06-26 09:15:38 -0700 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | # ----------------------------------------------------------------------------- |
| 3 | # Secures the ONOS console for all instances in the cell ONOS cluster. |
| 4 | # ----------------------------------------------------------------------------- |
| 5 | |
| 6 | [ ! -d "$ONOS_ROOT" ] && echo "ONOS_ROOT is not defined" >&2 && exit 1 |
| 7 | . $ONOS_ROOT/tools/build/envDefaults |
| 8 | |
| 9 | nodes=$(env | sort | egrep "OC[0-9]+" | cut -d= -f2) |
| 10 | |
| 11 | for node in $nodes; do |
Thomas Vachuska | 12bf445 | 2015-06-26 09:15:38 -0700 | [diff] [blame] | 12 | # Prune the node entry from the known hosts file since server key changes |
Brian O'Connor | c5876fd | 2015-10-29 23:07:55 -0700 | [diff] [blame] | 13 | ssh-keygen -f "$HOME/.ssh/known_hosts" -R [$node]:8101 || |
| 14 | ( echo "Failed to remove key from known_hosts" >&2 && exit 1 ) |
Thomas Vachuska | 12bf445 | 2015-06-26 09:15:38 -0700 | [diff] [blame] | 15 | |
| 16 | # Setup passwordless login for the local user on the remote node |
| 17 | ssh $ONOS_USER@$node " |
| 18 | [ ! -f ~/.ssh/id_rsa.pub ] && ssh-keygen -t rsa -f ~/.ssh/id_rsa -P '' -q |
| 19 | $ONOS_INSTALL_DIR/bin/onos-user-key \$(id -un) \$(cut -d\\ -f2 ~/.ssh/id_rsa.pub) |
Thomas Vachuska | eff0e4e | 2015-08-11 00:26:24 -0700 | [diff] [blame] | 20 | $ONOS_INSTALL_DIR/bin/onos-secure-ssh "$@" |
Thomas Vachuska | 12bf445 | 2015-06-26 09:15:38 -0700 | [diff] [blame] | 21 | |
| 22 | # Implicitly accept the new server key in dev/test environments |
| 23 | while ! ssh -p 8101 -o StrictHostKeyChecking=no localhost list 2>/dev/null; do |
| 24 | echo Waiting for connection... |
| 25 | sleep 1 |
| 26 | done |
| 27 | " |
Charles Chan | 2497dbe | 2015-10-14 17:08:56 -0700 | [diff] [blame] | 28 | |
| 29 | # Setup passwordless login for the remote user on the local bench host |
| 30 | # For now, we let the local public key override the remote one |
| 31 | # TODO: fix username collision between workbench and the remote hosts |
| 32 | onos-user-key $node |
Thomas Vachuska | 12bf445 | 2015-06-26 09:15:38 -0700 | [diff] [blame] | 33 | done |
| 34 | |