source: josm/trunk/native/macosx/macos-jpackage.sh@ 17487

Last change on this file since 17487 was 17487, checked in by GerdP, 3 years ago

see #20257:macOS build process fixes and improvements

  • Property svn:executable set to *
File size: 3.3 KB
Line 
1#!/bin/bash
2
3## Expected environment, passed from GitHub secrets:
4# https://docs.github.com/en/free-pro-team@latest/actions/reference/encrypted-secrets
5# APPLE_ID_PW Password for the Apple ID
6# CERT_MACOS_P12 Certificate used for code signing, base64 encoded
7# CERT_MACOS_PW Password for that certificate
8
9set -Eeou pipefail
10
11# Don't show one time passwords
12set +x
13
14APPLE_ID="thomas.skowron@fossgis.de"
15IMPORT_AND_UNLOCK_KEYCHAIN=${IMPORT_AND_UNLOCK_KEYCHAIN:-1}
16
17if [ -z "${1-}" ]
18then
19 echo "Usage: $0 josm_revision"
20 exit 1
21fi
22
23echo "Building JOSM.app"
24
25mkdir app
26
27if [ -z "$CERT_MACOS_P12" ] || [ -z "$CERT_MACOS_PW" ] || [ -z "$APPLE_ID_PW" ]
28then
29 echo "CERT_MACOS_P12, CERT_MACOS_PW and APPLE_ID_PW are not set in the environment."
30 echo "I will create a JOSM.app but I won't attempt to sign and notarize it."
31 SIGNAPP=false
32else
33 echo "Preparing certificates/keychain for signing…"
34
35 KEYCHAIN=build.keychain
36 KEYCHAINPATH=~/Library/Keychains/$KEYCHAIN-db
37 KEYCHAIN_PW=$(head /dev/urandom | base64 | head -c 20)
38 CERTIFICATE_P12=certificate.p12
39
40 echo "$CERT_MACOS_P12" | base64 --decode > $CERTIFICATE_P12
41 security create-keychain -p "$KEYCHAIN_PW" $KEYCHAIN
42 security default-keychain -s $KEYCHAIN
43 security unlock-keychain -p "$KEYCHAIN_PW" $KEYCHAIN
44 security import $CERTIFICATE_P12 -k $KEYCHAIN -P "$CERT_MACOS_PW" -T /usr/bin/codesign
45 security set-key-partition-list -S apple-tool:,apple: -s -k "$KEYCHAIN_PW" $KEYCHAIN
46 rm $CERTIFICATE_P12
47 SIGNAPP=true
48 echo "Signing preparation done."
49fi
50
51if $SIGNAPP; then
52 JPACKAGEOPTIONS="--mac-sign --mac-signing-keychain $KEYCHAINPATH"
53else
54 JPACKAGEOPTIONS=""
55fi
56
57echo "Building and signin app"
58 jpackage $JPACKAGEOPTIONS -n "JOSM" --input dist --main-jar josm-custom.jar \
59 --main-class org.openstreetmap.josm.gui.MainApplication \
60 --icon ./native/macosx/JOSM.icns --type app-image --dest app \
61 --java-options "-Xmx8192m" \
62 --app-version "$1" \
63 --copyright "JOSM, and all its integral parts, are released under the GNU General Public License v2 or later" \
64 --vendor "https://josm.openstreetmap.de" \
65 --mac-sign \
66 --mac-package-identifier de.openstreetmap.josm \
67 --mac-package-signing-prefix de.openstreetmap.josm \
68 --mac-signing-keychain $KEYCHAINPATH \
69 --file-associations native/macosx/bz2.properties \
70 --file-associations native/macosx/geojson.properties \
71 --file-associations native/macosx/gpx.properties \
72 --file-associations native/macosx/gz.properties \
73 --file-associations native/macosx/jos.properties \
74 --file-associations native/macosx/joz.properties \
75 --file-associations native/macosx/osm.properties \
76 --file-associations native/macosx/zip.properties \
77 --add-modules java.base,java.datatransfer,java.desktop,java.logging,java.management,java.naming,java.net.http,java.prefs,java.rmi,java.scripting,java.sql,java.transaction.xa,java.xml,jdk.crypto.ec,jdk.jfr,jdk.jsobject,jdk.unsupported,jdk.unsupported.desktop,jdk.xml.dom
78
79echo "Building done."
80
81if $SIGNAPP; then
82 echo "Preparing for notarization"
83 ditto -c -k --zlibCompressionLevel 9 --keepParent app/JOSM.app app/JOSM.zip
84
85 echo "Uploading to Apple"
86 xcrun altool --notarize-app -f app/JOSM.zip -p "$APPLE_ID_PW" -u "$APPLE_ID" --primary-bundle-id de.openstreetmap.josm
87fi
Note: See TracBrowser for help on using the repository browser.