#!/usr/bin/env bash set -e # This script downloads and unzips the artifacts produced in a workflow run. The # script has several pre-requisites: # - some standard Bash tools (curl, unzip) and one slightly more rare one (jq) # - the ID of a workflow run that has run successfully--this is where we # retrieve the artifacts from # - a GitHub access token, see https://github.com/settings/tokens # # Usage: download-workflow-artifacts.sh WORKFLOW_RUN_ID=${WORKFLOW_RUN_ID:-$1} GITHUB_TOKEN=${GITHUB_TOKEN:-$2} GITHUB_API_VERSION=${GITHUB_API_VERSION:-2022-11-28} GITHUB_API_URL=${GITHUB_API_URL:-https://api.github.com/repos/WebAssembly/wasi-sdk} TMP_DIR=$(mktemp -d -t wasi-sdk-artifacts.XXXXXXX) if [ -z "${WORKFLOW_RUN_ID}" ] || [ -z "${GITHUB_TOKEN}" ]; then >&2 echo "Missing parameter; exiting..." >&2 echo "Usage: download-worfklow-artifacts.sh " exit 1 fi # List out the artifacts in the given workflow run. # See https://docs.github.com/en/rest/actions/artifacts#list-workflow-run-artifacts ARTIFACTS=$(curl \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer ${GITHUB_TOKEN}" \ -H "X-GitHub-Api-Version: ${GITHUB_API_VERSION}" \ "${GITHUB_API_URL}/actions/runs/${WORKFLOW_RUN_ID}/artifacts" \ | jq -r '.artifacts[] | [(.id|tostring), .name, .archive_download_url] | join(",")') for A in $ARTIFACTS; do ID=$(echo $A | cut -d ',' -f 1) NAME=$(echo $A | cut -d ',' -f 2) URL=$(echo $A | cut -d ',' -f 3) TO=$TMP_DIR/$NAME.zip # Exclude dist-ubuntu-latest to prefer dist-ubuntu-bionic, which is # compatible with wider distributions. See: # - https://github.com/WebAssembly/wasi-sdk/pull/273#issuecomment-1373879491 # - https://github.com/WebAssembly/wasi-sdk/issues/303 if [ "${NAME}" = "dist-ubuntu-latest" ]; then continue fi # Exclude the 32-bit Windows artifact in favor of the 64-bit one. This helps # ensure the identically-named 32-bit tarfile doesn't overwrite the 64-bit # one below. See: # - https://github.com/WebAssembly/wasi-sdk/issues/326 if [ "${NAME}" = "dist-windows-latest-x86" ]; then continue fi >&2 echo "===== Downloading: ${TO} =====" # Download the artifacts to the temporary directory. # See https://docs.github.com/en/rest/actions/artifacts#download-an-artifact curl \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer ${GITHUB_TOKEN}" \ -H "X-GitHub-Api-Version: ${GITHUB_API_VERSION}" \ --location --output "${TO}" \ "${GITHUB_API_URL}/actions/artifacts/${ID}/zip" done # Unzip the workflow artifacts into a `release` directory. pushd $TMP_DIR > /dev/null mkdir release ls -1 *.zip | xargs -n1 unzip -q -o -d release # Some explanation: # -1 prints each file on a separate line # -n1 runs the command once for each item # -q means quietly # -o allows unzip to overwrite existing files (e.g., multiple copies of `libclang_rt.builtins-wasm32-wasi-...`) # -d tells unzip which directory to place things in >&2 echo "===== Files to release: ${TMP_DIR}/release =====" >&2 ls -1 release popd > /dev/null >&2 echo >&2 echo "Ensure the above artifacts look correct, then run \`draft-release.sh\` with the following directory:" echo "${TMP_DIR}/release"