debian.yml 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. name: Build Debian Package
  2. on:
  3. workflow_dispatch:
  4. inputs:
  5. ref:
  6. description: 'GitHub Ref (e.g. refs/tags/1.6.16)'
  7. required: true
  8. semver:
  9. description: 'SemVer String (e.g. 1.7.0-beta1)'
  10. required: true
  11. ppaver:
  12. description: 'Base PPA Version String (e.g. 1.6.16+1.7.0~beta1) without -0ppa1'
  13. required: true
  14. dput:
  15. description: 'Upload to PPA'
  16. required: true
  17. default: false
  18. type: boolean
  19. env:
  20. JAVA_VERSION: 20
  21. OPENJFX_JMODS_AMD64: 'https://download2.gluonhq.com/openjfx/20.0.1/openjfx-20.0.1_linux-x64_bin-jmods.zip'
  22. JMODS_AMD64_HASH: '0b244b08354dc5e1b639765fd0858cbc154774e9cb05467c4111b7c63d3b3721'
  23. OPENJFX_JMODS_AARCH64: 'https://download2.gluonhq.com/openjfx/20.0.1/openjfx-20.0.1_linux-aarch64_bin-jmods.zip'
  24. JMODS_AARCH64_HASH: '4b0dd30282c067aa07fe840374115b5ec5dcfd8dc479ebd2231dfdb6a518b3b3'
  25. jobs:
  26. build:
  27. name: Build Debian Package
  28. runs-on: ubuntu-20.04
  29. steps:
  30. - uses: actions/checkout@v3
  31. with:
  32. ref: ${{ inputs.ref }}
  33. fetch-depth: 0
  34. - id: versions
  35. name: Get version information
  36. run: |
  37. SEM_VER_STR="${{ inputs.semver }}"
  38. SEM_VER_NUM=`echo ${SEM_VER_STR} | sed -E 's/([0-9]+\.[0-9]+\.[0-9]+).*/\1/'`
  39. REVCOUNT=`git rev-list --count HEAD`
  40. echo "semVerStr=${SEM_VER_STR}" >> $GITHUB_OUTPUT
  41. echo "semVerNum=${SEM_VER_NUM}" >> $GITHUB_OUTPUT
  42. echo "revNum=${REVCOUNT}" >> $GITHUB_OUTPUT
  43. - name: Install build tools
  44. run: |
  45. sudo add-apt-repository ppa:coffeelibs/openjdk
  46. sudo apt-get update
  47. sudo apt-get install debhelper devscripts dput coffeelibs-jdk-19 libgtk2.0-0
  48. - name: Setup Java
  49. uses: actions/setup-java@v3
  50. with:
  51. distribution: 'zulu'
  52. java-version: ${{ env.JAVA_VERSION }}
  53. cache: 'maven'
  54. - name: Run maven
  55. run: mvn -B clean package -Pdependency-check,linux -DskipTests
  56. - name: Download OpenJFX jmods
  57. id: download-jmods
  58. run: |
  59. curl -L ${{ env.OPENJFX_JMODS_AMD64 }} -o openjfx-amd64.zip
  60. echo "${{ env.JMODS_AMD64_HASH }} openjfx-amd64.zip" | sha256sum -c
  61. if [ $? != 0 ]; then
  62. echo "Wrong checksum of JMOD archive downloaded from ${{ env.OPENJFX_JMODS_AMD64 }}.";
  63. exit 1
  64. fi
  65. mkdir -p jmods/amd64
  66. unzip -j openjfx-amd64.zip \*/javafx.base.jmod \*/javafx.controls.jmod \*/javafx.fxml.jmod \*/javafx.graphics.jmod -d jmods/amd64
  67. curl -L ${{ env.OPENJFX_JMODS_AARCH64 }} -o openjfx-aarch64.zip
  68. echo "${{ env.JMODS_AARCH64_HASH }} openjfx-aarch64.zip" | sha256sum -c
  69. if [ $? != 0 ]; then
  70. echo "Wrong checksum of JMOD archive downloaded from ${{ env.OPENJFX_JMODS_AARCH64 }}.";
  71. exit 1
  72. fi
  73. mkdir -p jmods/aarch64
  74. unzip -j openjfx-aarch64.zip \*/javafx.base.jmod \*/javafx.controls.jmod \*/javafx.fxml.jmod \*/javafx.graphics.jmod -d jmods/aarch64
  75. - name: Ensure major jfx version in pom and in jmods is the same
  76. run: |
  77. JMOD_VERSION_AMD64=$(jmod describe jmods/amd64/javafx.base.jmod | head -1)
  78. JMOD_VERSION_AMD64=${JMOD_VERSION_AMD64#*@}
  79. JMOD_VERSION_AMD64=${JMOD_VERSION_AMD64%%.*}
  80. JMOD_VERSION_AARCH64=$(jmod describe jmods/aarch64/javafx.base.jmod | head -1)
  81. JMOD_VERSION_AARCH64=${JMOD_VERSION_AARCH64#*@}
  82. JMOD_VERSION_AARCH64=${JMOD_VERSION_AARCH64%%.*}
  83. POM_JFX_VERSION=$(mvn help:evaluate "-Dexpression=javafx.version" -q -DforceStdout)
  84. POM_JFX_VERSION=${POM_JFX_VERSION#*@}
  85. POM_JFX_VERSION=${POM_JFX_VERSION%%.*}
  86. if [ $POM_JFX_VERSION -ne $JMOD_VERSION_AMD64 ]; then
  87. >&2 echo "Major JavaFX version in pom.xml (${POM_JFX_VERSION}) != amd64 jmod version (${JMOD_VERSION_AMD64})"
  88. exit 1
  89. fi
  90. if [ $POM_JFX_VERSION -ne $JMOD_VERSION_AARCH64 ]; then
  91. >&2 echo "Major JavaFX version in pom.xml (${POM_JFX_VERSION}) != aarch64 jmod version (${JMOD_VERSION_AARCH64})"
  92. exit 1
  93. fi
  94. - name: Create orig.tar.gz with common/ libs/ mods/ jmods/
  95. run: |
  96. mkdir pkgdir
  97. cp -r target/libs pkgdir
  98. cp -r target/mods pkgdir
  99. cp -r jmods pkgdir
  100. cp -r dist/linux/common/ pkgdir
  101. cp target/cryptomator-*.jar pkgdir/mods
  102. tar -cJf cryptomator_${{ inputs.ppaver }}.orig.tar.xz -C pkgdir .
  103. - name: Patch and rename pkgdir
  104. run: |
  105. cp -r dist/linux/debian/ pkgdir
  106. export RFC2822_TIMESTAMP=`date --rfc-2822`
  107. envsubst '${SEMVER_STR} ${VERSION_NUM} ${REVISION_NUM}' < dist/linux/debian/rules > pkgdir/debian/rules
  108. envsubst '${PPA_VERSION} ${RFC2822_TIMESTAMP}' < dist/linux/debian/changelog > pkgdir/debian/changelog
  109. find . -name "*.jar" >> pkgdir/debian/source/include-binaries
  110. mv pkgdir cryptomator_${{ inputs.ppaver }}
  111. env:
  112. SEMVER_STR: ${{ steps.versions.outputs.semVerStr }}
  113. VERSION_NUM: ${{ steps.versions.outputs.semVerNum }}
  114. REVISION_NUM: ${{ steps.versions.outputs.revNum }}
  115. PPA_VERSION: ${{ inputs.ppaver }}-0ppa1
  116. - name: Prepare GPG-Agent for signing with key 615D449FE6E6A235
  117. run: |
  118. echo "${GPG_PRIVATE_KEY}" | gpg --batch --quiet --import
  119. echo "${GPG_PASSPHRASE}" | gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --dry-run --sign README.md
  120. env:
  121. GPG_PRIVATE_KEY: ${{ secrets.RELEASES_GPG_PRIVATE_KEY }}
  122. GPG_PASSPHRASE: ${{ secrets.RELEASES_GPG_PASSPHRASE }}
  123. - name: debuild
  124. run: |
  125. debuild -S -sa -d
  126. debuild -b -sa -d
  127. env:
  128. DEBSIGN_PROGRAM: gpg --batch --pinentry-mode loopback
  129. DEBSIGN_KEYID: 615D449FE6E6A235
  130. working-directory: cryptomator_${{ inputs.ppaver }}
  131. - name: Create detached GPG signatures
  132. run: |
  133. gpg --batch --quiet --passphrase-fd 0 --pinentry-mode loopback -u 615D449FE6E6A235 --detach-sign -a cryptomator_*_amd64.deb
  134. - name: Upload artifacts
  135. uses: actions/upload-artifact@v3
  136. with:
  137. name: linux-deb-package
  138. path: |
  139. cryptomator_*.dsc
  140. cryptomator_*.orig.tar.xz
  141. cryptomator_*.debian.tar.xz
  142. cryptomator_*_source.buildinfo
  143. cryptomator_*_source.changes
  144. cryptomator_*_amd64.deb
  145. cryptomator_*.asc
  146. - name: Publish on PPA
  147. if: inputs.dput
  148. run: dput ppa:sebastian-stenzel/cryptomator-beta cryptomator_*_source.changes
  149. # If ref is a tag, also upload to GitHub Releases:
  150. - name: Determine tag name
  151. if: startsWith(inputs.ref, 'refs/tags/')
  152. run: |
  153. REF=${{ inputs.ref }}
  154. echo "TAG_NAME=${REF##*/}" >> $GITHUB_ENV
  155. - name: Publish Debian package on GitHub Releases
  156. if: startsWith(inputs.ref, 'refs/tags/')
  157. env:
  158. GITHUB_TOKEN: ${{ secrets.CRYPTOBOT_RELEASE_TOKEN }}
  159. run: |
  160. artifacts=$(ls | grep cryptomator*.deb)
  161. gh release upload ${{ env.TAG_NAME }} $artifacts