diff --git a/build_tools/mac_notarize.sh b/build_tools/mac_notarize.sh new file mode 100755 index 000000000..c58b7b47b --- /dev/null +++ b/build_tools/mac_notarize.sh @@ -0,0 +1,99 @@ +#!/usr/bin/env bash + +# Helper to notarize an .app.zip or .pkg file. +# Based on https://www.logcg.com/en/archives/3222.html + +set -e + +die() { echo "$*" 1>&2 ; exit 1; } + +check_status() { + echo "STATUS" $1 +} + +get_req_uuid() { + RESPONSE=$(&1 | + tee -a "$LOGFILE" | + get_req_uuid) + +test -z "$NOTARIZE_UUID" && cat "$LOGFILE" && die "Could not get RequestUUID" +echo "RequestUUID: $NOTARIZE_UUID" + +success=0 +for i in $(seq 20); do + echo "Checking progress..." + PROGRESS=$(xcrun altool --notarization-info "${NOTARIZE_UUID}" \ + -u "$AC_USER" \ + -p "$AC_PASS" 2>&1 | + tee -a "$LOGFILE") + echo "${PROGRESS}" | tail -n 1 + + if [ $? -ne 0 ] || [[ "${PROGRESS}" =~ "Invalid" ]] ; then + echo "Error with notarization. Exiting" + break + fi + + if ! [[ "${PROGRESS}" =~ "in progress" ]]; then + success=1 + break + else + echo "Not completed yet. Sleeping for 30 seconds." + fi + sleep 30 +done + +if [ $success -eq 1 ] ; then + if test "$ext" = "zip"; then + TMPDIR=$(mktemp -d) + echo "Extracting to $TMPDIR" + unzip -q "$INPUT" -d "$TMPDIR" + # Force glob expansion. + STAPLE_TARGET="$TMPDIR"/* + STAPLE_TARGET=$(echo $STAPLE_TARGET) + else + STAPLE_TARGET="$INPUT" + fi + echo "Stapling $STAPLE_TARGET" + xcrun stapler staple "$STAPLE_TARGET" + + if test "$ext" = "zip"; then + # Zip it back up. + INPUT_FULL=$(realpath "$INPUT") + rm -f "$INPUT" + cd "$(dirname "$STAPLE_TARGET")" + zip -r -q "$INPUT_FULL" $(basename "$STAPLE_TARGET") + fi +fi +echo "Processed $INPUT" + +if test "$ext" = "zip"; then + spctl -a -v "$STAPLE_TARGET" +fi