| Index: src/scripts/make_factory_package.sh
|
| diff --git a/src/scripts/make_factory_package.sh b/src/scripts/make_factory_package.sh
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..b3b1ebc5e60091ea9861178ed236907b444c8e57
|
| --- /dev/null
|
| +++ b/src/scripts/make_factory_package.sh
|
| @@ -0,0 +1,154 @@
|
| +#!/bin/bash
|
| +
|
| +# Copyright (c) 2009 The Chromium OS Authors. All rights reserved.
|
| +# Use of this source code is governed by a BSD-style license that can be
|
| +# found in the LICENSE file.
|
| +
|
| +# Script to generate a factory install partition set and miniomaha.conf
|
| +# file from a release image and a factory image. This creates a server
|
| +# configuration that can be installed using a factory install shim.
|
| +#
|
| +# miniomaha lives in src/platform/dev/ and miniomaha partition sets live
|
| +# in src/platform/dev/static.
|
| +
|
| +# 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"
|
| +
|
| +# Load functions and constants for chromeos-install
|
| +. "$(dirname "$0")/chromeos-common.sh"
|
| +
|
| +get_default_board
|
| +
|
| +# Flags
|
| +DEFINE_string board "${DEFAULT_BOARD}" "Board for which the image was built"
|
| +DEFINE_string factory "" \
|
| + "Directory and file containing factory image: /path/chromiumos_test_image.bin"
|
| +DEFINE_string release "" \
|
| + "Directory and file containing release image: /path/chromiumos_image.bin"
|
| +
|
| +
|
| +# Parse command line
|
| +FLAGS "$@" || exit 1
|
| +eval set -- "${FLAGS_ARGV}"
|
| +
|
| +if [ ! -f "${FLAGS_release}" ] ; then
|
| + echo "Cannot find image file ${FLAGS_release}"
|
| + exit 1
|
| +fi
|
| +
|
| +if [ ! -f "${FLAGS_factory}" ] ; then
|
| + echo "Cannot find image file ${FLAGS_factory}"
|
| + exit 1
|
| +fi
|
| +
|
| +# Convert args to paths. Need eval to un-quote the string so that shell
|
| +# chars like ~ are processed; just doing FOO=`readlink -f ${FOO}` won't work.
|
| +OMAHA_DIR=${SRC_ROOT}/platform/dev
|
| +OMAHA_DATA_DIR=${OMAHA_DIR}/static/
|
| +
|
| +if [ ${INSIDE_CHROOT} -eq 0 ]; then
|
| + echo "Caching sudo authentication"
|
| + sudo -v
|
| + echo "Done"
|
| +fi
|
| +
|
| +# Use this image as the source image to copy
|
| +RELEASE_DIR=`dirname ${FLAGS_release}`
|
| +FACTORY_DIR=`dirname ${FLAGS_factory}`
|
| +RELEASE_IMAGE=`basename ${FLAGS_release}`
|
| +FACTORY_IMAGE=`basename ${FLAGS_factory}`
|
| +
|
| +
|
| +prepare_omaha() {
|
| + sudo rm -rf ${OMAHA_DATA_DIR}/rootfs-test.gz
|
| + sudo rm -rf ${OMAHA_DATA_DIR}/rootfs-release.gz
|
| + rm -rf ${OMAHA_DATA_DIR}/efi.gz
|
| + rm -rf ${OMAHA_DATA_DIR}/oem.gz
|
| + rm -rf ${OMAHA_DATA_DIR}/state.gz
|
| + rm -rf ${OMAHA_DIR}/miniomaha.conf
|
| +}
|
| +
|
| +prepare_dir() {
|
| + sudo rm -rf rootfs-test.gz
|
| + sudo rm -rf rootfs-release.gz
|
| + rm -rf efi.gz
|
| + rm -rf oem.gz
|
| + rm -rf state.gz
|
| +}
|
| +
|
| +
|
| +# Clean up stale config and data files.
|
| +prepare_omaha
|
| +
|
| +# Get the release image.
|
| +pushd ${RELEASE_DIR}
|
| +echo "Generating omaha release image from ${FLAGS_release}"
|
| +echo "Generating omaha factory image from ${FLAGS_factory}"
|
| +echo "Output omaha image to ${OMAHA_DATA_DIR}"
|
| +echo "Output omaha config to ${OMAHA_DIR}/miniomaha.conf"
|
| +
|
| +prepare_dir
|
| +
|
| +sudo ./unpack_partitions.sh ${RELEASE_IMAGE} &> /dev/null
|
| +release_hash=`sudo ${SCRIPTS_DIR}/mk_memento_images.sh part_2 part_3 \
|
| + | grep hash | awk '{print $4}'`
|
| +sudo chmod a+rw update.gz
|
| +mv update.gz rootfs-release.gz
|
| +mv rootfs-release.gz ${OMAHA_DATA_DIR}
|
| +echo "release: ${release_hash}"
|
| +
|
| +cat part_8 | gzip -9 > oem.gz
|
| +oem_hash=`cat oem.gz | openssl sha1 -binary | openssl base64`
|
| +mv oem.gz ${OMAHA_DATA_DIR}
|
| +echo "oem: ${oem_hash}"
|
| +
|
| +cat part_12 | gzip -9 > efi.gz
|
| +efi_hash=`cat efi.gz | openssl sha1 -binary | openssl base64`
|
| +mv efi.gz ${OMAHA_DATA_DIR}
|
| +echo "efi: ${efi_hash}"
|
| +
|
| +popd
|
| +
|
| +# Go to retrieve the factory test image.
|
| +pushd ${FACTORY_DIR}
|
| +prepare_dir
|
| +
|
| +
|
| +sudo ./unpack_partitions.sh ${FACTORY_IMAGE} &> /dev/null
|
| +test_hash=`sudo ${SCRIPTS_DIR}//mk_memento_images.sh part_2 part_3 \
|
| + | grep hash | awk '{print $4}'`
|
| +sudo chmod a+rw update.gz
|
| +mv update.gz rootfs-test.gz
|
| +mv rootfs-test.gz ${OMAHA_DATA_DIR}
|
| +echo "test: ${test_hash}"
|
| +
|
| +cat part_1 | gzip -9 > state.gz
|
| +state_hash=`cat state.gz | openssl sha1 -binary | openssl base64`
|
| +mv state.gz ${OMAHA_DATA_DIR}
|
| +echo "state: ${state_hash}"
|
| +
|
| +echo "
|
| +config = [
|
| + {
|
| + 'qual_ids': set([\"${FLAGS_board}\"]),
|
| + 'factory_image': 'rootfs-test.gz',
|
| + 'factory_checksum': '${test_hash}',
|
| + 'release_image': 'rootfs-release.gz',
|
| + 'release_checksum': '${release_hash}',
|
| + 'oempartitionimg_image': 'oem.gz',
|
| + 'oempartitionimg_checksum': '${oem_hash}',
|
| + 'efipartitionimg_image': 'efi.gz',
|
| + 'efipartitionimg_checksum': '${efi_hash}',
|
| + 'stateimg_image': 'state.gz',
|
| + 'stateimg_checksum': '${state_hash}'
|
| + },
|
| +]
|
| +" > ${OMAHA_DIR}/miniomaha.conf
|
| +
|
| +popd
|
| +echo "The miniomaha server lives in src/platform/dev"
|
| +echo "to validate the configutarion, run:"
|
| +echo " python2.6 devserver.py --factory_config miniomaha.conf --validate_factory_config"
|
| +echo "To run the server:"
|
| +echo " python2.6 devserver.py --factory_config miniomaha.conf"
|
|
|