release.yml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560
  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: 16
  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@v1
  38. with:
  39. java-version: ${{ env.JAVA_VERSION }}
  40. - uses: actions/cache@v2
  41. with:
  42. path: ~/.m2/repository
  43. key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
  44. restore-keys: |
  45. ${{ runner.os }}-maven-
  46. - name: Ensure to use tagged version
  47. run: mvn versions:set -DnewVersion=${GITHUB_REF##*/} # use shell parameter expansion to strip of 'refs/tags'
  48. if: startsWith(github.ref, 'refs/tags/')
  49. - name: Build and Test
  50. run: mvn -B clean package -Pdependency-check,${{ matrix.profile }}
  51. - name: Patch buildkit
  52. run: |
  53. cp LICENSE.txt target
  54. cp dist/${{ matrix.profile }}/launcher* target
  55. cp target/cryptomator-*.jar target/mods
  56. - name: Upload ${{ matrix.profile }}-buildkit
  57. uses: actions/upload-artifact@v2
  58. with:
  59. name: ${{ matrix.profile }}-buildkit
  60. path: |
  61. target/libs
  62. target/mods
  63. target/LICENSE.txt
  64. target/launcher*
  65. if-no-files-found: error
  66. #
  67. # Release Metadata
  68. #
  69. metadata:
  70. name: Determine Version Metadata
  71. runs-on: ubuntu-latest
  72. outputs:
  73. semVerNum: ${{ steps.versions.outputs.semVerNum }}
  74. semVerStr: ${{ steps.versions.outputs.semVerStr }}
  75. revNum: ${{ steps.versions.outputs.revNum }}
  76. steps:
  77. - uses: actions/checkout@v2
  78. with:
  79. fetch-depth: 0
  80. - id: versions
  81. run: |
  82. if [[ $GITHUB_REF == refs/tags/* ]]; then
  83. VERSION_NUM=`echo ${GITHUB_REF##*/} | sed -E 's/([0-9]+\.[0-9]+\.[0-9]+).*/\1/'`
  84. echo "::set-output name=semVerStr::${GITHUB_REF##*/}"
  85. echo "::set-output name=semVerNum::${VERSION_NUM}"
  86. else
  87. VERSION_NUM=`echo "${{ github.event.inputs.semver }}" | sed -E 's/([0-9]+\.[0-9]+\.[0-9]+).*/\1/'`
  88. echo "::set-output name=semVerStr::${{ github.event.inputs.semver }}"
  89. echo "::set-output name=semVerNum::${VERSION_NUM}"
  90. fi
  91. echo "::set-output name=revNum::`git rev-list --count HEAD`"
  92. #
  93. # Application Directory
  94. #
  95. appdir:
  96. name: Create ${{ matrix.profile }}-appdir
  97. needs: [buildkit, metadata]
  98. runs-on: ${{ matrix.os }}
  99. strategy:
  100. fail-fast: true
  101. matrix:
  102. include:
  103. - os: ubuntu-latest
  104. profile: linux
  105. jpackageoptions: >
  106. --app-version "${{ needs.metadata.outputs.semVerNum }}.${{ needs.metadata.outputs.revNum }}"
  107. --java-options "-Dfile.encoding=\"utf-8\""
  108. --java-options "-Dcryptomator.logDir=\"~/.local/share/Cryptomator/logs\""
  109. --java-options "-Dcryptomator.pluginDir=\"~/.local/share/Cryptomator/plugins\""
  110. --java-options "-Dcryptomator.settingsPath=\"~/.config/Cryptomator/settings.json:~/.Cryptomator/settings.json\""
  111. --java-options "-Dcryptomator.ipcSocketPath=\"~/.config/Cryptomator/ipc.socket\""
  112. --java-options "-Dcryptomator.mountPointsDir=\"~/.local/share/Cryptomator/mnt\""
  113. --java-options "-Dcryptomator.showTrayIcon=false"
  114. --java-options "-Dcryptomator.buildNumber=\"appimage-${{ needs.metadata.outputs.revNum }}\""
  115. --resource-dir dist/linux/resources
  116. - os: windows-latest
  117. profile: win
  118. jpackageoptions: >
  119. --app-version "${{ needs.metadata.outputs.semVerNum }}.${{ needs.metadata.outputs.revNum }}"
  120. --java-options "-Dfile.encoding=\"utf-8\""
  121. --java-options "-Dcryptomator.logDir=\"~/AppData/Roaming/Cryptomator\""
  122. --java-options "-Dcryptomator.pluginDir=\"~/AppData/Roaming/Cryptomator/Plugins\""
  123. --java-options "-Dcryptomator.settingsPath=\"~/AppData/Roaming/Cryptomator/settings.json\""
  124. --java-options "-Dcryptomator.ipcSocketPath=\"~/AppData/Roaming/Cryptomator/ipc.socket\""
  125. --java-options "-Dcryptomator.keychainPath=\"~/AppData/Roaming/Cryptomator/keychain.json\""
  126. --java-options "-Dcryptomator.mountPointsDir=\"~/Cryptomator\""
  127. --java-options "-Dcryptomator.showTrayIcon=true"
  128. --java-options "-Dcryptomator.buildNumber=\"msi-${{ needs.metadata.outputs.revNum }}\""
  129. --resource-dir dist/win/resources
  130. --icon dist/win/resources/Cryptomator.ico
  131. - os: macos-latest
  132. profile: mac
  133. jpackageoptions: >
  134. --app-version "${{ needs.metadata.outputs.semVerNum }}"
  135. --java-options "-Dfile.encoding=\"utf-8\""
  136. --java-options "-Dcryptomator.logDir=\"~/Library/Logs/Cryptomator\""
  137. --java-options "-Dcryptomator.pluginDir=\"~/Library/Application Support/Cryptomator/Plugins\""
  138. --java-options "-Dcryptomator.settingsPath=\"~/Library/Application Support/Cryptomator/settings.json\""
  139. --java-options "-Dcryptomator.ipcSocketPath=\"~/Library/Application Support/Cryptomator/ipc.socket\""
  140. --java-options "-Dcryptomator.showTrayIcon=true"
  141. --java-options "-Dcryptomator.buildNumber=\"dmg-${{ needs.metadata.outputs.revNum }}\""
  142. --mac-package-identifier org.cryptomator
  143. --resource-dir dist/mac/resources
  144. steps:
  145. - uses: actions/checkout@v2
  146. - uses: actions/setup-java@v1
  147. with:
  148. java-version: ${{ env.JAVA_VERSION }}
  149. - name: Download ${{ matrix.profile }}-buildkit
  150. uses: actions/download-artifact@v2
  151. with:
  152. name: ${{ matrix.profile }}-buildkit
  153. path: buildkit
  154. - name: Create Runtime Image
  155. run: >
  156. ${JAVA_HOME}/bin/jlink
  157. --verbose
  158. --output runtime
  159. --module-path "${JAVA_HOME}/jmods"
  160. --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
  161. --no-header-files
  162. --no-man-pages
  163. --strip-debug
  164. --compress=1
  165. - name: Create App Directory
  166. run: >
  167. ${JAVA_HOME}/bin/jpackage
  168. --verbose
  169. --type app-image
  170. --runtime-image runtime
  171. --input buildkit/libs
  172. --module-path buildkit/mods
  173. --module org.cryptomator.desktop/org.cryptomator.launcher.Cryptomator
  174. --dest appdir
  175. --name Cryptomator
  176. --vendor "Skymatic GmbH"
  177. --copyright "(C) 2016 - 2021 Skymatic GmbH"
  178. --java-options "-Xss5m"
  179. --java-options "-Xmx256m"
  180. --java-options "-Dcryptomator.appVersion=\"${{ needs.metadata.outputs.semVerStr }}\""
  181. ${{ matrix.jpackageoptions }}
  182. - name: Create appdir.tar
  183. run: tar -cvf appdir.tar appdir
  184. - name: Upload ${{ matrix.profile }}-appdir
  185. uses: actions/upload-artifact@v2
  186. with:
  187. name: ${{ matrix.profile }}-appdir
  188. path: appdir.tar
  189. if-no-files-found: error
  190. #
  191. # Linux Cryptomator.AppImage
  192. #
  193. linux-appimage:
  194. name: Build Cryptomator.AppImage
  195. runs-on: ubuntu-latest
  196. needs: [appdir, metadata]
  197. steps:
  198. - uses: actions/checkout@v2
  199. - name: Download linux-appdir
  200. uses: actions/download-artifact@v2
  201. with:
  202. name: linux-appdir
  203. - name: Untar appdir.tar
  204. run: |
  205. tar -xvf appdir.tar
  206. - name: Patch Cryptomator.AppDir
  207. run: |
  208. mv appdir/Cryptomator Cryptomator.AppDir
  209. cp -r dist/linux/appimage/resources/AppDir/* Cryptomator.AppDir/
  210. envsubst '${REVISION_NO}' < dist/linux/appimage/resources/AppDir/bin/cryptomator.sh > Cryptomator.AppDir/bin/cryptomator.sh
  211. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/org.cryptomator.Cryptomator.svg
  212. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/Cryptomator.svg
  213. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/.DirIcon
  214. ln -s usr/share/applications/org.cryptomator.Cryptomator.desktop Cryptomator.AppDir/Cryptomator.desktop
  215. ln -s bin/cryptomator.sh Cryptomator.AppDir/AppRun
  216. env:
  217. REVISION_NO: ${{ needs.metadata.outputs.revNum }}
  218. - name: Extract libjffi.so # workaround for https://github.com/cryptomator/cryptomator-linux/issues/27
  219. run: |
  220. JFFI_NATIVE_JAR=`ls lib/app/ | grep -e 'jffi-[1-9]\.[0-9]\{1,2\}.[0-9]\{1,2\}-native.jar'`
  221. ${JAVA_HOME}/bin/jar -xf lib/app/${JFFI_NATIVE_JAR} /jni/x86_64-Linux/
  222. mv jni/x86_64-Linux/* lib/app/libjffi.so
  223. working-directory: Cryptomator.AppDir
  224. - name: Download AppImageKit
  225. run: |
  226. curl -L https://github.com/AppImage/AppImageKit/releases/download/13/appimagetool-x86_64.AppImage -o appimagetool.AppImage
  227. chmod +x appimagetool.AppImage
  228. ./appimagetool.AppImage --appimage-extract
  229. - name: Prepare GPG-Agent for signing with key 615D449FE6E6A235
  230. run: |
  231. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  232. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --dry-run --sign Cryptomator.AppDir/AppRun
  233. env:
  234. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  235. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  236. - name: Build AppImage
  237. run: >
  238. ./squashfs-root/AppRun Cryptomator.AppDir cryptomator-${{ needs.metadata.outputs.semVerStr }}-x86_64.AppImage
  239. -u 'gh-releases-zsync|cryptomator|cryptomator|latest|cryptomator-*-x86_64.AppImage.zsync'
  240. --sign --sign-key=615D449FE6E6A235 --sign-args="--batch --pinentry-mode loopback"
  241. - name: Upload AppImage
  242. uses: actions/upload-artifact@v2
  243. with:
  244. name: linux-appimage
  245. path: |
  246. cryptomator-*.AppImage
  247. cryptomator-*.AppImage.zsync
  248. if-no-files-found: error
  249. #
  250. # macOS Cryptomator.app
  251. #
  252. mac-app:
  253. name: Build Cryptomator.app
  254. runs-on: macos-latest
  255. needs: [appdir, metadata]
  256. steps:
  257. - uses: actions/checkout@v2
  258. - name: Download mac-appdir
  259. uses: actions/download-artifact@v2
  260. with:
  261. name: mac-appdir
  262. - name: Untar appdir.tar
  263. run: tar -xvf appdir.tar
  264. - name: Patch Cryptomator.app
  265. run: |
  266. mv appdir/Cryptomator.app Cryptomator.app
  267. mv dist/mac/resources/Cryptomator-Vault.icns Cryptomator.app/Contents/Resources/
  268. sed -i '' "s|###BUNDLE_SHORT_VERSION_STRING###|${VERSION_NO}|g" Cryptomator.app/Contents/Info.plist
  269. sed -i '' "s|###BUNDLE_VERSION###|${REVISION_NO}|g" Cryptomator.app/Contents/Info.plist
  270. env:
  271. VERSION_NO: ${{ needs.metadata.outputs.semVerNum }}
  272. REVISION_NO: ${{ needs.metadata.outputs.revNum }}
  273. - name: Install codesign certificate
  274. env:
  275. CODESIGN_P12_BASE64: ${{ secrets.MACOS_CODESIGN_P12_BASE64 }}
  276. CODESIGN_P12_PW: ${{ secrets.MACOS_CODESIGN_P12_PW }}
  277. CODESIGN_TMP_KEYCHAIN_PW: ${{ secrets.MACOS_CODESIGN_TMP_KEYCHAIN_PW }}
  278. run: |
  279. # create variables
  280. CERTIFICATE_PATH=$RUNNER_TEMP/codesign.p12
  281. KEYCHAIN_PATH=$RUNNER_TEMP/codesign.keychain-db
  282. # import certificate and provisioning profile from secrets
  283. echo -n "$CODESIGN_P12_BASE64" | base64 --decode --output $CERTIFICATE_PATH
  284. # create temporary keychain
  285. security create-keychain -p "$CODESIGN_TMP_KEYCHAIN_PW" $KEYCHAIN_PATH
  286. security set-keychain-settings -lut 900 $KEYCHAIN_PATH
  287. security unlock-keychain -p "$CODESIGN_TMP_KEYCHAIN_PW" $KEYCHAIN_PATH
  288. # import certificate to keychain
  289. security import $CERTIFICATE_PATH -P "$CODESIGN_P12_PW" -A -t cert -f pkcs12 -k $KEYCHAIN_PATH
  290. security list-keychain -d user -s $KEYCHAIN_PATH
  291. - name: Codesign
  292. env:
  293. CODESIGN_IDENTITY: ${{ secrets.MACOS_CODESIGN_IDENTITY }}
  294. run: |
  295. find Cryptomator.app/Contents/runtime/Contents/MacOS -name '*.dylib' -exec codesign --force -s ${CODESIGN_IDENTITY} {} \;
  296. for JAR_PATH in `find Cryptomator.app -name "*.jar"`; do
  297. if [[ `unzip -l ${JAR_PATH} | grep '.dylib\|.jnilib'` ]]; then
  298. JAR_FILENAME=$(basename ${JAR_PATH})
  299. OUTPUT_PATH=${JAR_PATH%.*}
  300. echo "Codesigning libs in ${JAR_FILENAME}..."
  301. unzip -q ${JAR_PATH} -d ${OUTPUT_PATH}
  302. find ${OUTPUT_PATH} -name '*.dylib' -exec codesign -s ${CODESIGN_IDENTITY} {} \;
  303. find ${OUTPUT_PATH} -name '*.jnilib' -exec codesign -s ${CODESIGN_IDENTITY} {} \;
  304. rm ${JAR_PATH}
  305. pushd ${OUTPUT_PATH} > /dev/null
  306. zip -qr ../${JAR_FILENAME} *
  307. popd > /dev/null
  308. rm -r ${OUTPUT_PATH}
  309. fi
  310. done
  311. echo "Codesigning Cryptomator.app..."
  312. codesign --force --deep --entitlements dist/mac/Cryptomator.entitlements -o runtime -s ${CODESIGN_IDENTITY} Cryptomator.app
  313. - name: Clean up codesign certificate
  314. if: ${{ always() }}
  315. run: security delete-keychain $RUNNER_TEMP/codesign.keychain-db
  316. - name: Create app.tar
  317. run: tar -cvf app.tar Cryptomator.app
  318. - name: Upload mac-app
  319. uses: actions/upload-artifact@v2
  320. with:
  321. name: mac-app
  322. path: app.tar
  323. if-no-files-found: error
  324. #
  325. # macOS Cryptomator.dmg
  326. #
  327. mac-dmg:
  328. name: Build Cryptomator.dmg
  329. runs-on: macos-11
  330. needs: [mac-app, metadata]
  331. steps:
  332. - uses: actions/checkout@v2
  333. - name: Download mac-appdir
  334. uses: actions/download-artifact@v2
  335. with:
  336. name: mac-app
  337. - name: Untar app.tar
  338. run: tar -xvf app.tar
  339. - name: Prepare .dmg contents
  340. run: |
  341. mkdir dmg
  342. mv Cryptomator.app dmg
  343. cp dist/mac/dmg/resources/macFUSE.webloc dmg
  344. ls -l dmg
  345. - name: Install create-dmg
  346. run: |
  347. brew install create-dmg
  348. create-dmg --help
  349. - name: Create .dmg
  350. run: >
  351. create-dmg
  352. --volname Cryptomator
  353. --volicon "dist/mac/dmg/resources/Cryptomator-Volume.icns"
  354. --background "dist/mac/dmg/resources/Cryptomator-background.tiff"
  355. --window-pos 400 100
  356. --window-size 640 694
  357. --icon-size 128
  358. --icon "Cryptomator.app" 128 245
  359. --hide-extension "Cryptomator.app"
  360. --icon "macFUSE.webloc" 320 501
  361. --hide-extension "macFUSE.webloc"
  362. --app-drop-link 512 245
  363. --eula "dist/mac/dmg/resources/license.rtf"
  364. --icon ".background" 128 758
  365. --icon ".fseventsd" 320 758
  366. --icon ".VolumeIcon.icns" 512 758
  367. Cryptomator-${VERSION_NO}.dmg dmg
  368. env:
  369. VERSION_NO: ${{ needs.metadata.outputs.semVerNum }}
  370. - name: Install notarization credentials
  371. env:
  372. NOTARIZATION_KEYCHAIN_PROFILE: ${{ secrets.MACOS_NOTARIZATION_KEYCHAIN_PROFILE }}
  373. NOTARIZATION_APPLE_ID: ${{ secrets.MACOS_NOTARIZATION_APPLE_ID }}
  374. NOTARIZATION_PW: ${{ secrets.MACOS_NOTARIZATION_PW }}
  375. NOTARIZATION_TEAM_ID: ${{ secrets.MACOS_NOTARIZATION_TEAM_ID }}
  376. NOTARIZATION_TMP_KEYCHAIN_PW: ${{ secrets.MACOS_NOTARIZATION_TMP_KEYCHAIN_PW }}
  377. run: |
  378. # create temporary keychain
  379. KEYCHAIN_PATH=$RUNNER_TEMP/notarization.keychain-db
  380. security create-keychain -p "${NOTARIZATION_TMP_KEYCHAIN_PW}" ${KEYCHAIN_PATH}
  381. security set-keychain-settings -lut 900 ${KEYCHAIN_PATH}
  382. security unlock-keychain -p "${NOTARIZATION_TMP_KEYCHAIN_PW}" ${KEYCHAIN_PATH}
  383. # import credentials from secrets
  384. sudo xcode-select -s /Applications/Xcode_13.0.app
  385. xcrun notarytool store-credentials "${NOTARIZATION_KEYCHAIN_PROFILE}" --apple-id "${NOTARIZATION_APPLE_ID}" --password "${NOTARIZATION_PW}" --team-id "${NOTARIZATION_TEAM_ID}" --keychain "${KEYCHAIN_PATH}"
  386. - name: Notarize .dmg
  387. env:
  388. NOTARIZATION_KEYCHAIN_PROFILE: ${{ secrets.MACOS_NOTARIZATION_KEYCHAIN_PROFILE }}
  389. run: |
  390. KEYCHAIN_PATH=$RUNNER_TEMP/notarization.keychain-db
  391. sudo xcode-select -s /Applications/Xcode_13.0.app
  392. xcrun notarytool submit Cryptomator-*.dmg --keychain-profile "${NOTARIZATION_KEYCHAIN_PROFILE}" --keychain "${KEYCHAIN_PATH}" --wait
  393. xcrun stapler staple Cryptomator-*.dmg
  394. - name: Clean up notarization credentials
  395. if: ${{ always() }}
  396. run: security delete-keychain $RUNNER_TEMP/notarization.keychain-db
  397. - name: Add possible alpha/beta tags to installer name
  398. run: mv Cryptomator-*.dmg Cryptomator-${{ needs.metadata.outputs.semVerStr }}.dmg
  399. - name: Upload mac-dmg
  400. uses: actions/upload-artifact@v2
  401. with:
  402. name: mac-dmg
  403. path: Cryptomator-*.dmg
  404. if-no-files-found: error
  405. #
  406. # MSI package
  407. #
  408. win-msi:
  409. name: Build Cryptomator.msi
  410. runs-on: windows-latest
  411. needs: [appdir, metadata]
  412. steps:
  413. - uses: actions/checkout@v2
  414. - name: Download win-appdir
  415. uses: actions/download-artifact@v2
  416. with:
  417. name: win-appdir
  418. - name: Untar appdir.tar
  419. run: tar -xvf appdir.tar
  420. - uses: actions/setup-java@v1
  421. with:
  422. java-version: ${{ env.JAVA_VERSION }}
  423. - name: Patch Application Directory
  424. run: |
  425. cp dist/win/contrib/* appdir/Cryptomator
  426. - name: Fix permissions
  427. run: attrib -r appdir/Cryptomator/Cryptomator.exe
  428. shell: pwsh
  429. - name: Codesign
  430. uses: skymatic/code-sign-action@v1
  431. with:
  432. certificate: ${{ secrets.WIN_CODESIGN_P12_BASE64 }}
  433. password: ${{ secrets.WIN_CODESIGN_P12_PW }}
  434. certificatesha1: FF52240075AD7D14AF25629FDF69635357C7D14B
  435. description: Cryptomator
  436. timestampUrl: 'http://timestamp.digicert.com'
  437. folder: appdir/Cryptomator
  438. recursive: true
  439. - name: Create MSI
  440. run: >
  441. ${JAVA_HOME}/bin/jpackage
  442. --verbose
  443. --type msi
  444. --win-upgrade-uuid bda45523-42b1-4cae-9354-a45475ed4775
  445. --app-image appdir/Cryptomator
  446. --dest installer
  447. --name Cryptomator
  448. --vendor "Skymatic GmbH"
  449. --copyright "(C) 2016 - 2021 Skymatic GmbH"
  450. --app-version "${{ needs.metadata.outputs.semVerNum }}"
  451. --win-menu
  452. --win-dir-chooser
  453. --resource-dir dist/win/resources
  454. --license-file dist/win/resources/license.rtf
  455. --file-associations dist/win/resources/FAvaultFile.properties
  456. env:
  457. JP_WIXWIZARD_RESOURCES: ${{ github.workspace }}/dist/win/resources # requires abs path, used in resources/main.wxs
  458. - name: Codesign MSI
  459. uses: skymatic/code-sign-action@v1
  460. with:
  461. certificate: ${{ secrets.WIN_CODESIGN_P12_BASE64 }}
  462. password: ${{ secrets.WIN_CODESIGN_P12_PW }}
  463. certificatesha1: FF52240075AD7D14AF25629FDF69635357C7D14B
  464. description: Cryptomator Installer
  465. timestampUrl: 'http://timestamp.digicert.com'
  466. folder: installer
  467. - name: Add possible alpha/beta tags to installer name
  468. run: mv installer/Cryptomator-*.msi installer/Cryptomator-${{ needs.metadata.outputs.semVerStr }}.msi
  469. - name: Upload win-msi
  470. uses: actions/upload-artifact@v2
  471. with:
  472. name: win-msi
  473. path: installer/*.msi
  474. if-no-files-found: error
  475. #
  476. # Release
  477. #
  478. release:
  479. name: Draft a release on Github
  480. runs-on: ubuntu-latest
  481. needs: [metadata,linux-appimage,mac-dmg,win-msi]
  482. if: startsWith(github.ref, 'refs/tags/') && github.repository == 'cryptomator/cryptomator'
  483. env:
  484. APPIMAGE_SHA256_MSG: undefined
  485. DMG_SHA256_MSG: undefined
  486. MSI_SHA256_MSG: undefined
  487. steps:
  488. - uses: actions/checkout@v2
  489. - name: Create tarball
  490. run: git archive --prefix="cryptomator-${{ needs.metadata.outputs.semVerStr }}/" -o "cryptomator-${{ needs.metadata.outputs.semVerStr }}.tar.gz" ${{ github.ref }}
  491. - name: Download linux appimage
  492. uses: actions/download-artifact@v2
  493. with:
  494. name: linux-appimage
  495. - name: Download macOS dmg
  496. uses: actions/download-artifact@v2
  497. with:
  498. name: mac-dmg
  499. - name: Download Windows msi
  500. uses: actions/download-artifact@v2
  501. with:
  502. name: win-msi
  503. - name: Create detached GPG signature for all release files with key 615D449FE6E6A235
  504. run: |
  505. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  506. for FILE in `find . -name "*.AppImage" -o -name "*.dmg" -o -name "*.msi" -o -name "*.zsync" -o -name "*.tar.gz"`; do
  507. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --detach-sign -a ${FILE}
  508. done
  509. env:
  510. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  511. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  512. - name: Compute SHA256 checksums of release artifacts # sha256sum is split on the whitespace with sed and reorderd. env keys are file name extensions in uppercase
  513. run: |
  514. for FILE in `find . -name "*.AppImage" -o -name "*.dmg" -o -name "*.msi" -o -name "*.zsync" -o -name "*.tar.gz"`; do
  515. CHECKSUM_MSG=$(sha256sum ${FILE})
  516. VALUE=$(echo ${CHECKSUM_MSG} | sed 's/\([0-9,a-f]\{64\}\)[[:blank:]]\([Cc]ryptomator-.*$\)/\2: `\1`/' )
  517. KEY=$(echo ${CHECKSUM_MSG} | sed 's/.*[[:blank:]].*\.\(.*$\)/\1/')
  518. echo "{${KEY^^}_SHA256_MSG}={${VALUE}} >> $GITHUB_ENV
  519. done
  520. - name: Create release draft
  521. uses: softprops/action-gh-release@v1
  522. with:
  523. draft: true
  524. fail_on_unmatched_files: true
  525. discussion_category_name: releases
  526. token: ${{ secrets.CRYPTOBOT_RELEASE_TOKEN }}
  527. files: |
  528. *.AppImage
  529. *.zsync
  530. *.asc
  531. *.dmg
  532. *.msi
  533. body: |
  534. :construction: Work in Progress
  535. ## What's new
  536. ## Bugfixes
  537. ## Misc
  538. ---
  539. :scroll: A complete list of closed issues is available [here](LINK)
  540. ---
  541. Checksums of release artifacts:
  542. * ${{ env.APPIMAGE_SHA256_MSG}}
  543. * ${{ env.DMG_SHA256_MSG}}
  544. * ${{ env.MSI_SHA_256_MSG}}