From e1fd6a2700415f905a89d02eddd8d9abed5e28d5 Mon Sep 17 00:00:00 2001 From: Darius Maitia Date: Thu, 14 Nov 2024 06:31:19 -0300 Subject: [PATCH] Maven publication: adding Maven central repository (#286) * Maven publication: adding Maven central repository * Maven publication: modifying PGP references * Maven publication: align with new GPG variable naming convention --- .github/workflows/publish-android.yml | 14 ++++- .github/workflows/publish-jvm.yml | 14 ++++- zenoh-kotlin/build.gradle.kts | 80 ++++++++++++++++++++++++++- 3 files changed, 101 insertions(+), 7 deletions(-) diff --git a/.github/workflows/publish-android.yml b/.github/workflows/publish-android.yml index 1dd37a474..4e7f8f45d 100644 --- a/.github/workflows/publish-android.yml +++ b/.github/workflows/publish-android.yml @@ -70,7 +70,17 @@ jobs: echo "PUB_MODE=-PSNAPSHOT" >> $GITHUB_ENV fi - - name: Gradle Publish Android Package - run: ./gradlew publishAndroidReleasePublicationToGithubPackagesRepository -Pandroid=true ${{ env.PUB_MODE }} + - name: Gradle Publish Android Package to GitHub packages repository + run: ./gradlew publishAndroidReleasePublicationToGithubPackagesRepository -PremotePublication=true -Pandroid=true ${{ env.PUB_MODE }} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + ORG_GPG_PRIVATE_KEY: ${{ secrets.ORG_GPG_PRIVATE_KEY }} + ORG_GPG_PASSPHRASE: ${{ secrets.ORG_GPG_PASSPHRASE }} + + - name: Gradle Publish Android Package to Maven Central repository + run: ./gradlew publishAndroidReleasePublicationToMavenCentralRepository -PremotePublication=true -Pandroid=true ${{ env.PUB_MODE }} + env: + ORG_OSSRH_USERNAME: ${{ secrets.ORG_OSSRH_USERNAME }} + ORG_OSSRH_PASSWORD: ${{ secrets.ORG_OSSRH_PASSWORD }} + ORG_GPG_PRIVATE_KEY: ${{ secrets.ORG_GPG_PRIVATE_KEY }} + ORG_GPG_PASSPHRASE: ${{ secrets.ORG_GPG_PASSPHRASE }} diff --git a/.github/workflows/publish-jvm.yml b/.github/workflows/publish-jvm.yml index e34c2aaa5..68c833b31 100644 --- a/.github/workflows/publish-jvm.yml +++ b/.github/workflows/publish-jvm.yml @@ -175,7 +175,17 @@ jobs: echo "PUB_MODE=-PSNAPSHOT" >> $GITHUB_ENV fi - - name: Gradle Publish JVM Package - run: ./gradlew publishJvmPublicationToGithubPackagesRepository -PgithubPublish=true ${{ env.PUB_MODE }} + - name: Gradle Publish JVM Package to GitHub packages repository + run: ./gradlew publishJvmPublicationToGithubPackagesRepository -PremotePublication=true ${{ env.PUB_MODE }} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + ORG_GPG_PRIVATE_KEY: ${{ secrets.ORG_GPG_PRIVATE_KEY }} + ORG_GPG_PASSPHRASE: ${{ secrets.ORG_GPG_PASSPHRASE }} + + - name: Gradle Publish JVM Package to Maven Central repository + run: ./gradlew publishJvmPublicationToMavenCentralRepository -PremotePublication=true ${{ env.PUB_MODE }} + env: + ORG_OSSRH_USERNAME: ${{ secrets.ORG_OSSRH_USERNAME }} + ORG_OSSRH_PASSWORD: ${{ secrets.ORG_OSSRH_PASSWORD }} + ORG_GPG_PRIVATE_KEY: ${{ secrets.ORG_GPG_PRIVATE_KEY }} + ORG_GPG_PASSPHRASE: ${{ secrets.ORG_GPG_PASSPHRASE }} diff --git a/zenoh-kotlin/build.gradle.kts b/zenoh-kotlin/build.gradle.kts index 40eaaef6e..4b11620a6 100644 --- a/zenoh-kotlin/build.gradle.kts +++ b/zenoh-kotlin/build.gradle.kts @@ -20,11 +20,15 @@ plugins { id("com.adarshr.test-logger") id("org.jetbrains.dokka") `maven-publish` + signing } val androidEnabled = project.findProperty("android")?.toString()?.toBoolean() == true val release = project.findProperty("release")?.toString()?.toBoolean() == true -val githubPublish = project.findProperty("githubPublish")?.toString()?.toBoolean() == true + +// If the publication is meant to be done on a remote repository (GitHub packages or Maven central). +// Modifying this property will affect the release workflows! +val isRemotePublication = project.findProperty("remotePublication")?.toString()?.toBoolean() == true var buildMode = if (release) BuildMode.RELEASE else BuildMode.DEBUG @@ -79,7 +83,7 @@ kotlin { } } val jvmMain by getting { - if (githubPublish) { + if (isRemotePublication) { // The line below is intended to load the native libraries that are crosscompiled on GitHub actions when publishing a JVM package. resources.srcDir("../jni-libs").include("*/**") } else { @@ -94,7 +98,54 @@ kotlin { publishing { publications.withType { + groupId = "io.zenoh" + artifactId = "zenoh-kotlin" version = project.version.toString() + if (project.hasProperty("SNAPSHOT")) "-SNAPSHOT" else "" + + pom { + name.set("Zenoh Kotlin") + description.set("The Eclipse Zenoh: Zero Overhead Pub/sub, Store/Query and Compute.") + url.set("https://zenoh.io/") + + licenses { + license { + name.set("Eclipse Public License 2.0 OR Apache License 2.0") + url.set("http://www.eclipse.org/legal/epl-2.0") + } + } + developers { + developer { + id.set("ZettaScale") + name.set("ZettaScale Zenoh Team") + email.set("zenoh@zettascale.tech") + } + developer { + id.set("DariusIMP") + name.set("Darius Maitia") + email.set("darius@zettascale.tech") + } + developer { + id.set("Mallets") + name.set("Luca Cominardi") + email.set("luca@zettascale.tech") + } + developer { + id.set("Kydos") + name.set("Angelo Corsaro") + email.set("angelo@zettascale.tech") + } + developer { + id.set("Wyfo") + name.set("Joseph Perez") + email.set("joseph.perez@zettascale.tech") + } + } + scm { + connection.set("scm:git:https://github.com/eclipse-zenoh/zenoh-kotlin.git") + developerConnection.set("scm:git:https://github.com/eclipse-zenoh/zenoh-kotlin.git") + url.set("https://github.com/eclipse-zenoh/zenoh-kotlin") + } + } } repositories { @@ -106,9 +157,32 @@ kotlin { password = System.getenv("GITHUB_TOKEN") } } + maven { + name = "MavenCentral" + url = uri(if (project.hasProperty("SNAPSHOT")) + "https://oss.sonatype.org/content/repositories/snapshots/" + else + "https://oss.sonatype.org/service/local/staging/deploy/maven2/" + ) + credentials { + username = System.getenv("ORG_OSSRH_USERNAME") + password = System.getenv("ORG_OSSRH_PASSWORD") + } + } } } } + +signing { + isRequired = isRemotePublication + useInMemoryPgpKeys(System.getenv("ORG_GPG_PRIVATE_KEY"), System.getenv("ORG_GPG_PASSPHRASE")) + sign(publishing.publications) +} + +tasks.withType().configureEach { + dependsOn(tasks.withType()) +} + tasks.withType { doFirst { // The line below is added for the Android Unit tests which are equivalent to the JVM tests. @@ -130,7 +204,7 @@ tasks.named("compileKotlinJvm") { tasks.register("buildZenohJni") { doLast { - if (!githubPublish) { + if (!isRemotePublication) { // This is intended for local publications. For publications done through GitHub workflows, // the zenoh-jni build is achieved and loaded differently from the CI buildZenohJNI(buildMode)