Release #21
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: Release | |
on: | |
workflow_dispatch: | |
inputs: | |
releaseVersion: | |
description: "Default version to use when preparing a release." | |
required: true | |
default: "X.Y.Z" | |
developmentVersion: | |
description: "Default version to use for new local working copy." | |
required: true | |
default: "X.Y.Z-SNAPSHOT" | |
jobs: | |
release-maven: | |
runs-on: 'ubuntu-latest' | |
steps: | |
- name: Print github context | |
env: | |
GITHUB_CONTEXT: ${{ toJSON(github) }} | |
run: echo "$GITHUB_CONTEXT" | |
- name: Install wine+rpm for distribution | |
shell: bash | |
run: | | |
sudo apt-get install ppa-purge && sudo ppa-purge -y ppa:ubuntu-toolchain-r/test | |
sudo dpkg --add-architecture i386 | |
sudo mkdir -pm755 /etc/apt/keyrings && sudo wget -O /etc/apt/keyrings/winehq-archive.key https://dl.winehq.org/wine-builds/winehq.key | |
sudo wget -NP /etc/apt/sources.list.d/ https://dl.winehq.org/wine-builds/ubuntu/dists/jammy/winehq-jammy.sources | |
sudo apt-get update | |
sudo apt install --install-recommends winehq-stable | |
sudo mkdir -p /opt/wine/mono && sudo wget "https://dl.winehq.org/wine/wine-mono/8.0.0/wine-mono-8.0.0-x86.tar.xz" -P /opt/wine/mono && sudo tar -xf /opt/wine/mono/wine-mono-8.0.0-x86.tar.xz -C /opt/wine/mono && sudo rm /opt/wine/mono/wine-mono-8.0.0-x86.tar.xz | |
wine --version | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
submodules: recursive | |
- name: Set up Java for publishing to Maven Central Repository OSS | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '8' | |
distribution: 'temurin' | |
server-id: ossrh | |
server-username: MAVEN_USERNAME | |
server-password: MAVEN_PASSWORD | |
- name: Cache Maven packages | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-m2-repository-${{ hashFiles('**/pom.xml') }} | |
restore-keys: ${{ runner.os }}-m2-repository | |
- name: Install gpg secret key | |
env: | |
GPG_PRIVATE_KEY: ${{ secrets.GPG_PRIVATE_KEY }} | |
if: ${{ env.GPG_PRIVATE_KEY!=''}} | |
run: | | |
cat <(echo -e "${{ secrets.GPG_PRIVATE_KEY }}") | gpg --batch --import | |
gpg --list-secret-keys --keyid-format LONG | |
git config --global user.signingkey B02611B009E5302EB58D102D6C2EDF3C90D33841 | |
- name: Configure Git User | |
run: | | |
git config --global user.name "Open Identity Platform Community" | |
git config --global user.email "[email protected]" | |
- name: Release and publish to the Maven Central Repository | |
env: | |
GITHUB_ACTOR: ${{ github.actor }} | |
GITHUB_TOKEN: ${{ github.token }} | |
MAVEN_USERNAME: ${{ secrets.OSSRH_USERNAME }} | |
MAVEN_PASSWORD: ${{ secrets.OSSRH_TOKEN }} | |
MAVEN_OPTS: -Dhttps.protocols=TLSv1.2 -Dmaven.wagon.httpconnectionManager.ttlSeconds=120 -Dmaven.wagon.http.retryHandler.requestSentEnabled=true -Dmaven.wagon.http.retryHandler.count=10 | |
if: ${{ env.MAVEN_USERNAME!='' && env.MAVEN_PASSWORD!='' }} | |
run: mvn --batch-mode -Darguments="-Dgpg.passphrase=${{ secrets.GPG_PASSPHRASE }}" -DsignTag=true -DtagNameFormat="${{ github.event.inputs.releaseVersion }}" -DreleaseVersion=${{ github.event.inputs.releaseVersion }} -DdevelopmentVersion=${{ github.event.inputs.developmentVersion }} release:prepare release:perform --file pom.xml | |
- name: Release on GitHub | |
uses: softprops/action-gh-release@v1 | |
with: | |
name: ${{ github.event.inputs.releaseVersion }} | |
tag_name: ${{ github.event.inputs.releaseVersion }} | |
draft: false | |
prerelease: false | |
fail_on_unmatched_files: false | |
generate_release_notes: true | |
files: | | |
opendj-server-legacy/target/package/*.zip | |
opendj-ldap-toolkit/target/*.zip | |
opendj-packages/opendj-deb/opendj-deb-standard/target/*.deb | |
opendj-packages/opendj-rpm/opendj-rpm-standard/target/rpm/opendj/RPMS/noarch/*.rpm | |
opendj-packages/opendj-msi/opendj-msi-standard/target/*.msi | |
opendj-packages/opendj-docker/target/Dockerfile.zip | |
opendj-packages/opendj-openshift-template/*.yaml | |
opendj-doc-generated-ref/target/*.zip | |
opendj-dsml-servlet/target/*.war | |
opendj-rest2ldap-servlet/target/*.war | |
- uses: actions/checkout@v3 | |
continue-on-error: true | |
with: | |
repository: ${{ github.repository }}.wiki | |
path: ${{ github.event.repository.name }}.wiki | |
fetch-depth: 0 | |
- name: Publish docs in wiki | |
continue-on-error: true | |
shell: bash | |
env: | |
GITHUB_ACTOR: ${{ github.actor }} | |
GITHUB_TOKEN: ${{ github.token }} | |
run: | | |
cd ${{ github.event.repository.name }}.wiki | |
rm -rf docbkx | |
mv ../opendj-doc-generated-ref/target/docbkx ../${{ github.event.repository.name }}.wiki | |
git add -A | |
git commit -a -m "upload docs after release ${{ github.event.inputs.releaseVersion }}" | |
git tag -f ${{ github.event.inputs.releaseVersion }} | |
git push --quiet --force | |
git push --quiet --force origin ${{ github.event.inputs.releaseVersion }} | |
release-docker: | |
name: Docker release | |
runs-on: 'ubuntu-latest' | |
needs: | |
- release-maven | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
ref: ${{ github.event.inputs.releaseVersion }} | |
fetch-depth: 1 | |
submodules: recursive | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@v4 | |
with: | |
images: | | |
${{ github.repository }} | |
ghcr.io/${{ github.repository }}/${{ github.event.repository.name }} | |
tags: | | |
type=raw,value=latest | |
type=raw,value=${{ github.event.inputs.releaseVersion }} | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Login to DockerHub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Login to GHCR | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build and push image | |
uses: docker/build-push-action@v3 | |
continue-on-error: true | |
with: | |
context: ./opendj-packages/opendj-docker | |
file: ./opendj-packages/opendj-docker/Dockerfile | |
build-args: | | |
VERSION=${{ github.event.inputs.releaseVersion }} | |
platforms: linux/amd64, linux/arm64/8, linux/arm/v7, linux/ppc64le, linux/s390x | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
release-docker-alpine: | |
name: Docker release | |
runs-on: 'ubuntu-latest' | |
needs: | |
- release-maven | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
ref: ${{ github.event.inputs.releaseVersion }} | |
fetch-depth: 1 | |
submodules: recursive | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@v4 | |
with: | |
images: | | |
${{ github.repository }} | |
ghcr.io/${{ github.repository }}/${{ github.event.repository.name }} | |
tags: | | |
type=raw,value=alpine | |
type=raw,value=${{ github.event.inputs.releaseVersion }}-alpine | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Login to DockerHub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Login to GHCR | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build and push image | |
continue-on-error: true | |
uses: docker/build-push-action@v3 | |
with: | |
context: ./opendj-packages/opendj-docker | |
file: ./opendj-packages/opendj-docker/Dockerfile-alpine | |
build-args: | | |
VERSION=${{ github.event.inputs.releaseVersion }} | |
platforms: linux/amd64,linux/arm64/8, linux/s390x, linux/386, linux/arm/v7, linux/arm/v6, linux/ppc64le | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} |