fix(core_roller_upload): Use new payload names and upload path.

As of 4e85b172 the build system generates the update payload using the
coreos_production_update prefix, so use that instead. Use the release
version in the storage path instead of a disk image MD5; the version is
sufficiently unique and the no need for the obfuscation.

Drop the disk image copy in the download storage that I tacked in, that
will go into a new core_promote script that I have written but not
tested yet (need an alpha release to promote!!).
This commit is contained in:
Michael Marineau 2014-05-05 16:48:43 -07:00
parent 19d22fb6cf
commit ce9d1c95a9

View File

@ -12,10 +12,10 @@ export GCLIENT_ROOT=$(readlink -f "${SCRIPT_ROOT}/../../")
DEFINE_string board "amd64-usr" \ DEFINE_string board "amd64-usr" \
"Board type of the image" "Board type of the image"
DEFINE_string group "alpha" \ DEFINE_string payload "coreos_production_update.gz" \
"Group that this update goes into." "Path to the update payload"
DEFINE_string image "coreos_production_image.bin" \ DEFINE_string metadata "coreos_production_update.meta" \
"Path to the production image (not base/dev/qemu/xen/etc)" "Path to the update metadata"
DEFINE_string version "${COREOS_VERSION_STRING}" \ DEFINE_string version "${COREOS_VERSION_STRING}" \
"Version number of this build." "Version number of this build."
DEFINE_string app_id "e96281a6-d1af-4bde-9a0a-97b76e56dc57" \ DEFINE_string app_id "e96281a6-d1af-4bde-9a0a-97b76e56dc57" \
@ -27,10 +27,8 @@ DEFINE_string api_key "" \
"API key for roller." "API key for roller."
DEFINE_string endpoint "https://public.update.core-os.net" \ DEFINE_string endpoint "https://public.update.core-os.net" \
"Roller endpoint to update." "Roller endpoint to update."
DEFINE_string storage "gs://update-storage.core-os.net" \
DEFINE_boolean update_storage ${FLAGS_FALSE} \ "Google Storage location to host the payload."
"Update image download location for group on storage.core-os.net."
FLAGS_HELPS="usage: $SCRIPTNAME [flags] FLAGS_HELPS="usage: $SCRIPTNAME [flags]
@ -38,8 +36,6 @@ Setting everything up for use\n
1) Run 'gsutil config' and use project id coreos.com:core-update-storage\n 1) Run 'gsutil config' and use project id coreos.com:core-update-storage\n
2) Ensure rollerctl is installed in your path\n 2) Ensure rollerctl is installed in your path\n
NOTE: Use the coreos_production_image.bin not base, developer, vm, etc...
" "
# Parse flags # Parse flags
@ -50,25 +46,20 @@ switch_to_strict_mode
[[ -z "${FLAGS_api_key}" ]] && die "--api_key is required" [[ -z "${FLAGS_api_key}" ]] && die "--api_key is required"
[[ -z "${FLAGS_user}" ]] && die "--user is required" [[ -z "${FLAGS_user}" ]] && die "--user is required"
MD5SUM=$(md5sum ${FLAGS_image} | cut -f1 -d" ") # Ensure GS URL doesn't have a trailing /
[[ -z "$MD5SUM" ]] && die "Failed to hash ${FLAGS_image}" FLAGS_storage="${FLAGS_storage%%/}"
URL="update-storage.core-os.net/${FLAGS_board}/${FLAGS_group}/$MD5SUM/update.gz"
gsutil cp "update.gz" gs://${URL} GS_URL="${FLAGS_storage}/${FLAGS_board}/${FLAGS_version}/update.gz"
HTTP_URL="http://${GS_URL#gs://}"
gsutil cp "${FLAGS_payload}" "${GS_URL}"
rollerctl \ rollerctl \
-s ${FLAGS_endpoint} \ -s ${FLAGS_endpoint} \
-u ${FLAGS_user} \ -u ${FLAGS_user} \
-k ${FLAGS_api_key} \ -k ${FLAGS_api_key} \
new-package \ new-package \
--url "http://${URL}" \ --url "${HTTP_URL}" \
--file "update.gz" \ --file "${FLAGS_payload}" \
--meta "update.meta" \ --meta "${FLAGS_metadata}" \
--version "${FLAGS_version}" \ --version "${FLAGS_version}" \
"${FLAGS_app_id}" "${FLAGS_app_id}"
# Copy the vagrant boxes and pre-built images over to the group mirror
if [[ "${FLAGS_update_storage}" -eq "${FLAGS_TRUE}" ]]; then
gsutil cp \
"${COREOS_UPLOAD_ROOT}/${FLAGS_board}/${FLAGS_version}/*" \
"${COREOS_UPLOAD_ROOT}/${FLAGS_board}/${FLAGS_group}/"
fi