| Index: bin/cros_copy_upgrade_server.sh
|
| diff --git a/bin/cros_copy_upgrade_server.sh b/bin/cros_copy_upgrade_server.sh
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..5b375c88d264549a87ad7aa95c802ce4df6d2547
|
| --- /dev/null
|
| +++ b/bin/cros_copy_upgrade_server.sh
|
| @@ -0,0 +1,195 @@
|
| +#!/bin/sh
|
| +
|
| +# Load common constants. This should be the first executable line.
|
| +# The path to common.sh should be relative to your script's location.
|
| +. "$(dirname "$0")/common.sh"
|
| +
|
| +# Flags
|
| +DEFINE_string upgrade_server "" "SSH-capable host for upgrade server install"
|
| +DEFINE_string dest_path "" "Directory on host to do install"
|
| +DEFINE_string client_address "" "IP Address of netbook to update"
|
| +DEFINE_string server_address "" "IP Address of upgrade server"
|
| +DEFINE_boolean start_server ${FLAGS_TRUE} "Start up the server"
|
| +DEFINE_boolean stop_server ${FLAGS_FALSE} "Start up the server"
|
| +DEFINE_string from "" "Image directory to upload to server"
|
| +
|
| +# Parse command line
|
| +FLAGS "$@" || exit 1
|
| +eval set -- "${FLAGS_ARGV}"
|
| +
|
| +set -e
|
| +
|
| +# Make sure dev server argument has been set
|
| +require_upgrade_server () {
|
| + if [ -z "${FLAGS_upgrade_server}" ] ; then
|
| + echo "The --upgrade-server= argument is mandatory"
|
| + exit 1
|
| + fi
|
| +}
|
| +
|
| +# Make sure a pointer to the latest image has been created
|
| +require_latest_image () {
|
| + [ -n "$latest_image" ] && return
|
| + if [ -n "${FLAGS_from}" ] ; then
|
| + latest_image=$(readlink -f ${FLAGS_from})
|
| + else
|
| + latest_image=$(env CHROMEOS_BUILD_ROOT=${SCRIPTS_DIR}/../build \
|
| + ${SCRIPTS_DIR}/get_latest_image.sh)
|
| + fi
|
| +}
|
| +
|
| +validate_devserver_path () {
|
| + if [ $(expr "${FLAGS_dest_path}" : '\.\.') != 0 ]; then
|
| + echo "Error: --dest_path argument (${FLAGS_dest_path}) must not be relative"
|
| + exit 1
|
| + fi
|
| + FLAGS_dest_path=/tmp/devserver/${FLAGS_dest_path##/tmp/devserver/}
|
| +}
|
| +
|
| +# Copy the various bits of the dev server scripts over to our remote host
|
| +create_devserver () {
|
| + FLAGS_dest_path=$1
|
| + validate_devserver_path
|
| +
|
| + echo "Creating dev server in ${FLAGS_upgrade_server}:${FLAGS_dest_path}..."
|
| +
|
| + require_upgrade_server
|
| + # Create new empty directory to hold server components
|
| + ssh "${FLAGS_upgrade_server}" rm -rf "${FLAGS_dest_path}" || true
|
| + ssh "${FLAGS_upgrade_server}" mkdir -p "${FLAGS_dest_path}/python"
|
| +
|
| + # Copy server components into place
|
| + (cd ${SCRIPTS_DIR}/../.. && \
|
| + tar zcf - --exclude=.git --exclude=.svn \
|
| + src/scripts/start_devserver \
|
| + src/scripts/{common,get_latest_image,mk_memento_images}.sh \
|
| + src/third_party/shflags src/platform/dev) | \
|
| + ssh ${FLAGS_upgrade_server} "cd ${FLAGS_dest_path} && tar zxf -"
|
| +
|
| + # Copy Python web library into place out of the chroot
|
| + (cd ${SCRIPTS_DIR}/../../chroot/usr/lib/python*/site-packages && \
|
| + tar zcf - web*) | \
|
| + ssh ${FLAGS_upgrade_server} "cd ${FLAGS_dest_path}/python && tar zxf -"
|
| +}
|
| +
|
| +# Copy the latest image over to archive server
|
| +create_archive_dir () {
|
| + archive_dir=$1
|
| +
|
| + echo "Creating archive dir in ${FLAGS_upgrade_server}:${archive_dir}..."
|
| +
|
| + require_upgrade_server
|
| + require_latest_image
|
| +
|
| + # Copy the latest image into the newly created archive
|
| + ssh "${FLAGS_upgrade_server}" "mkdir -p ${archive_dir}"
|
| +
|
| + image_path=${latest_image##*build/}
|
| +
|
| + (cd ${SCRIPTS_DIR}/../build && tar zcf - ${image_path}) | \
|
| + ssh ${FLAGS_upgrade_server} "cd ${archive_dir} && tar zxf -"
|
| +
|
| + # unpack_partitions.sh lies in its hashbang. It really wants bash
|
| + unpack_script=${archive_dir}/${image_path}/unpack_partitions.sh
|
| + ssh ${FLAGS_upgrade_server} "sed -e 's/^#!\/bin\/sh/#!\/bin\/bash/' < ${unpack_script} > ${unpack_script}.new && chmod 755 ${unpack_script}.new && mv ${unpack_script}.new ${unpack_script}"
|
| +
|
| + # Since we are in static-only mode, we need to create a few links
|
| + for file in update.gz stateful.image.gz ; do
|
| + ssh ${FLAGS_upgrade_server} "cd ${archive_dir} && ln -sf ${image_path}/$file ."
|
| + ssh ${FLAGS_upgrade_server} "ln -sf ${archive_dir}/$file ${FLAGS_dest_path}/src/platform/dev/static"
|
| + done
|
| +}
|
| +
|
| +stop_server () {
|
| + require_upgrade_server
|
| + echo "Stopping remote devserver..."
|
| + echo "(Fast restart using \"$0 --upgrade_server=${FLAGS_upgrade_server} --dest_path=${FLAGS_dest_path} --archive_dir=${archive_dir}\")"
|
| + ssh ${FLAGS_upgrade_server} pkill -f ${archive_dir} || /bin/true
|
| +}
|
| +
|
| +# Start remote server
|
| +start_server () {
|
| + require_upgrade_server
|
| + echo "Starting remote devserver..."
|
| + server_logfile=/tmp/devserver_log.$$
|
| + portlist=/tmp/devserver_portlist.$$
|
| + echo "Server will be logging locally to $server_logfile"
|
| +
|
| + # Find a TCP listen socket that is not in use
|
| + ssh ${FLAGS_upgrade_server} "netstat -lnt" | awk '{ print $4 }' > $portlist
|
| + server_port=8081
|
| + while grep -q ":${port}$" $portlist; do
|
| + server_port=$[server_port + 1]
|
| + done
|
| + rm -f $portlist
|
| +
|
| + ssh ${FLAGS_upgrade_server} "cd ${FLAGS_dest_path}/src/scripts && env PYTHONPATH=${remote_root}${FLAGS_dest_path}/python CHROMEOS_BUILD_ROOT=${archive_dir} ./start_devserver --archive_dir ${archive_dir} $server_port" > $server_logfile 2>&1 &
|
| + server_pid=$!
|
| +
|
| + trap server_cleanup 2
|
| +
|
| + # Wait for server to startup
|
| + while sleep 1; do
|
| + if fgrep -q 'Serving images from' $server_logfile; then
|
| + echo "Server is ready"
|
| + break
|
| + elif kill -0 ${server_pid}; then
|
| + continue
|
| + else
|
| + echo "Server failed to startup"
|
| + exit 1
|
| + fi
|
| + done
|
| +}
|
| +
|
| +server_cleanup () {
|
| + trap '' 2
|
| + stop_server
|
| + exit 0
|
| +}
|
| +
|
| +# If destination path wasn't set on command line, create one from scratch
|
| +if [ -z "${FLAGS_dest_path}" -a ${FLAGS_stop_server} -eq ${FLAGS_FALSE} ] ; then
|
| + require_latest_image
|
| + hostname=$(uname -n)
|
| + hostname=${hostname%%.*}
|
| + image_name=${latest_image##*/}
|
| + create_devserver ${hostname}_${image_name}
|
| + FLAGS_start_server=${FLAGS_TRUE}
|
| +else
|
| + validate_devserver_path
|
| +fi
|
| +
|
| +if [ ${FLAGS_stop_server} -eq ${FLAGS_FALSE} ] ; then
|
| + create_archive_dir "${FLAGS_dest_path}/archive"
|
| + FLAGS_start_server=${FLAGS_TRUE}
|
| +else
|
| + archive_dir="${FLAGS_dest_path}/archive"
|
| +fi
|
| +
|
| +if [ "${FLAGS_stop_server}" -eq ${FLAGS_TRUE} ] ; then
|
| + stop_server
|
| + exit 0
|
| +fi
|
| +
|
| +# Make sure old devserver is dead, then restart it
|
| +if [ "${FLAGS_start_server}" -eq ${FLAGS_TRUE} ] ; then
|
| + stop_server
|
| + start_server
|
| +
|
| + tail -f ${server_logfile} &
|
| +
|
| + # Now tell the client to load from the server
|
| + if [ -n "${FLAGS_client_address}" ] ; then
|
| + if [ -z "${FLAGS_server_address}" ] ; then
|
| + FLAGS_server_address=${FLAGS_upgrade_server}
|
| + fi
|
| + live_args="--update_url=http://${FLAGS_server_address}:${server_port}/update \
|
| + --remote=${FLAGS_client_address}"
|
| + echo "Running ${SCRIPTS_DIR}/image_to_live.sh $live_args"
|
| + ${SCRIPTS_DIR}/image_to_live.sh $live_args &
|
| + fi
|
| +
|
| + wait ${server_pid}
|
| +fi
|
| +
|
|
|