blob: e62e5dd73028e68bf121b457996fc7209261cf91 [file] [log] [blame]
Thomas Vachuska12bf4452015-06-26 09:15:38 -07001#!/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
Thomas Vachuska35349332016-04-04 14:06:46 -07009# Scan arguments for user/password or other options...
10while getopts u:p: o; do
11 case "$o" in
12 u) user=$OPTARG;;
13 p) password=$OPTARG;;
14 esac
15done
16password=${password:-$user} # password defaults to the user if not specified
17let OPC=$OPTIND-1
18shift $OPC
19
Thomas Vachuskacf7ce3b2018-08-20 09:34:08 -070020user=${user:-$ONOS_WEB_USER}
21password=${password:-$ONOS_WEB_PASS}
Claudine Chiu45312d02016-06-15 13:17:12 +000022nodes=${1:-$(env | sort | egrep "^OC[0-9]+" | cut -d= -f2)}
Thomas Vachuska12bf4452015-06-26 09:15:38 -070023
Yuta HIGUCHI04107122017-01-13 18:51:12 -080024# ensure known_hosts file exist
25(umask 077; touch "$HOME/.ssh/known_hosts")
Ray Milkeyd84f89b2018-08-17 14:54:17 -070026set -x
Thomas Vachuska12bf4452015-06-26 09:15:38 -070027for node in $nodes; do
Thomas Vachuska12bf4452015-06-26 09:15:38 -070028 # Setup passwordless login for the local user on the remote node
29 ssh $ONOS_USER@$node "
Ray Milkeyd84f89b2018-08-17 14:54:17 -070030 set -x
Thomas Vachuska12bf4452015-06-26 09:15:38 -070031 [ ! -f ~/.ssh/id_rsa.pub ] && ssh-keygen -t rsa -f ~/.ssh/id_rsa -P '' -q
32 $ONOS_INSTALL_DIR/bin/onos-user-key \$(id -un) \$(cut -d\\ -f2 ~/.ssh/id_rsa.pub)
Thomas Vachuska5af2e4f2016-12-16 12:07:33 -080033 $ONOS_INSTALL_DIR/bin/onos-user-password $user $password
Thomas Vachuska12bf4452015-06-26 09:15:38 -070034
35 # Implicitly accept the new server key in dev/test environments
36 while ! ssh -p 8101 -o StrictHostKeyChecking=no localhost list 2>/dev/null; do
37 echo Waiting for connection...
38 sleep 1
39 done
40 "
Charles Chan2497dbe2015-10-14 17:08:56 -070041
42 # Setup passwordless login for the remote user on the local bench host
43 # For now, we let the local public key override the remote one
44 # TODO: fix username collision between workbench and the remote hosts
45 onos-user-key $node
Thomas Vachuska12bf4452015-06-26 09:15:38 -070046done