|
@@ -8,9 +8,12 @@ hr() {
|
|
|
set -e
|
|
|
|
|
|
# Generate file name variables
|
|
|
+export GIT_TAG=$(git describe --abbrev=0)
|
|
|
export GIT_HASH=$(git rev-parse --short HEAD)
|
|
|
export FILE_DATE=$(date +%Y-%m-%d.%H-%M-%S)
|
|
|
-export FILENAME=$FILE_DATE-$GIT_HASH-$TRAVIS_BRANCH-osx.pkg
|
|
|
+export FILENAME=$FILE_DATE-$GIT_HASH-$TRAVIS_BRANCH-osx.dmg
|
|
|
+
|
|
|
+echo "git tag: $GIT_TAG"
|
|
|
|
|
|
cd ./build
|
|
|
|
|
@@ -30,32 +33,44 @@ if [ -n "${TRAVIS_TAG}" ]; then
|
|
|
STABLE=true
|
|
|
fi
|
|
|
|
|
|
-sudo python ../CI/install/osx/build_app.py --public-key ../CI/install/osx/OBSPublicDSAKey.pem --sparkle-framework ../../sparkle/Sparkle.framework --stable=$STABLE
|
|
|
+#sudo python ../CI/install/osx/build_app.py --public-key ../CI/install/osx/OBSPublicDSAKey.pem --sparkle-framework ../../sparkle/Sparkle.framework --stable=$STABLE
|
|
|
+
|
|
|
+../CI/install/osx/packageApp.sh
|
|
|
+
|
|
|
+# fix obs outputs
|
|
|
+cp /usr/local/opt/mbedtls/lib/libmbedtls.12.dylib ./OBS.app/Contents/Frameworks/
|
|
|
+cp /usr/local/opt/mbedtls/lib/libmbedcrypto.3.dylib ./OBS.app/Contents/Frameworks/
|
|
|
+cp /usr/local/opt/mbedtls/lib/libmbedx509.0.dylib ./OBS.app/Contents/Frameworks/
|
|
|
+install_name_tool -change /usr/local/opt/mbedtls/lib/libmbedtls.12.dylib @executable_path/../Frameworks/libmbedtls.12.dylib ./OBS.app/Contents/Plugins/obs-outputs.so
|
|
|
+install_name_tool -change /usr/local/opt/mbedtls/lib/libmbedcrypto.3.dylib @executable_path/../Frameworks/libmbedcrypto.3.dylib ./OBS.app/Contents/Plugins/obs-outputs.so
|
|
|
+install_name_tool -change /usr/local/opt/mbedtls/lib/libmbedx509.0.dylib @executable_path/../Frameworks/libmbedx509.0.dylib ./OBS.app/Contents/Plugins/obs-outputs.so
|
|
|
+install_name_tool -change /usr/local/opt/curl/lib/libcurl.4.dylib @executable_path/../Frameworks/libcurl.4.dylib ./OBS.app/Contents/Plugins/obs-outputs.so
|
|
|
+install_name_tool -change @rpath/libobs.0.dylib @executable_path/../Frameworks/libobs.0.dylib ./OBS.app/Contents/Plugins/obs-outputs.so
|
|
|
+
|
|
|
+# copy sparkle into the app
|
|
|
+hr "Copying Sparkle.framework"
|
|
|
+cp -r ../../sparkle/Sparkle.framework ./OBS.app/Contents/Frameworks/
|
|
|
+install_name_tool -change @rpath/Sparkle.framework/Versions/A/Sparkle @executable_path/../Frameworks/Sparkle.framework/Versions/A/Sparkle ./OBS.app/Contents/MacOS/obs
|
|
|
|
|
|
# Copy Chromium embedded framework to app Frameworks directory
|
|
|
hr "Copying Chromium Embedded Framework.framework"
|
|
|
sudo mkdir -p OBS.app/Contents/Frameworks
|
|
|
sudo cp -r ../../cef_binary_${CEF_BUILD_VERSION}_macosx64/Release/Chromium\ Embedded\ Framework.framework OBS.app/Contents/Frameworks/
|
|
|
-sudo install_name_tool -change \
|
|
|
- @rpath/Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- ../../Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- OBS.app/Contents/Resources/obs-plugins/obs-browser.so
|
|
|
-sudo install_name_tool -change \
|
|
|
- @executable_path/../Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- ../../Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- OBS.app/Contents/Resources/obs-plugins/obs-browser.so
|
|
|
-sudo install_name_tool -change \
|
|
|
- @rpath/Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- ../../Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- OBS.app/Contents/Resources/obs-plugins/obs-browser-page
|
|
|
-sudo install_name_tool -change \
|
|
|
- @executable_path/../Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- ../../Frameworks/Chromium\ Embedded\ Framework.framework/Chromium\ Embedded\ Framework \
|
|
|
- OBS.app/Contents/Resources/obs-plugins/obs-browser-page
|
|
|
-
|
|
|
-# Package app
|
|
|
-hr "Generating .pkg"
|
|
|
-packagesbuild ../CI/install/osx/CMakeLists.pkgproj
|
|
|
+
|
|
|
+install_name_tool -change /usr/local/opt/qt/lib/QtGui.framework/Versions/5/QtGui @executable_path/../Frameworks/QtGui.framework/Versions/5/QtGui ./OBS.app/Contents/Plugins/obs-browser.so
|
|
|
+install_name_tool -change /usr/local/opt/qt/lib/QtCore.framework/Versions/5/QtCore @executable_path/../Frameworks/QtCore.framework/Versions/5/QtCore ./OBS.app/Contents/Plugins/obs-browser.so
|
|
|
+install_name_tool -change /usr/local/opt/qt/lib/QtWidgets.framework/Versions/5/QtWidgets @executable_path/../Frameworks/QtWidgets.framework/Versions/5/QtWidgets ./OBS.app/Contents/Plugins/obs-browser.so
|
|
|
+
|
|
|
+cp ../CI/install/osx/OBSPublicDSAKey.pem OBS.app/Contents/Resources
|
|
|
+
|
|
|
+# edit plist
|
|
|
+plutil -insert CFBundleVersion -string $GIT_TAG ./OBS.app/Contents/Info.plist
|
|
|
+plutil -insert CFBundleShortVersionString -string $GIT_TAG ./OBS.app/Contents/Info.plist
|
|
|
+plutil -insert OBSFeedsURL -string https://obsproject.com/osx_update/feeds.xml ./OBS.app/Contents/Info.plist
|
|
|
+plutil -insert SUFeedURL -string https://obsproject.com/osx_update/stable/updates.xml ./OBS.app/Contents/Info.plist
|
|
|
+plutil -insert SUPublicDSAKeyFile -string OBSPublicDSAKey.pem ./OBS.app/Contents/Info.plist
|
|
|
+
|
|
|
+dmgbuild -s ../CI/install/osx/settings.json "OBS" obs.dmg
|
|
|
|
|
|
if [ -v "$TRAVIS" ]; then
|
|
|
# Signing stuff
|
|
@@ -70,12 +85,10 @@ if [ -v "$TRAVIS" ]; then
|
|
|
security import ./Certificates.p12 -k build.keychain -T /usr/bin/productsign -P ""
|
|
|
# macOS 10.12+
|
|
|
security set-key-partition-list -S apple-tool:,apple: -s -k mysecretpassword build.keychain
|
|
|
- hr "Signing Package"
|
|
|
- productsign --sign 2MMRE5MTB8 ./OBS.pkg ./$FILENAME
|
|
|
-else
|
|
|
- cp ./OBS.pkg ./$FILENAME
|
|
|
fi
|
|
|
|
|
|
+cp ./OBS.dmg ./$FILENAME
|
|
|
+
|
|
|
# Move to the folder that travis uses to upload artifacts from
|
|
|
hr "Moving package to nightly folder for distribution"
|
|
|
mkdir ../nightly
|