telegraf/scripts/mac-signing.sh

103 lines
3.6 KiB
Bash

#!/bin/bash
function cleanup () {
echo "Cleaning up any existing Telegraf or Telegraf.app"
printf "\n"
rm -rf Telegraf
rm -rf Telegraf.app
}
# Acquire the necessary certificates.
# MacCertificate, MacCertificatePassword, AppleSigningAuthorityCertificate are environment variables, to follow convention they should have been all caps.
# shellcheck disable=SC2154
base64 -D -o MacCertificate.p12 <<< "$MacCertificate"
# shellcheck disable=SC2154
sudo security import MacCertificate.p12 -k /Library/Keychains/System.keychain -P "$MacCertificatePassword" -A
# shellcheck disable=SC2154
base64 -D -o AppleSigningAuthorityCertificate.cer <<< "$AppleSigningAuthorityCertificate"
sudo security import AppleSigningAuthorityCertificate.cer -k '/Library/Keychains/System.keychain' -A
amdFile=$(find "$HOME/project/dist" -name "*darwin_amd64.tar*")
armFile=$(find "$HOME/project/dist" -name "*darwin_arm64.tar*")
macFiles=("${amdFile}" "${armFile}")
for tarFile in "${macFiles[@]}";
do
cleanup
# Create the .app bundle directory structure
RootAppDir="Telegraf.app/Contents"
mkdir -p "$RootAppDir"
mkdir -p "$RootAppDir/MacOS"
mkdir -p "$RootAppDir/Resources"
DeveloperID="Developer ID Application: InfluxData Inc. (M7DN9H35QT)"
# Sign telegraf binary and the telegraf_entry_mac script
echo "Extract $tarFile to $RootAppDir/Resources"
tar -xzvf "$tarFile" --strip-components=2 -C "$RootAppDir/Resources"
printf "\n"
TelegrafBinPath="$RootAppDir/Resources/usr/bin/telegraf"
codesign --force -s "$DeveloperID" --timestamp --options=runtime "$TelegrafBinPath"
echo "Verify if $TelegrafBinPath was signed"
codesign -dvv "$TelegrafBinPath"
printf "\n"
cp ~/project/scripts/telegraf_entry_mac "$RootAppDir"/MacOS
EntryMacPath="$RootAppDir/MacOS/telegraf_entry_mac"
codesign -s "$DeveloperID" --timestamp --options=runtime "$EntryMacPath"
echo "Verify if $EntryMacPath was signed"
codesign -dvv "$EntryMacPath"
printf "\n"
cp ~/project/info.plist "$RootAppDir"
cp ~/project/assets/windows/icon.icns "$RootAppDir/Resources"
chmod +x "$RootAppDir/MacOS/telegraf_entry_mac"
# Sign the entire .app bundle, and wrap it in a DMG.
codesign -s "$DeveloperID" --timestamp --options=runtime --deep --force Telegraf.app
baseName=$(basename "$tarFile" .tar.gz)
echo "$baseName"
hdiutil create -size 500m -volname Telegraf -srcfolder Telegraf.app "$baseName".dmg
codesign -s "$DeveloperID" --timestamp --options=runtime "$baseName".dmg
# Send the DMG to be notarized.
# AppleUsername and ApplePassword are environment variables, to follow convention they should have been all caps.
# shellcheck disable=SC2154
uuid=$(xcrun altool --notarize-app --primary-bundle-id "com.influxdata.telegraf" --username "$AppleUsername" --password "$ApplePassword" --file "$baseName".dmg | awk '/RequestUUID/ { print $NF; }')
echo "UUID: $uuid"
if [[ $uuid == "" ]]; then
echo "Could not upload for notarization."
exit 1
fi
printf "\n"
# Wait until the status returns something other than 'in progress'.
request_status="in progress"
while [[ "$request_status" == "in progress" ]]; do
sleep 10
request_response=$(xcrun altool --notarization-info "$uuid" --username "$AppleUsername" --password "$ApplePassword" 2>&1)
request_status=$(echo "$request_response" | awk -F ': ' '/Status:/ { print $2; }' )
done
if [[ $request_status != "success" ]]; then
echo "Failed to notarize."
echo "$request_response"
cleanup
exit 1
fi
# Attach the notarization to the DMG.
xcrun stapler staple "$baseName".dmg
cleanup
mkdir -p ~/project/build/dist
mv "$baseName".dmg ~/project/build/dist
echo "$baseName.dmg signed and notarized!"
done