build.yml 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. name: Build
  2. on:
  3. [push]
  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 buildkit-${{ matrix.profile }}
  41. needs: test
  42. runs-on: ${{ matrix.os }}
  43. strategy:
  44. fail-fast: true
  45. matrix:
  46. include:
  47. - os: ubuntu-latest
  48. profile: linux
  49. launcher: launcher-linux.sh
  50. - os: windows-latest
  51. profile: win
  52. launcher: launcher-win.bat
  53. - os: macOS-latest
  54. profile: mac
  55. launcher: launcher-mac.sh
  56. steps:
  57. - uses: actions/checkout@v2
  58. - uses: actions/setup-java@v1
  59. with:
  60. java-version: ${{ env.JAVA_VERSION }}
  61. - uses: actions/cache@v2
  62. with:
  63. path: ~/.m2/repository
  64. key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
  65. restore-keys: |
  66. ${{ runner.os }}-maven-
  67. - name: Copy .jar files
  68. run: mvn -B clean package -DskipTests -P${{ matrix.profile }}
  69. - name: Archive buildkit-${{ matrix.profile }}.tar.gz
  70. run: |
  71. cp LICENSE.txt target
  72. cp dist/buildkit/${{ matrix.launcher }} target
  73. cp target/cryptomator-*.jar target/mods
  74. - name: Upload buildkit-${{ matrix.profile }}
  75. uses: actions/upload-artifact@v2
  76. with:
  77. name: buildkit-${{ matrix.profile }}
  78. path: |
  79. target/libs
  80. target/mods
  81. target/LICENSE.txt
  82. target/${{ matrix.launcher }}
  83. if-no-files-found: error
  84. #
  85. # Release Metadata
  86. #
  87. metadata:
  88. name: Determine Version Metadata
  89. runs-on: ubuntu-latest
  90. needs: test
  91. outputs:
  92. versionStr: ${{ steps.versions.outputs.versionStr }}
  93. versionNum: ${{ steps.versions.outputs.versionNum }}
  94. revNum: ${{ steps.versions.outputs.revNum }}
  95. steps:
  96. - uses: actions/checkout@v2
  97. with:
  98. fetch-depth: 0
  99. - id: versions
  100. run: |
  101. if [[ $GITHUB_REF == refs/tags/* ]]; then
  102. echo "::set-output name=versionStr::${GITHUB_REF##*/}"
  103. echo "::set-output name=versionNum::${GITHUB_REF##*/}"
  104. else
  105. echo "::set-output name=versionStr::SNAPSHOT"
  106. echo "::set-output name=versionNum::99.0.0"
  107. fi
  108. echo "::set-output name=revNum::`git rev-list --count HEAD`"
  109. #
  110. # Application Directory
  111. #
  112. appdir:
  113. name: Create appdir-${{ matrix.profile }}
  114. needs: [buildkit, metadata]
  115. runs-on: ${{ matrix.os }}
  116. strategy:
  117. fail-fast: true
  118. matrix:
  119. include:
  120. - os: ubuntu-latest
  121. profile: linux
  122. jpackageoptions: >
  123. --app-version "${{ needs.metadata.outputs.versionNum }}.${{ needs.metadata.outputs.revNum }}"
  124. --java-options "-Dfile.encoding=\"utf-8\""
  125. --java-options "-Dcryptomator.logDir=\"~/.local/share/Cryptomator/logs\""
  126. --java-options "-Dcryptomator.settingsPath=\"~/.config/Cryptomator/settings.json:~/.Cryptomator/settings.json\""
  127. --java-options "-Dcryptomator.ipcSocketPath=\"~/.config/Cryptomator/ipc.socket\""
  128. --java-options "-Dcryptomator.mountPointsDir=\"~/.local/share/Cryptomator/mnt\""
  129. --java-options "-Dcryptomator.showTrayIcon=false"
  130. --java-options "-Dcryptomator.buildNumber=\"appimage-${{ needs.metadata.outputs.revNum }}\""
  131. --resource-dir dist/appdir/linux/resources
  132. - os: windows-latest
  133. profile: win
  134. jpackageoptions: >
  135. --app-version "${{ needs.metadata.outputs.versionNum }}.${{ needs.metadata.outputs.revNum }}"
  136. --java-options "-Dfile.encoding=\"utf-8\""
  137. --java-options "-Dcryptomator.logDir=\"~/AppData/Roaming/Cryptomator\""
  138. --java-options "-Dcryptomator.settingsPath=\"~/AppData/Roaming/Cryptomator/settings.json\""
  139. --java-options "-Dcryptomator.ipcSocketPath=\"~/AppData/Roaming/Cryptomator/ipc.socket\""
  140. --java-options "-Dcryptomator.keychainPath=\"~/AppData/Roaming/Cryptomator/keychain.json\""
  141. --java-options "-Dcryptomator.mountPointsDir=\"~/Cryptomator\""
  142. --java-options "-Dcryptomator.showTrayIcon=true"
  143. --java-options "-Dcryptomator.buildNumber=\"msi-${{ needs.metadata.outputs.revNum }}\""
  144. --resource-dir dist/appdir/win/resources
  145. --icon dist/appdir/win/resources/Cryptomator.ico
  146. - os: macOS-latest
  147. profile: mac
  148. jpackageoptions: >
  149. --app-version "${{ needs.metadata.outputs.versionNum }}"
  150. --java-options "-Dfile.encoding=\"utf-8\""
  151. --java-options "-Dcryptomator.logDir=\"~/Library/Logs/Cryptomator\""
  152. --java-options "-Dcryptomator.settingsPath=\"~/Library/Application Support/Cryptomator/settings.json\""
  153. --java-options "-Dcryptomator.ipcSocketPath=\"~/Library/Application Support/Cryptomator/ipc.socket\""
  154. --java-options "-Dcryptomator.showTrayIcon=true"
  155. --java-options "-Dcryptomator.buildNumber=\"dmg-${{ needs.metadata.outputs.revNum }}\""
  156. --mac-package-identifier org.cryptomator
  157. --resource-dir dist/appdir/mac/resources
  158. steps:
  159. - uses: actions/checkout@v2
  160. - uses: actions/setup-java@v1
  161. with:
  162. java-version: ${{ env.JAVA_VERSION }}
  163. - name: Download buildkit-${{ matrix.profile }}
  164. uses: actions/download-artifact@v2
  165. with:
  166. name: buildkit-${{ matrix.profile }}
  167. path: buildkit
  168. - name: Create Runtime Image
  169. run: >
  170. ${JAVA_HOME}/bin/jlink
  171. --verbose
  172. --output runtime
  173. --module-path "${JAVA_HOME}/jmods"
  174. --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
  175. --no-header-files
  176. --no-man-pages
  177. --strip-debug
  178. --compress=1
  179. - name: Create App Directory
  180. run: >
  181. ${JAVA_HOME}/bin/jpackage
  182. --verbose
  183. --type app-image
  184. --runtime-image runtime
  185. --input buildkit/libs
  186. --module-path buildkit/mods
  187. --module org.cryptomator.desktop/org.cryptomator.launcher.Cryptomator
  188. --dest appdir
  189. --name Cryptomator
  190. --vendor "Skymatic GmbH"
  191. --copyright "(C) 2016 - 2021 Skymatic GmbH"
  192. --java-options "-Xss5m"
  193. --java-options "-Xmx256m"
  194. ${{ matrix.jpackageoptions }}
  195. # TODO: patch in separate job
  196. # - name: Add Contrib Files
  197. # run: |
  198. # if [ -e dist/appdir/${{ matrix.profile }}/contrib/ ]; then
  199. # cp dist/appdir/${{ matrix.profile }}/contrib/* appdir/
  200. # fi
  201. - name: Upload appdir-${{ matrix.profile }}
  202. uses: actions/upload-artifact@v2
  203. with:
  204. name: appdir-${{ matrix.profile }}
  205. path: appdir/Cryptomator*/
  206. if-no-files-found: error
  207. #
  208. # Linux AppImage
  209. #
  210. linux-appimage:
  211. name: Build AppImage
  212. runs-on: ubuntu-latest
  213. needs: [appdir]
  214. steps:
  215. - uses: actions/checkout@v2
  216. - name: Download buildkit-linux
  217. uses: actions/download-artifact@v2
  218. with:
  219. name: appdir-linux
  220. path: Cryptomator.AppDir
  221. - name: Extract libjffi.so # workaround for https://github.com/cryptomator/cryptomator-linux/issues/27
  222. run: |
  223. JFFI_NATIVE_JAR=`ls libs/ | grep -e 'jffi-[1-9]\.[0-9]\{1,2\}.[0-9]\{1,2\}-native.jar'`
  224. ${JAVA_HOME}/bin/jar -xf libs/${JFFI_NATIVE_JAR} /jni/x86_64-Linux/
  225. mv jni/x86_64-Linux/* libs/libjffi.so
  226. working-directory: Cryptomator.AppDir
  227. - name: Patch Cryptomator.AppDir
  228. run: |
  229. cp -r dist/appimage/resources/AppDir/* Cryptomator.AppDir/
  230. chmod +x Cryptomator.AppDir/runtime/bin/java
  231. envsubst '${REVISION_NO}' < dist/appimage/resources/AppDir/bin/cryptomator.sh > Cryptomator.AppDir/bin/cryptomator.sh
  232. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/org.cryptomator.Cryptomator.svg
  233. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/Cryptomator.svg
  234. ln -s usr/share/icons/hicolor/scalable/apps/org.cryptomator.Cryptomator.svg Cryptomator.AppDir/.DirIcon
  235. ln -s usr/share/applications/org.cryptomator.Cryptomator.desktop Cryptomator.AppDir/Cryptomator.desktop
  236. ln -s bin/cryptomator.sh Cryptomator.AppDir/AppRun
  237. env:
  238. REVISION_NO: ${{ needs.metadata.outputs.revNum }}
  239. - name: Download AppImageKit
  240. run: |
  241. curl -L https://github.com/AppImage/AppImageKit/releases/download/13/appimagetool-x86_64.AppImage -o appimagetool.AppImage
  242. chmod +x appimagetool.AppImage
  243. ./appimagetool.AppImage --appimage-extract
  244. - name: Prepare GPG-Agent for signing with key 615D449FE6E6A235
  245. run: |
  246. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  247. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --dry-run --sign Cryptomator.AppDir/AppRun
  248. env:
  249. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  250. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  251. - name: Build AppImage
  252. run: >
  253. ./squashfs-root/AppRun Cryptomator.AppDir cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage
  254. -u 'gh-releases-zsync|cryptomator|cryptomator|latest|cryptomator-*-x86_64.AppImage.zsync'
  255. --sign --sign-key=615D449FE6E6A235 --sign-args="--batch --pinentry-mode loopback"
  256. - name: Create Detached GPG Signature
  257. run: |
  258. gpg --batch --quiet --pinentry-mode loopback -u 615D449FE6E6A235 --detach-sign -a cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage
  259. gpg --batch --quiet --pinentry-mode loopback -u 615D449FE6E6A235 --detach-sign -a cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage.zsync
  260. - name: Upload AppImage
  261. uses: actions/upload-artifact@v2
  262. with:
  263. name: appimage
  264. path: |
  265. cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage
  266. cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage.asc
  267. cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage.zsync
  268. cryptomator-${{ needs.metadata.outputs.versionStr }}-x86_64.AppImage.zsync.asc
  269. if-no-files-found: error
  270. # release:
  271. # name: Draft a Release on GitHub Releases
  272. # runs-on: ubuntu-latest
  273. # needs: test
  274. # if: startsWith(github.ref, 'refs/tags/') && github.repository == 'cryptomator/cryptomator'
  275. # steps:
  276. # - uses: actions/checkout@v2
  277. # - name: Download buildkit-linux.zip
  278. # uses: actions/download-artifact@v1
  279. # with:
  280. # name: buildkit-linux.zip
  281. # path: .
  282. # - name: Download buildkit-mac.zip
  283. # uses: actions/download-artifact@v1
  284. # with:
  285. # name: buildkit-mac.zip
  286. # path: .
  287. # - name: Download buildkit-win.zip
  288. # uses: actions/download-artifact@v1
  289. # with:
  290. # name: buildkit-win.zip
  291. # path: .
  292. # - name: Create tarball
  293. # run: git archive --prefix="cryptomator-${{ github.ref }}/" -o "cryptomator-${{ github.ref }}.tar.gz" ${{ github.ref }}
  294. # - name: Sign tarball with key 615D449FE6E6A235
  295. # run: |
  296. # echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  297. # echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --detach-sign -a "cryptomator-${{ github.ref }}.tar.gz"
  298. # env:
  299. # GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  300. # GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  301. # - name: Create Release
  302. # id: create_release
  303. # uses: actions/create-release@v1
  304. # env:
  305. # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  306. # with:
  307. # tag_name: ${{ github.ref }}
  308. # release_name: ${{ github.ref }}
  309. # body: |
  310. # :construction: Work in Progress
  311. # TODO:
  312. # * [ ] add Linux appimage, zsync file and signature file
  313. # * [ ] add Windows installer and signature file
  314. # * [ ] add MacOs disk image and signature file
  315. # ## What's new
  316. # ## Bugfixes
  317. # ## Misc
  318. # ---
  319. # :scroll: A complete list of closed issues is available [here](LINK)
  320. # draft: true
  321. # prerelease: false
  322. # - name: Upload buildkit-linux.zip to GitHub Releases
  323. # uses: actions/upload-release-asset@v1.0.1
  324. # env:
  325. # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  326. # with:
  327. # upload_url: ${{ steps.create_release.outputs.upload_url }}
  328. # asset_path: buildkit-linux.zip
  329. # asset_name: buildkit-linux.zip
  330. # asset_content_type: application/zip
  331. # - name: Upload buildkit-mac.zip to GitHub Releases
  332. # uses: actions/upload-release-asset@v1.0.1
  333. # env:
  334. # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  335. # with:
  336. # upload_url: ${{ steps.create_release.outputs.upload_url }}
  337. # asset_path: buildkit-mac.zip
  338. # asset_name: buildkit-mac.zip
  339. # asset_content_type: application/zip
  340. # - name: Upload buildkit-win.zip to GitHub Releases
  341. # uses: actions/upload-release-asset@v1.0.1
  342. # env:
  343. # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  344. # with:
  345. # upload_url: ${{ steps.create_release.outputs.upload_url }}
  346. # asset_path: buildkit-win.zip
  347. # asset_name: buildkit-win.zip
  348. # asset_content_type: application/zip
  349. # - name: Upload tarball signature to GitHub Releases
  350. # uses: actions/upload-release-asset@v1.0.1
  351. # env:
  352. # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  353. # with:
  354. # upload_url: ${{ steps.create_release.outputs.upload_url }}
  355. # asset_path: "cryptomator-${{ github.ref }}.tar.gz.asc"
  356. # asset_name: "cryptomator-${{ github.ref }}.tar.gz.asc"
  357. # asset_content_type: application/octet-stream