blob: f80de7ab862f179f7c86931b2197f4396f637fd1 [file] [log] [blame]
#!/bin/bash
# Copyright 2017 The Fuchsia Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
### start a remote interactive shell in the target device
## usage: fx shell [-h|--help] [-d|--device <device>] [<command>]
##
## Creates an SSH connection with a device and executes a command
## (if specified) on the device.
##
## Arguments:
## -h|--help Print out this message.
## -d|--device Fuchsia link-local name of the device. If not
## specified, will connect to the only available
## device on the link-local network.
source "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"/lib/vars.sh
case $1 in
-h|--help)
fx-command-help
exit 0
;;
-d|--device)
shift # name
if [[ -z "$1" ]]; then
echo "Missing parameter: <device>" >&2
fx-command-help
exit 1
fi
device="$1"
shift # value
;;
esac
# Note: I know there are people who don't like the host-key message, but DO NOT
# apply -q here, it silences error messages and makes network and configuration
# failures much harder to diagnose when helping people. The control master will
# mean you only get one per TCP socket, which is once per newly booted host.
# It's not a huge burden compared to end user support.
fx-command-exec ssh "$(fx-command-run netaddr --fuchsia "${device}")" "$@"