Publish: manual full release #89
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: "Publish: manual full release OR automatic snapshot" | |
on: | |
workflow_dispatch: | |
inputs: | |
releaseversion: | |
description: 'Release version' | |
required: true | |
nextversion: | |
description: 'Next dev version' | |
required: true | |
jobs: | |
setup: | |
runs-on: ubuntu-latest | |
outputs: | |
# Output project version from the POM to conditionally run dependent steps | |
project-version: ${{ steps.project_version.outputs.version }} | |
steps: | |
- name: Checkout latest code | |
uses: actions/checkout@v3 | |
- name: Setup Java & Maven | |
uses: actions/setup-java@v3 | |
with: | |
java-version: 17 | |
distribution: 'temurin' | |
cache: 'maven' | |
- name: Get project version from POM | |
id: project_version | |
run: echo "VERSION=`mvn help:evaluate -Dexpression=project.version -q -DforceStdout`" >> $GITHUB_OUTPUT | |
check_vars: | |
needs: setup | |
runs-on: ubuntu-latest | |
steps: | |
- name: Show OSSRH_USERNAME | |
run: | | |
echo "Using OSSRH_USERNAME ${{ secrets.OSSRH_USERNAME }}" | |
- name: Check if OSSRH_PASSWORD is available | |
run: | | |
if [[ -z "${{ secrets.OSSRH_PASSWORD }}" ]]; then | |
echo "OSSRH_PASSWORD is not available!" | |
else | |
echo "OSSRH_PASSWORD is available." | |
fi | |
- name: Check if MAVEN_GPG_PASSPHRASE is available | |
run: | | |
if [[ -z "$MAVEN_GPG_PASSPHRASE" ]]; then | |
echo "MAVEN_GPG_PASSPHRASE is not available!" | |
else | |
echo "MAVEN_GPG_PASSPHRASE is available." | |
fi | |
env: | |
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }} | |
# - name: Sign with our MAVEN_GPG_PASSPHRASE as an env variable | |
# run: | | |
# echo "1234" | gpg --no-use-agent -o /dev/null --local-user $MAVEN_GPG_PASSPHRASE -as - | |
# echo "The correct passphrase was entered for this key" | |
# env: | |
# MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }} | |
release: | |
needs: check_vars | |
if: github.event_name == 'workflow_dispatch' | |
runs-on: ubuntu-latest | |
env: | |
RELEASE: ${{ inputs.releaseversion }} | |
NEXT: ${{ inputs.nextversion }} | |
steps: | |
- name: Checkout latest code | |
uses: actions/checkout@v3 | |
- name: Config git user | |
run: | | |
git config user.name ${{ github.actor }} | |
git config user.email "${{ github.actor }}@users.noreply.github.com" | |
- name: Setup Java & Maven | |
uses: actions/setup-java@v3 | |
with: | |
java-version: 17 | |
distribution: 'temurin' | |
cache: 'maven' | |
server-id: ossrh | |
server-username: MAVEN_USERNAME | |
server-password: MAVEN_PASSWORD | |
gpg-private-key: ${{ secrets.MAVEN_GPG_KEY }} | |
gpg-passphrase: MAVEN_GPG_PASSPHRASE | |
# ============================================================================= | |
# Start the release | |
# ============================================================================= | |
- name: Release main POM | |
run: | | |
mvn -B -U -V -ntp release:prepare -DreleaseVersion=$RELEASE -Dtag=$RELEASE -DdevelopmentVersion=$NEXT | |
mvn -B -U -V -ntp release:perform -P release | |
env: | |
MAVEN_USERNAME: ${{ secrets.OSSRH_USERNAME }} | |
MAVEN_PASSWORD: ${{ secrets.OSSRH_PASSWORD }} | |
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }} | |
- name: Build and publish new dev version | |
run: mvn -B -U -V -ntp deploy -P release | |
env: | |
MAVEN_USERNAME: ${{ secrets.OSSRH_USERNAME }} | |
MAVEN_PASSWORD: ${{ secrets.OSSRH_PASSWORD }} | |
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }} |