Files
amnezia-client/deploy/build_macos.sh
T

171 lines
5.6 KiB
Bash
Raw Normal View History

2021-05-21 05:33:40 -07:00
#!/bin/bash
echo "Build script started ..."
set -o errexit -o nounset
while getopts n flag
2022-08-19 16:17:37 +03:00
do
case "${flag}" in
n) NOTARIZE_APP=1;;
esac
done
2021-05-21 05:33:40 -07:00
# Hold on to current directory
PROJECT_DIR=$(pwd)
DEPLOY_DIR=$PROJECT_DIR/deploy
mkdir -p $DEPLOY_DIR/build
BUILD_DIR=$DEPLOY_DIR/build
echo "Project dir: ${PROJECT_DIR}"
echo "Build dir: ${BUILD_DIR}"
APP_NAME=AmneziaVPN
APP_FILENAME=$APP_NAME.app
APP_DOMAIN=org.amneziavpn.package
PLIST_NAME=$APP_NAME.plist
OUT_APP_DIR=$BUILD_DIR/client
BUNDLE_DIR=$OUT_APP_DIR/$APP_FILENAME
PREBUILT_DEPLOY_DATA_DIR=$PROJECT_DIR/deploy/data/deploy-prebuilt/macos
2021-05-21 05:33:40 -07:00
DEPLOY_DATA_DIR=$PROJECT_DIR/deploy/data/macos
2021-05-21 05:33:40 -07:00
INSTALLER_DATA_DIR=$BUILD_DIR/installer/packages/$APP_DOMAIN/data
INSTALLER_BUNDLE_DIR=$BUILD_DIR/installer/$APP_FILENAME
2022-08-19 16:17:37 +03:00
DMG_FILENAME=$PROJECT_DIR/${APP_NAME}.dmg
2021-05-21 05:33:40 -07:00
2023-04-11 09:50:44 -04:00
# Search Qt
2021-06-03 10:34:28 -07:00
if [ -z "${QT_VERSION+x}" ]; then
2024-02-26 02:44:28 -08:00
QT_VERSION=6.4.3;
2023-06-29 17:38:04 -07:00
QIF_VERSION=4.6
2023-01-08 17:21:51 -08:00
QT_BIN_DIR=$HOME/Qt/$QT_VERSION/macos/bin
2021-06-03 10:34:28 -07:00
QIF_BIN_DIR=$QT_BIN_DIR/../../../Tools/QtInstallerFramework/$QIF_VERSION/bin
fi
2021-05-21 05:33:40 -07:00
echo "Using Qt in $QT_BIN_DIR"
echo "Using QIF in $QIF_BIN_DIR"
# Checking env
2022-11-29 22:44:29 +03:00
$QT_BIN_DIR/qt-cmake --version
cmake --version
2021-05-21 05:33:40 -07:00
clang -v
# Build App
echo "Building App..."
cd $BUILD_DIR
2022-11-29 22:44:29 +03:00
$QT_BIN_DIR/qt-cmake -S $PROJECT_DIR -B $BUILD_DIR
2023-01-08 17:21:51 -08:00
cmake --build . --config release --target all
2021-05-21 05:33:40 -07:00
# Build and run tests here
echo "____________________________________"
echo "............Deploy.................."
echo "____________________________________"
2023-05-28 08:24:00 -07:00
# Package
2021-05-21 05:33:40 -07:00
echo "Packaging ..."
2023-08-24 09:12:06 -04:00
cp -Rv $PREBUILT_DEPLOY_DATA_DIR/* $BUNDLE_DIR/Contents/macOS
2022-01-23 15:25:53 -08:00
$QT_BIN_DIR/macdeployqt $OUT_APP_DIR/$APP_FILENAME -always-overwrite -qmldir=$PROJECT_DIR
2023-01-08 17:21:51 -08:00
cp -av $BUILD_DIR/service/server/$APP_NAME-service $BUNDLE_DIR/Contents/macOS
2021-05-21 05:33:40 -07:00
cp -Rv $PROJECT_DIR/deploy/data/macos/* $BUNDLE_DIR/Contents/macOS
rm -f $BUNDLE_DIR/Contents/macOS/post_install.sh $BUNDLE_DIR/Contents/macOS/post_uninstall.sh
if [ "${MAC_CERT_PW+x}" ]; then
2022-08-19 18:35:17 +03:00
CERTIFICATE_P12=$DEPLOY_DIR/PrivacyTechAppleCertDeveloperId.p12
WWDRCA=$DEPLOY_DIR/WWDRCA.cer
2023-09-21 05:14:15 -07:00
KEYCHAIN=amnezia.build.macos.keychain
2022-08-19 18:35:17 +03:00
TEMP_PASS=tmp_pass
security create-keychain -p $TEMP_PASS $KEYCHAIN || true
security default-keychain -s $KEYCHAIN
security unlock-keychain -p $TEMP_PASS $KEYCHAIN
security default-keychain
security list-keychains
security import $WWDRCA -k $KEYCHAIN -T /usr/bin/codesign || true
security import $CERTIFICATE_P12 -k $KEYCHAIN -P $MAC_CERT_PW -T /usr/bin/codesign || true
security set-key-partition-list -S apple-tool:,apple: -k $TEMP_PASS $KEYCHAIN
security find-identity -p codesigning
echo "Signing App bundle..."
2023-10-17 06:39:49 -07:00
/usr/bin/codesign --deep --force --verbose --timestamp -o runtime --sign "$MAC_SIGNER_ID" $BUNDLE_DIR
2022-08-19 18:35:17 +03:00
/usr/bin/codesign --verify -vvvv $BUNDLE_DIR || true
spctl -a -vvvv $BUNDLE_DIR || true
if [ "${NOTARIZE_APP+x}" ]; then
2023-04-11 09:50:44 -04:00
echo "Notarizing App bundle..."
2022-08-19 18:35:17 +03:00
/usr/bin/ditto -c -k --keepParent $BUNDLE_DIR $PROJECT_DIR/Bundle_to_notarize.zip
2023-10-17 06:39:49 -07:00
xcrun notarytool submit $PROJECT_DIR/Bundle_to_notarize.zip --apple-id $APPLE_DEV_EMAIL --team-id $MAC_TEAM_ID --password $APPLE_DEV_PASSWORD
2022-08-19 18:35:17 +03:00
rm $PROJECT_DIR/Bundle_to_notarize.zip
2023-10-17 06:39:49 -07:00
sleep 300
2022-08-19 18:35:17 +03:00
xcrun stapler staple $BUNDLE_DIR
xcrun stapler validate $BUNDLE_DIR
spctl -a -vvvv $BUNDLE_DIR || true
fi
2021-05-21 05:33:40 -07:00
fi
echo "Packaging installer..."
mkdir -p $INSTALLER_DATA_DIR
cp -av $PROJECT_DIR/deploy/installer $BUILD_DIR
cp -av $DEPLOY_DATA_DIR/post_install.sh $INSTALLER_DATA_DIR/post_install.sh
cp -av $DEPLOY_DATA_DIR/post_uninstall.sh $INSTALLER_DATA_DIR/post_uninstall.sh
cp -av $DEPLOY_DATA_DIR/$PLIST_NAME $INSTALLER_DATA_DIR/$PLIST_NAME
chmod a+x $INSTALLER_DATA_DIR/post_install.sh $INSTALLER_DATA_DIR/post_uninstall.sh
cd $BUNDLE_DIR
tar czf $INSTALLER_DATA_DIR/$APP_NAME.tar.gz ./
echo "Building installer..."
$QIF_BIN_DIR/binarycreator --offline-only -v -c $BUILD_DIR/installer/config/macos.xml -p $BUILD_DIR/installer/packages -f $INSTALLER_BUNDLE_DIR
if [ "${MAC_CERT_PW+x}" ]; then
2022-08-19 16:17:37 +03:00
echo "Signing installer bundle..."
security unlock-keychain -p $TEMP_PASS $KEYCHAIN
2023-10-17 06:39:49 -07:00
/usr/bin/codesign --deep --force --verbose --timestamp -o runtime --sign "$MAC_SIGNER_ID" $INSTALLER_BUNDLE_DIR
2022-08-19 16:17:37 +03:00
/usr/bin/codesign --verify -vvvv $INSTALLER_BUNDLE_DIR || true
if [ "${NOTARIZE_APP+x}" ]; then
2023-04-11 09:50:44 -04:00
echo "Notarizing installer bundle..."
2022-08-19 16:17:37 +03:00
/usr/bin/ditto -c -k --keepParent $INSTALLER_BUNDLE_DIR $PROJECT_DIR/Installer_bundle_to_notarize.zip
2023-10-17 06:39:49 -07:00
xcrun notarytool submit $PROJECT_DIR/Installer_bundle_to_notarize.zip --apple-id $APPLE_DEV_EMAIL --team-id $MAC_TEAM_ID --password $APPLE_DEV_PASSWORD
2022-08-19 16:17:37 +03:00
rm $PROJECT_DIR/Installer_bundle_to_notarize.zip
2023-10-17 06:39:49 -07:00
sleep 300
2022-08-19 16:17:37 +03:00
xcrun stapler staple $INSTALLER_BUNDLE_DIR
xcrun stapler validate $INSTALLER_BUNDLE_DIR
spctl -a -vvvv $INSTALLER_BUNDLE_DIR || true
fi
2021-05-21 05:33:40 -07:00
fi
echo "Building DMG installer..."
2024-02-22 13:57:58 +03:00
# Allow Terminal to make changes in Privacy & Security > App Management
hdiutil create -size 256mb -volname AmneziaVPN -srcfolder $BUILD_DIR/installer/$APP_NAME.app -ov -format UDZO $DMG_FILENAME
2021-05-21 05:33:40 -07:00
if [ "${MAC_CERT_PW+x}" ]; then
2022-08-19 16:17:37 +03:00
echo "Signing DMG installer..."
security unlock-keychain -p $TEMP_PASS $KEYCHAIN
2023-10-17 06:39:49 -07:00
/usr/bin/codesign --deep --force --verbose --timestamp -o runtime --sign "$MAC_SIGNER_ID" $DMG_FILENAME
2022-08-19 16:17:37 +03:00
/usr/bin/codesign --verify -vvvv $DMG_FILENAME || true
if [ "${NOTARIZE_APP+x}" ]; then
2023-04-11 09:50:44 -04:00
echo "Notarizing DMG installer..."
2023-10-17 06:39:49 -07:00
xcrun notarytool submit $DMG_FILENAME --apple-id $APPLE_DEV_EMAIL --team-id $MAC_TEAM_ID --password $APPLE_DEV_PASSWORD
sleep 300
2022-08-19 16:17:37 +03:00
xcrun stapler staple $DMG_FILENAME
xcrun stapler validate $DMG_FILENAME
fi
2021-05-21 05:33:40 -07:00
fi
echo "Finished, artifact is $DMG_FILENAME"
# restore keychain
security default-keychain -s login.keychain