|  | #!/bin/bash | 
|  | # Copyright 2020 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. | 
|  |  | 
|  | #### CATEGORY=Other | 
|  | ### Remotely build, fetch and pave | 
|  |  | 
|  | ## usage: fx pave-remote HOST [DIR] [--no-pave] [--no-build] | 
|  | ##          [--no-check-ssh-keys] [-- PAVE_ARGS] | 
|  | ## | 
|  | ## Connect to HOST, run a build using fx from DIR, fetch the artifacts and | 
|  | ## start the paver. | 
|  | ## | 
|  | ##  --no-build           do not build, just pull artifacts already present | 
|  | ##  --no-pave            do not start the paver, just pull the artifacts | 
|  | ##  --no-check-ssh-keys  do not verify that the default SSH credentials are the | 
|  | ##                       same before paving. | 
|  | ##  --                   pass any arguments after the -- to the fx pave command | 
|  | ## | 
|  | ##  HOST          the hostname to connect to | 
|  | ##  DIR           defaults to ~/fuchsia, the path to the FUCHSIA_DIR on HOST | 
|  | ##  PAVE_ARGS     arguments for the fx pave command | 
|  | ## | 
|  | ## HOST and DIR are persisted in the file //.fx-remote-config and are reused as | 
|  | ## defaults in future invocations of any 'fx *-remote' tools. | 
|  |  | 
|  | set -o errexit | 
|  |  | 
|  | source "$(cd "$(dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd)"/lib/vars.sh || exit $? | 
|  | source "$(cd "$(dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd)"/lib/fx-remote.sh || exit $? | 
|  | source "$(cd "$(dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd)"/lib/verify-default-keys.sh || exit $? | 
|  | fx-config-read | 
|  |  | 
|  | build=true | 
|  | pave=true | 
|  | check_ssh_keys=true | 
|  | host="" | 
|  | dir="" | 
|  | args=() | 
|  | while [[ $# -ne 0 ]]; do | 
|  | case "$1" in | 
|  | --help|-h) | 
|  | fx-command-help | 
|  | exit 0 | 
|  | ;; | 
|  | --no-build) | 
|  | build=false | 
|  | ;; | 
|  | --no-pave) | 
|  | pave=false | 
|  | ;; | 
|  | --no-check-ssh-keys) | 
|  | check_ssh_keys=false | 
|  | ;; | 
|  | --) | 
|  | shift | 
|  | args+=("$@") | 
|  | break | 
|  | ;; | 
|  | -*) | 
|  | fx-error "Unknown flag: $1" | 
|  | fx-command-help | 
|  | exit 1 | 
|  | ;; | 
|  | *) | 
|  | if [[ -z "${host}" ]]; then | 
|  | host="$1" | 
|  | elif [[ -z "${dir}" ]]; then | 
|  | dir="$1" | 
|  | else | 
|  | fx-error "unexpected argument: '$1'" | 
|  | exit 1 | 
|  | fi | 
|  | ;; | 
|  | esac | 
|  | shift | 
|  | done | 
|  |  | 
|  | if cached=( $(load_remote_info "$host") ); then | 
|  | host="${cached[0]}" | 
|  | dir="${cached[1]}" | 
|  | fi | 
|  |  | 
|  | if [[ -z "${host}" ]]; then | 
|  | fx-error "HOST must be specified" | 
|  | fx-command-help | 
|  | exit 1 | 
|  | fi | 
|  |  | 
|  | if [[ -z "${dir}" ]]; then | 
|  | if ssh "$host" ls \~/fuchsia/.jiri_root/bin/fx > /dev/null; then | 
|  | dir="~/fuchsia" | 
|  | else | 
|  | fx-error "failed to find ~/fuchsia on $host, please specify DIR" | 
|  | fx-command-help | 
|  | exit 1 | 
|  | fi | 
|  | fi | 
|  |  | 
|  | # Verify that keys match. | 
|  | if "${check_ssh_keys}"; then | 
|  | verify_default_keys "${FUCHSIA_DIR}" "${host}" "${dir}" || exit $? | 
|  | fi | 
|  |  | 
|  | save_remote_info "$host" "$dir" | 
|  |  | 
|  | authkeys_path="$(get-ssh-authkeys)" || { | 
|  | fx-error "Cannot continue without a valid authorized keys file." | 
|  | exit 1 | 
|  | } | 
|  |  | 
|  | artifact_dir="${FUCHSIA_DIR}/out/fetched" | 
|  | fetch_remote_build_artifacts "${host}" "${dir}" "${artifact_dir}" pave $build | 
|  |  | 
|  | if "${pave}"; then | 
|  | if [[ -n "$(get-device-name)" ]]; then | 
|  | args+=(-n $(get-device-name)) | 
|  | fi | 
|  |  | 
|  | fetch_or_build_tool "${host}" "${dir}" "${artifact_dir}" bootserver | 
|  | cd "${artifact_dir}" | 
|  | ./pave.sh --authorized-keys "${authkeys_path}" "${args[@]}" | 
|  | fi |