| #!/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}")" "$@" |