release.yml 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740
  1. name: Installers and Release
  2. on:
  3. workflow_dispatch:
  4. inputs:
  5. semver:
  6. description: 'SemVer'
  7. required: true
  8. default: '0.99.99-SNAPSHOT'
  9. push:
  10. tags: # see https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet
  11. - '[0-9]+.[0-9]+.[0-9]+'
  12. - '[0-9]+.[0-9]+.[0-9]+-*'
  13. env:
  14. JAVA_VERSION: 17
  15. defaults:
  16. run:
  17. shell: bash
  18. jobs:
  19. #
  20. # Buildkit
  21. #
  22. buildkit:
  23. name: Build ${{ matrix.profile }}-buildkit
  24. runs-on: ${{ matrix.os }}
  25. strategy:
  26. fail-fast: true
  27. matrix:
  28. include:
  29. - os: ubuntu-latest
  30. profile: linux
  31. - os: windows-latest
  32. profile: win
  33. - os: macos-latest
  34. profile: mac
  35. steps:
  36. - uses: actions/checkout@v2
  37. - uses: actions/setup-java@v2
  38. with:
  39. distribution: 'temurin'
  40. java-version: ${{ env.JAVA_VERSION }}
  41. cache: 'maven'
  42. - name: Ensure to use tagged version
  43. run: mvn versions:set -DnewVersion=${GITHUB_REF##*/} # use shell parameter expansion to strip of 'refs/tags'
  44. if: startsWith(github.ref, 'refs/tags/')
  45. - name: Build and Test
  46. run: mvn -B clean package -Pdependency-check,${{ matrix.profile }}
  47. - name: Patch buildkit
  48. run: |
  49. cp LICENSE.txt target
  50. cp dist/${{ matrix.profile }}/launcher* target
  51. cp target/cryptomator-*.jar target/mods
  52. - name: Upload ${{ matrix.profile }}-buildkit
  53. uses: actions/upload-artifact@v2
  54. with:
  55. name: ${{ matrix.profile }}-buildkit
  56. path: |
  57. target/libs
  58. target/mods
  59. target/LICENSE.txt
  60. target/launcher*
  61. if-no-files-found: error
  62. #
  63. # Release Metadata
  64. #
  65. metadata:
  66. name: Determine Version Metadata
  67. runs-on: ubuntu-latest
  68. outputs:
  69. semVerNum: ${{ steps.versions.outputs.semVerNum }}
  70. semVerStr: ${{ steps.versions.outputs.semVerStr }}
  71. ppaVerStr: ${{ steps.versions.outputs.ppaVerStr }}
  72. revNum: ${{ steps.versions.outputs.revNum }}
  73. steps:
  74. - uses: actions/checkout@v2
  75. with:
  76. fetch-depth: 0
  77. - id: versions
  78. run: |
  79. if [[ $GITHUB_REF == refs/tags/* ]]; then
  80. SEM_VER_STR=${GITHUB_REF##*/}
  81. else
  82. SEM_VER_STR=${{ github.event.inputs.semver }}
  83. fi
  84. SEM_VER_NUM=`echo ${SEM_VER_STR} | sed -E 's/([0-9]+\.[0-9]+\.[0-9]+).*/\1/'`
  85. REVCOUNT=`git rev-list --count HEAD`
  86. echo "::set-output name=semVerStr::${SEM_VER_STR}"
  87. echo "::set-output name=semVerNum::${SEM_VER_NUM}"
  88. echo "::set-output name=ppaVerStr::${SEM_VER_STR/-/\~}-${REVCOUNT}"
  89. echo "::set-output name=revNum::${REVCOUNT}"
  90. - uses: skymatic/semver-validation-action@v1
  91. with:
  92. version: ${{ steps.versions.outputs.semVerStr }}
  93. #
  94. # Application Directory
  95. #
  96. appdir:
  97. name: Create ${{ matrix.profile }}-appdir
  98. needs: [buildkit, metadata]
  99. runs-on: ${{ matrix.os }}
  100. strategy:
  101. fail-fast: true
  102. matrix:
  103. include:
  104. - os: ubuntu-latest
  105. profile: linux
  106. jpackageoptions: >
  107. --app-version "${{ needs.metadata.outputs.semVerNum }}.${{ needs.metadata.outputs.revNum }}"
  108. --java-options "-Dfile.encoding=\"utf-8\""
  109. --java-options "-Dcryptomator.logDir=\"~/.local/share/Cryptomator/logs\""
  110. --java-options "-Dcryptomator.pluginDir=\"~/.local/share/Cryptomator/plugins\""
  111. --java-options "-Dcryptomator.settingsPath=\"~/.config/Cryptomator/settings.json:~/.Cryptomator/settings.json\""
  112. --java-options "-Dcryptomator.ipcSocketPath=\"~/.config/Cryptomator/ipc.socket\""
  113. --java-options "-Dcryptomator.mountPointsDir=\"~/.local/share/Cryptomator/mnt\""
  114. --java-options "-Dcryptomator.showTrayIcon=false"
  115. --java-options "-Dcryptomator.buildNumber=\"appimage-${{ needs.metadata.outputs.revNum }}\""
  116. --resource-dir dist/linux/resources
  117. - os: windows-latest
  118. profile: win
  119. jpackageoptions: >
  120. --app-version "${{ needs.metadata.outputs.semVerNum }}.${{ needs.metadata.outputs.revNum }}"
  121. --java-options "-Dfile.encoding=\"utf-8\""
  122. --java-options "-Dcryptomator.logDir=\"~/AppData/Roaming/Cryptomator\""
  123. --java-options "-Dcryptomator.pluginDir=\"~/AppData/Roaming/Cryptomator/Plugins\""
  124. --java-options "-Dcryptomator.settingsPath=\"~/AppData/Roaming/Cryptomator/settings.json\""
  125. --java-options "-Dcryptomator.ipcSocketPath=\"~/AppData/Roaming/Cryptomator/ipc.socket\""
  126. --java-options "-Dcryptomator.keychainPath=\"~/AppData/Roaming/Cryptomator/keychain.json\""
  127. --java-options "-Dcryptomator.mountPointsDir=\"~/Cryptomator\""
  128. --java-options "-Dcryptomator.showTrayIcon=true"
  129. --java-options "-Dcryptomator.buildNumber=\"msi-${{ needs.metadata.outputs.revNum }}\""
  130. --resource-dir dist/win/resources
  131. --icon dist/win/resources/Cryptomator.ico
  132. - os: macos-latest
  133. profile: mac
  134. jpackageoptions: >
  135. --app-version "${{ needs.metadata.outputs.semVerNum }}"
  136. --java-options "-Dfile.encoding=\"utf-8\""
  137. --java-options "-Dapple.awt.enableTemplateImages=true"
  138. --java-options "-Dcryptomator.logDir=\"~/Library/Logs/Cryptomator\""
  139. --java-options "-Dcryptomator.pluginDir=\"~/Library/Application Support/Cryptomator/Plugins\""
  140. --java-options "-Dcryptomator.settingsPath=\"~/Library/Application Support/Cryptomator/settings.json\""
  141. --java-options "-Dcryptomator.ipcSocketPath=\"~/Library/Application Support/Cryptomator/ipc.socket\""
  142. --java-options "-Dcryptomator.showTrayIcon=true"
  143. --java-options "-Dcryptomator.buildNumber=\"dmg-${{ needs.metadata.outputs.revNum }}\""
  144. --mac-package-identifier org.cryptomator
  145. --resource-dir dist/mac/resources
  146. steps:
  147. - uses: actions/checkout@v2
  148. - uses: actions/setup-java@v2
  149. with:
  150. distribution: 'temurin'
  151. java-version: ${{ env.JAVA_VERSION }}
  152. - name: Download ${{ matrix.profile }}-buildkit
  153. uses: actions/download-artifact@v2
  154. with:
  155. name: ${{ matrix.profile }}-buildkit
  156. path: buildkit
  157. - name: Create Runtime Image
  158. run: >
  159. ${JAVA_HOME}/bin/jlink
  160. --verbose
  161. --output runtime
  162. --module-path "${JAVA_HOME}/jmods"
  163. --add-modules java.base,java.desktop,java.logging,java.naming,java.net.http,java.scripting,java.sql,java.xml,jdk.unsupported,jdk.crypto.ec,jdk.accessibility,jdk.management.jfr
  164. --no-header-files
  165. --no-man-pages
  166. --strip-debug
  167. --compress=1
  168. - name: Create App Directory
  169. run: >
  170. ${JAVA_HOME}/bin/jpackage
  171. --verbose
  172. --type app-image
  173. --runtime-image runtime
  174. --input buildkit/libs
  175. --module-path buildkit/mods
  176. --module org.cryptomator.desktop/org.cryptomator.launcher.Cryptomator
  177. --dest appdir
  178. --name Cryptomator
  179. --vendor "Skymatic GmbH"
  180. --copyright "(C) 2016 - 2022 Skymatic GmbH"
  181. --java-options "-Xss5m"
  182. --java-options "-Xmx256m"
  183. --java-options "-Dcryptomator.appVersion=\"${{ needs.metadata.outputs.semVerStr }}\""
  184. ${{ matrix.jpackageoptions }}
  185. - name: Create appdir.tar
  186. run: tar -cvf appdir.tar appdir
  187. - name: Upload ${{ matrix.profile }}-appdir
  188. uses: actions/upload-artifact@v2
  189. with:
  190. name: ${{ matrix.profile }}-appdir
  191. path: appdir.tar
  192. if-no-files-found: error
  193. #
  194. # Debian Package
  195. #
  196. deb:
  197. name: Create Debian Package
  198. needs: [buildkit, metadata]
  199. runs-on: ubuntu-18.04
  200. steps:
  201. - uses: actions/checkout@v2
  202. - name: install build tools
  203. run: |
  204. sudo apt-get update
  205. sudo apt-get install debhelper devscripts
  206. - name: Download linux-buildkit
  207. uses: actions/download-artifact@v2
  208. with:
  209. name: linux-buildkit
  210. path: pkgdir
  211. - name: create orig.tar.gz with common/ libs/ mods/
  212. run: |
  213. cp -r dist/linux/common/ pkgdir
  214. tar -cJf cryptomator_${{ needs.metadata.outputs.ppaVerStr }}.orig.tar.xz -C pkgdir .
  215. - name: patch and rename pkgdir
  216. run: |
  217. cp -r dist/linux/debian/ pkgdir
  218. export RFC2822_TIMESTAMP=`date --rfc-2822`
  219. envsubst '${SEMVER_STR} ${VERSION_NUM} ${REVISION_NUM}' < dist/linux/debian/rules > pkgdir/debian/rules
  220. envsubst '${PPA_VERSION} ${RFC2822_TIMESTAMP}' < dist/linux/debian/changelog > pkgdir/debian/changelog
  221. find . -name "*.jar" >> pkgdir/debian/source/include-binaries
  222. mv pkgdir cryptomator_${{ needs.metadata.outputs.ppaVerStr }}
  223. env:
  224. SEMVER_STR: ${{ needs.metadata.outputs.semVerStr }}
  225. VERSION_NUM: ${{ needs.metadata.outputs.semVerNum }}
  226. REVISION_NUM: ${{ needs.metadata.outputs.revNum }}
  227. PPA_VERSION: ${{ needs.metadata.outputs.ppaVerStr }}-0ppa1
  228. - name: import gpg key 615D449FE6E6A235
  229. run: |
  230. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  231. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --dry-run --sign dist/linux/debian/rules
  232. env:
  233. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  234. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  235. - name: debuild
  236. run: |
  237. debuild -S -sa -d
  238. debuild -b -sa -d
  239. env:
  240. DEBSIGN_PROGRAM: gpg --batch --pinentry-mode loopback
  241. DEBSIGN_KEYID: 615D449FE6E6A235
  242. working-directory: cryptomator_${{ needs.metadata.outputs.ppaVerStr }}
  243. - name: Upload artifacts
  244. uses: actions/upload-artifact@v2
  245. with:
  246. name: linux-deb-package
  247. path: |
  248. cryptomator_*.dsc
  249. cryptomator_*.orig.tar.xz
  250. cryptomator_*.debian.tar.xz
  251. cryptomator_*_source.buildinfo
  252. cryptomator_*_source.changes
  253. cryptomator_*_amd64.deb
  254. #
  255. # Upload Source Package to PPA
  256. #
  257. ppa:
  258. name: Upload Source Package to PPA
  259. needs: [deb]
  260. runs-on: ubuntu-18.04
  261. steps:
  262. - name: install dput
  263. run: |
  264. sudo apt-get update
  265. sudo apt-get install dput
  266. - name: import public key
  267. run: curl -sSL ${GPG_PUBLIC_KEY_URL} | gpg --import -
  268. env:
  269. GPG_PUBLIC_KEY_URL: https://gist.githubusercontent.com/cryptobot/211111cf092037490275f39d408f461a/raw/E6E6A235.asc
  270. - name: download linux-deb-package
  271. uses: actions/download-artifact@v2
  272. with:
  273. name: linux-deb-package
  274. path: .
  275. - name: dput to beta repo
  276. run: dput ppa:sebastian-stenzel/cryptomator-beta cryptomator_*_source.changes
  277. #
  278. # Linux Cryptomator.AppImage
  279. #
  280. linux-appimage:
  281. name: Build Cryptomator.AppImage
  282. runs-on: ubuntu-latest
  283. needs: [appdir, metadata]
  284. steps:
  285. - uses: actions/checkout@v2
  286. - name: Download linux-appdir
  287. uses: actions/download-artifact@v2
  288. with:
  289. name: linux-appdir
  290. - name: Untar appdir.tar
  291. run: |
  292. tar -xvf appdir.tar
  293. - name: Patch Cryptomator.AppDir
  294. run: |
  295. mv appdir/Cryptomator Cryptomator.AppDir
  296. cp -r dist/linux/appimage/resources/AppDir/* Cryptomator.AppDir/
  297. envsubst '${REVISION_NO} ${SEMVER_STR}' < dist/linux/appimage/resources/AppDir/bin/cryptomator.sh > Cryptomator.AppDir/bin/cryptomator.sh
  298. cp dist/linux/common/org.cryptomator.Cryptomator256.png Cryptomator.AppDir/usr/share/icons/hicolor/256x256/apps/org.cryptomator.Cryptomator.png
  299. cp dist/linux/common/org.cryptomator.Cryptomator512.png Cryptomator.AppDir/usr/share/icons/hicolor/512x512/apps/org.cryptomator.Cryptomator.png
  300. cp dist/linux/common/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg
  301. cp dist/linux/common/org.cryptomator.Cryptomator.metainfo.xml Cryptomator.AppDir/usr/share/metainfo/org.cryptomator.Cryptomator.metainfo.xml
  302. cp dist/linux/common/org.cryptomator.Cryptomator.desktop Cryptomator.AppDir/usr/share/applications/org.cryptomator.Cryptomator.desktop
  303. cp dist/linux/common/application-vnd.cryptomator.vault.xml Cryptomator.AppDir/usr/share/mime/packages/application-vnd.cryptomator.vault.xml
  304. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/org.cryptomator.Cryptomator.svg
  305. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/Cryptomator.svg
  306. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/.DirIcon
  307. ln -s usr/share/applications/org.cryptomator.Cryptomator.desktop Cryptomator.AppDir/Cryptomator.desktop
  308. ln -s bin/cryptomator.sh Cryptomator.AppDir/AppRun
  309. env:
  310. REVISION_NO: ${{ needs.metadata.outputs.revNum }}
  311. SEMVER_STR: ${{ needs.metadata.outputs.semVerStr }}
  312. - name: Extract libjffi.so # workaround for https://github.com/cryptomator/cryptomator-linux/issues/27
  313. run: |
  314. JFFI_NATIVE_JAR=`ls lib/app/ | grep -e 'jffi-[1-9]\.[0-9]\{1,2\}.[0-9]\{1,2\}-native.jar'`
  315. ${JAVA_HOME}/bin/jar -xf lib/app/${JFFI_NATIVE_JAR} /jni/x86_64-Linux/
  316. mv jni/x86_64-Linux/* lib/app/libjffi.so
  317. working-directory: Cryptomator.AppDir
  318. - name: Download AppImageKit
  319. run: |
  320. curl -L https://github.com/AppImage/AppImageKit/releases/download/13/appimagetool-x86_64.AppImage -o appimagetool.AppImage
  321. chmod +x appimagetool.AppImage
  322. ./appimagetool.AppImage --appimage-extract
  323. - name: Prepare GPG-Agent for signing with key 615D449FE6E6A235
  324. run: |
  325. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  326. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --dry-run --sign Cryptomator.AppDir/AppRun
  327. env:
  328. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  329. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  330. - name: Build AppImage
  331. run: >
  332. ./squashfs-root/AppRun Cryptomator.AppDir cryptomator-${{ needs.metadata.outputs.semVerStr }}-x86_64.AppImage
  333. -u 'gh-releases-zsync|cryptomator|cryptomator|latest|cryptomator-*-x86_64.AppImage.zsync'
  334. --sign --sign-key=615D449FE6E6A235 --sign-args="--batch --pinentry-mode loopback"
  335. - name: Upload AppImage
  336. uses: actions/upload-artifact@v2
  337. with:
  338. name: linux-appimage
  339. path: |
  340. cryptomator-*.AppImage
  341. cryptomator-*.AppImage.zsync
  342. if-no-files-found: error
  343. #
  344. # macOS Cryptomator.app
  345. #
  346. mac-app:
  347. name: Build Cryptomator.app
  348. runs-on: macos-latest
  349. needs: [appdir, metadata]
  350. steps:
  351. - uses: actions/checkout@v2
  352. - name: Download mac-appdir
  353. uses: actions/download-artifact@v2
  354. with:
  355. name: mac-appdir
  356. - name: Untar appdir.tar
  357. run: tar -xvf appdir.tar
  358. - name: Patch Cryptomator.app
  359. run: |
  360. mv appdir/Cryptomator.app Cryptomator.app
  361. mv dist/mac/resources/Cryptomator-Vault.icns Cryptomator.app/Contents/Resources/
  362. sed -i '' "s|###BUNDLE_SHORT_VERSION_STRING###|${VERSION_NO}|g" Cryptomator.app/Contents/Info.plist
  363. sed -i '' "s|###BUNDLE_VERSION###|${REVISION_NO}|g" Cryptomator.app/Contents/Info.plist
  364. env:
  365. VERSION_NO: ${{ needs.metadata.outputs.semVerNum }}
  366. REVISION_NO: ${{ needs.metadata.outputs.revNum }}
  367. - name: Install codesign certificate
  368. env:
  369. CODESIGN_P12_BASE64: ${{ secrets.MACOS_CODESIGN_P12_BASE64 }}
  370. CODESIGN_P12_PW: ${{ secrets.MACOS_CODESIGN_P12_PW }}
  371. CODESIGN_TMP_KEYCHAIN_PW: ${{ secrets.MACOS_CODESIGN_TMP_KEYCHAIN_PW }}
  372. run: |
  373. # create variables
  374. CERTIFICATE_PATH=$RUNNER_TEMP/codesign.p12
  375. KEYCHAIN_PATH=$RUNNER_TEMP/codesign.keychain-db
  376. # import certificate and provisioning profile from secrets
  377. echo -n "$CODESIGN_P12_BASE64" | base64 --decode --output $CERTIFICATE_PATH
  378. # create temporary keychain
  379. security create-keychain -p "$CODESIGN_TMP_KEYCHAIN_PW" $KEYCHAIN_PATH
  380. security set-keychain-settings -lut 900 $KEYCHAIN_PATH
  381. security unlock-keychain -p "$CODESIGN_TMP_KEYCHAIN_PW" $KEYCHAIN_PATH
  382. # import certificate to keychain
  383. security import $CERTIFICATE_PATH -P "$CODESIGN_P12_PW" -A -t cert -f pkcs12 -k $KEYCHAIN_PATH
  384. security list-keychain -d user -s $KEYCHAIN_PATH
  385. - name: Codesign
  386. env:
  387. CODESIGN_IDENTITY: ${{ secrets.MACOS_CODESIGN_IDENTITY }}
  388. run: |
  389. find Cryptomator.app/Contents/runtime/Contents/MacOS -name '*.dylib' -exec codesign --force -s ${CODESIGN_IDENTITY} {} \;
  390. for JAR_PATH in `find Cryptomator.app -name "*.jar"`; do
  391. if [[ `unzip -l ${JAR_PATH} | grep '.dylib\|.jnilib'` ]]; then
  392. JAR_FILENAME=$(basename ${JAR_PATH})
  393. OUTPUT_PATH=${JAR_PATH%.*}
  394. echo "Codesigning libs in ${JAR_FILENAME}..."
  395. unzip -q ${JAR_PATH} -d ${OUTPUT_PATH}
  396. find ${OUTPUT_PATH} -name '*.dylib' -exec codesign --force -s ${CODESIGN_IDENTITY} {} \;
  397. find ${OUTPUT_PATH} -name '*.jnilib' -exec codesign --force -s ${CODESIGN_IDENTITY} {} \;
  398. rm ${JAR_PATH}
  399. pushd ${OUTPUT_PATH} > /dev/null
  400. zip -qr ../${JAR_FILENAME} *
  401. popd > /dev/null
  402. rm -r ${OUTPUT_PATH}
  403. fi
  404. done
  405. echo "Codesigning Cryptomator.app..."
  406. codesign --force --deep --entitlements dist/mac/Cryptomator.entitlements -o runtime -s ${CODESIGN_IDENTITY} Cryptomator.app
  407. - name: Clean up codesign certificate
  408. if: ${{ always() }}
  409. run: security delete-keychain $RUNNER_TEMP/codesign.keychain-db
  410. - name: Create app.tar
  411. run: tar -cvf app.tar Cryptomator.app
  412. - name: Upload mac-app
  413. uses: actions/upload-artifact@v2
  414. with:
  415. name: mac-app
  416. path: app.tar
  417. if-no-files-found: error
  418. #
  419. # macOS Cryptomator.dmg
  420. #
  421. mac-dmg:
  422. name: Build Cryptomator.dmg
  423. runs-on: macos-11
  424. needs: [mac-app, metadata]
  425. steps:
  426. - uses: actions/checkout@v2
  427. - name: Download mac-appdir
  428. uses: actions/download-artifact@v2
  429. with:
  430. name: mac-app
  431. - name: Untar app.tar
  432. run: tar -xvf app.tar
  433. - name: Prepare .dmg contents
  434. run: |
  435. mkdir dmg
  436. mv Cryptomator.app dmg
  437. cp dist/mac/dmg/resources/macFUSE.webloc dmg
  438. ls -l dmg
  439. - name: Install create-dmg
  440. run: |
  441. brew install create-dmg
  442. create-dmg --help
  443. - name: Create .dmg
  444. run: >
  445. create-dmg
  446. --volname Cryptomator
  447. --volicon "dist/mac/dmg/resources/Cryptomator-Volume.icns"
  448. --background "dist/mac/dmg/resources/Cryptomator-background.tiff"
  449. --window-pos 400 100
  450. --window-size 640 694
  451. --icon-size 128
  452. --icon "Cryptomator.app" 128 245
  453. --hide-extension "Cryptomator.app"
  454. --icon "macFUSE.webloc" 320 501
  455. --hide-extension "macFUSE.webloc"
  456. --app-drop-link 512 245
  457. --eula "dist/mac/dmg/resources/license.rtf"
  458. --icon ".background" 128 758
  459. --icon ".fseventsd" 320 758
  460. --icon ".VolumeIcon.icns" 512 758
  461. Cryptomator-${VERSION_NO}.dmg dmg
  462. env:
  463. VERSION_NO: ${{ needs.metadata.outputs.semVerNum }}
  464. - name: Install notarization credentials
  465. env:
  466. NOTARIZATION_KEYCHAIN_PROFILE: ${{ secrets.MACOS_NOTARIZATION_KEYCHAIN_PROFILE }}
  467. NOTARIZATION_APPLE_ID: ${{ secrets.MACOS_NOTARIZATION_APPLE_ID }}
  468. NOTARIZATION_PW: ${{ secrets.MACOS_NOTARIZATION_PW }}
  469. NOTARIZATION_TEAM_ID: ${{ secrets.MACOS_NOTARIZATION_TEAM_ID }}
  470. NOTARIZATION_TMP_KEYCHAIN_PW: ${{ secrets.MACOS_NOTARIZATION_TMP_KEYCHAIN_PW }}
  471. run: |
  472. # create temporary keychain
  473. KEYCHAIN_PATH=$RUNNER_TEMP/notarization.keychain-db
  474. security create-keychain -p "${NOTARIZATION_TMP_KEYCHAIN_PW}" ${KEYCHAIN_PATH}
  475. security set-keychain-settings -lut 900 ${KEYCHAIN_PATH}
  476. security unlock-keychain -p "${NOTARIZATION_TMP_KEYCHAIN_PW}" ${KEYCHAIN_PATH}
  477. # import credentials from secrets
  478. sudo xcode-select -s /Applications/Xcode_13.0.app
  479. xcrun notarytool store-credentials "${NOTARIZATION_KEYCHAIN_PROFILE}" --apple-id "${NOTARIZATION_APPLE_ID}" --password "${NOTARIZATION_PW}" --team-id "${NOTARIZATION_TEAM_ID}" --keychain "${KEYCHAIN_PATH}"
  480. - name: Notarize .dmg
  481. env:
  482. NOTARIZATION_KEYCHAIN_PROFILE: ${{ secrets.MACOS_NOTARIZATION_KEYCHAIN_PROFILE }}
  483. run: |
  484. KEYCHAIN_PATH=$RUNNER_TEMP/notarization.keychain-db
  485. sudo xcode-select -s /Applications/Xcode_13.0.app
  486. xcrun notarytool submit Cryptomator-*.dmg --keychain-profile "${NOTARIZATION_KEYCHAIN_PROFILE}" --keychain "${KEYCHAIN_PATH}" --wait
  487. xcrun stapler staple Cryptomator-*.dmg
  488. - name: Clean up notarization credentials
  489. if: ${{ always() }}
  490. run: security delete-keychain $RUNNER_TEMP/notarization.keychain-db
  491. - name: Add possible alpha/beta tags to installer name
  492. run: mv Cryptomator-*.dmg Cryptomator-${{ needs.metadata.outputs.semVerStr }}.dmg
  493. - name: Upload mac-dmg
  494. uses: actions/upload-artifact@v2
  495. with:
  496. name: mac-dmg
  497. path: Cryptomator-*.dmg
  498. if-no-files-found: error
  499. #
  500. # MSI package
  501. #
  502. win-msi:
  503. name: Build Cryptomator.msi
  504. runs-on: windows-latest
  505. needs: [appdir, metadata]
  506. steps:
  507. - uses: actions/checkout@v2
  508. - name: Download win-appdir
  509. uses: actions/download-artifact@v2
  510. with:
  511. name: win-appdir
  512. - name: Untar appdir.tar
  513. run: tar -xvf appdir.tar
  514. - uses: actions/setup-java@v2
  515. with:
  516. distribution: 'temurin'
  517. java-version: ${{ env.JAVA_VERSION }}
  518. cache: 'maven'
  519. - name: Patch Application Directory
  520. run: |
  521. cp dist/win/contrib/* appdir/Cryptomator
  522. - name: Fix permissions
  523. run: attrib -r appdir/Cryptomator/Cryptomator.exe
  524. shell: pwsh
  525. - name: Codesign
  526. uses: skymatic/code-sign-action@v1
  527. with:
  528. certificate: ${{ secrets.WIN_CODESIGN_P12_BASE64 }}
  529. password: ${{ secrets.WIN_CODESIGN_P12_PW }}
  530. certificatesha1: FF52240075AD7D14AF25629FDF69635357C7D14B
  531. description: Cryptomator
  532. timestampUrl: 'http://timestamp.digicert.com'
  533. folder: appdir/Cryptomator
  534. recursive: true
  535. - name: Generate license
  536. run: >
  537. mvn -B license:add-third-party
  538. "-Dlicense.thirdPartyFilename=license.rtf"
  539. "-Dlicense.fileTemplate=dist/win/resources/licenseTemplate.ftl"
  540. "-Dlicense.outputDirectory=dist/win/resources"
  541. - name: Create MSI
  542. run: >
  543. ${JAVA_HOME}/bin/jpackage
  544. --verbose
  545. --type msi
  546. --win-upgrade-uuid bda45523-42b1-4cae-9354-a45475ed4775
  547. --app-image appdir/Cryptomator
  548. --dest installer
  549. --name Cryptomator
  550. --vendor "Skymatic GmbH"
  551. --copyright "(C) 2016 - 2022 Skymatic GmbH"
  552. --app-version "${{ needs.metadata.outputs.semVerNum }}"
  553. --win-menu
  554. --win-dir-chooser
  555. --win-shortcut-prompt
  556. --win-update-url "https:\\cryptomator.org"
  557. --win-menu-group Cryptomator
  558. --resource-dir dist/win/resources
  559. --license-file dist/win/resources/license.rtf
  560. --file-associations dist/win/resources/FAvaultFile.properties
  561. env:
  562. JP_WIXWIZARD_RESOURCES: ${{ github.workspace }}/dist/win/resources # requires abs path, used in resources/main.wxs
  563. - name: Codesign MSI
  564. uses: skymatic/code-sign-action@v1
  565. with:
  566. certificate: ${{ secrets.WIN_CODESIGN_P12_BASE64 }}
  567. password: ${{ secrets.WIN_CODESIGN_P12_PW }}
  568. certificatesha1: FF52240075AD7D14AF25629FDF69635357C7D14B
  569. description: Cryptomator Installer
  570. timestampUrl: 'http://timestamp.digicert.com'
  571. folder: installer
  572. - name: Add possible alpha/beta tags to installer name
  573. run: mv installer/Cryptomator-*.msi installer/Cryptomator-${{ needs.metadata.outputs.semVerStr }}-x64.msi
  574. - name: Upload win-msi
  575. uses: actions/upload-artifact@v2
  576. with:
  577. name: win-msi
  578. path: installer/*.msi
  579. if-no-files-found: error
  580. #
  581. # Windows Cryptomator.exe bundle
  582. #
  583. win-exe:
  584. name: Build Cryptomator.exe bundle
  585. runs-on: windows-latest
  586. needs: [win-msi, metadata]
  587. steps:
  588. - uses: actions/checkout@v2
  589. - name: Download Windows msi
  590. uses: actions/download-artifact@v2
  591. with:
  592. name: win-msi
  593. path: dist/win/bundle/resources
  594. - name: Strip version info from msi file name
  595. run: mv dist/win/bundle/resources/Cryptomator*.msi dist/win/bundle/resources/Cryptomator.msi
  596. - uses: actions/setup-java@v2
  597. with:
  598. distribution: 'temurin'
  599. java-version: ${{ env.JAVA_VERSION }}
  600. cache: 'maven'
  601. - name: Generate license
  602. run: >
  603. mvn -B license:add-third-party
  604. "-Dlicense.thirdPartyFilename=license.rtf"
  605. "-Dlicense.fileTemplate=dist/win/bundle/resources/licenseTemplate.ftl"
  606. "-Dlicense.outputDirectory=dist/win/bundle/resources"
  607. - name: Download winfsp
  608. run:
  609. curl --output dist/win/bundle/resources/winfsp.msi -L https://github.com/billziss-gh/winfsp/releases/download/v1.10/winfsp-1.10.22006.msi
  610. - name: Compile to wixObj file
  611. run: >
  612. "${WIX}/bin/candle.exe" dist/win/bundle/bundleWithWinfsp.wxs
  613. -ext WixBalExtension
  614. -out dist/win/bundle/
  615. -dBundleVersion="${{ needs.metadata.outputs.semVerNum }}.${{ needs.metadata.outputs.revNum }}"
  616. -dBundleVendor="Skymatic GmbH"
  617. -dBundleCopyright="(C) 2016 - 2022 Skymatic GmbH"
  618. -dAboutUrl="https://cryptomator.org"
  619. -dHelpUrl="https://cryptomator.org/contact"
  620. -dUpdateUrl="https://cryptomator.org/downloads/"
  621. - name: Create executable with linker
  622. run: >
  623. "${WIX}/bin/light.exe" -b dist/win/ dist/win/bundle/bundleWithWinfsp.wixobj
  624. -ext WixBalExtension
  625. -out installer/Cryptomator.exe
  626. - name: Codesign EXE
  627. uses: skymatic/code-sign-action@v1
  628. with:
  629. certificate: ${{ secrets.WIN_CODESIGN_P12_BASE64 }}
  630. password: ${{ secrets.WIN_CODESIGN_P12_PW }}
  631. certificatesha1: FF52240075AD7D14AF25629FDF69635357C7D14B
  632. description: Cryptomator Installer
  633. timestampUrl: 'http://timestamp.digicert.com'
  634. folder: installer
  635. - name: Add possible alpha/beta tags to installer name
  636. run: mv installer/Cryptomator.exe installer/Cryptomator-${{ needs.metadata.outputs.semVerStr }}-x64.exe
  637. - name: Upload win-exe
  638. uses: actions/upload-artifact@v2
  639. with:
  640. name: win-exe
  641. path: installer/*.exe
  642. if-no-files-found: error
  643. #
  644. # Release
  645. #
  646. release:
  647. name: Draft a release on Github
  648. runs-on: ubuntu-latest
  649. needs: [metadata,linux-appimage,mac-dmg,win-msi,win-exe,ppa]
  650. if: startsWith(github.ref, 'refs/tags/') && github.repository == 'cryptomator/cryptomator'
  651. steps:
  652. - uses: actions/checkout@v2
  653. - name: Create tarball
  654. run: git archive --prefix="cryptomator-${{ needs.metadata.outputs.semVerStr }}/" -o "cryptomator-${{ needs.metadata.outputs.semVerStr }}.tar.gz" ${{ github.ref }}
  655. - name: Download Debian package
  656. uses: actions/download-artifact@v2
  657. with:
  658. name: linux-deb-package
  659. - name: Download linux appimage
  660. uses: actions/download-artifact@v2
  661. with:
  662. name: linux-appimage
  663. - name: Download macOS dmg
  664. uses: actions/download-artifact@v2
  665. with:
  666. name: mac-dmg
  667. - name: Download Windows msi
  668. uses: actions/download-artifact@v2
  669. with:
  670. name: win-msi
  671. - name: Download Windows exe
  672. uses: actions/download-artifact@v2
  673. with:
  674. name: win-exe
  675. - name: Create detached GPG signature for all release files with key 615D449FE6E6A235
  676. run: |
  677. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  678. for FILE in `find . -name "*.AppImage" -o -name "*.deb" -o -name "*.dmg" -o -name "*.exe" -o -name "*.msi" -o -name "*.zsync" -o -name "*.tar.gz"`; do
  679. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --detach-sign -a ${FILE}
  680. done
  681. env:
  682. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  683. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  684. - name: Compute SHA256 checksums of release artifacts
  685. run: |
  686. SHA256_SUMS=`find . -name "*.AppImage" -o -name "*.deb" -o -name "*.dmg" -o -name "*.exe" -o -name "*.msi" -o -name "*.tar.gz" | xargs sha256sum`
  687. echo "SHA256_SUMS<<EOF" >> $GITHUB_ENV
  688. echo "${SHA256_SUMS}" >> $GITHUB_ENV
  689. echo "EOF" >> $GITHUB_ENV
  690. continue-on-error: true
  691. - name: Create release draft
  692. uses: softprops/action-gh-release@v1
  693. with:
  694. draft: true
  695. fail_on_unmatched_files: true
  696. discussion_category_name: releases
  697. token: ${{ secrets.CRYPTOBOT_RELEASE_TOKEN }}
  698. files: |
  699. *.AppImage
  700. *.zsync
  701. *.asc
  702. *.deb
  703. *.dmg
  704. *.msi
  705. *.exe
  706. body: |-
  707. :construction: Work in Progress
  708. ## What's New
  709. ## Bugfixes
  710. ## Misc
  711. ---
  712. :scroll: A complete list of closed issues is available [here](LINK).
  713. ---
  714. :floppy_disk: SHA-256 checksums of release artifacts:
  715. ```
  716. ${{ env.SHA256_SUMS }}
  717. ```