# This workflow uses actions that are not certified by GitHub. # They are provided by a third-party and are governed by # separate terms of service, privacy policy, and support # documentation. # This workflow will build a package using Gradle and then publish it to GitHub packages when a release is created # For more information see: https://github.com/actions/setup-java/blob/main/docs/advanced-usage.md#Publishing-using-gradle name: Publish Packages to GitHub Packages with Gradle on: release: types: [created] jobs: build: name: Build and Publish runs-on: ubuntu-latest permissions: contents: read packages: write steps: - name: Checkout uses: actions/checkout@v4 - name: Setup GPG TTY run: export GPG_TTY=$(tty) - name: Import PGP Private Key uses: crazy-max/ghaction-import-gpg@v6.1.0 with: gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }} passphrase: ${{ secrets.GPG_PASSPHRASE }} trust_level: 5 - name: Creating PGP Ring Key run: echo ${{ secrets.GPG_PASSPHRASE }} | gpg --batch --yes --pinentry-mode loopback --passphrase-fd 0 --export-secret-keys -o gpg_key.ring - name: Restore gradle.properties env: GRADLE_PROPERTIES: ${{ secrets.GRADLE_PROPERTIES }} shell: bash run: | mkdir -p ~/.gradle/ echo "GRADLE_USER_HOME=${HOME}/.gradle" >> $GITHUB_ENV echo "${GRADLE_PROPERTIES}" > ~/.gradle/gradle.properties - name: Check gradle.properties run: cat ~/.gradle/gradle.properties - name: Set up JDK 17 uses: actions/setup-java@v4 with: java-version: '17' distribution: 'corretto' server-id: github # Value of the distributionManagement/repository/id field of the pom.xml settings-path: ${{ github.workspace }} # location for the settings.xml file - name: Setup Gradle uses: gradle/actions/setup-gradle@417ae3ccd767c252f5661f1ace9f835f9654f2b5 # v3.1.0 - name: Grant Execution Authority to Gradlew run: chmod +x ./gradlew - name: Build with Gradle run: ./gradlew build - name: Publish to Maven Central run: ./gradlew publish