build.yml 24 KB

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