Skip to content

Commit 8252ba7

Browse files
authored
Merge pull request #12 from icerockdev/maven-portal-migrate
Migrate to Maven Central Portal
2 parents 245331e + 91af452 commit 8252ba7

File tree

8 files changed

+116
-55
lines changed

8 files changed

+116
-55
lines changed

.github/workflows/distribution.yml

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -13,11 +13,19 @@ jobs:
1313
- uses: actions/setup-java@v1
1414
with:
1515
java-version: 11
16-
- name: Build and publish to mavenCentral
16+
- name: Build and publish to directory
1717
env:
1818
OSSRH_USER: ${{ secrets.OSSRH_USER }}
1919
OSSRH_KEY: ${{ secrets.OSSRH_KEY }}
2020
SIGNING_KEY_ID: ${{ secrets.SIGNING_KEYID }}
2121
SIGNING_PASSWORD: ${{ secrets.SIGNING_PASSWORD }}
2222
SIGNING_KEY: ${{ secrets.GPG_KEY_CONTENTS }}
23-
run: ./gradlew publish -PlibraryPublish
23+
run: ./gradlew jreleaserConfig build publish -PlibraryPublish
24+
- name: Publish to Maven Central Repository
25+
env:
26+
OSSRH_USER: ${{ secrets.OSSRH_USER }}
27+
OSSRH_KEY: ${{ secrets.OSSRH_KEY }}
28+
SIGNING_KEY_ID: ${{ secrets.SIGNING_KEYID }}
29+
SIGNING_PASSWORD: ${{ secrets.SIGNING_PASSWORD }}
30+
SIGNING_KEY: ${{ secrets.GPG_KEY_CONTENTS }}
31+
run: ./gradlew jreleaserFullRelease -PlibraryPublish

README.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ repositories {
88
}
99

1010
// Append dependency
11-
implementation("com.icerockdev.service:email-service:0.4.0")
11+
implementation("com.icerockdev.service:email-service:0.5.2")
1212
````
1313

1414
## Library usage

build.gradle.kts

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ allprojects {
1313
maybeCreate("provided")
1414
}
1515

16-
val copyLibsCompileTask = tasks.create("copyLibsCompile", Copy::class.java) {
16+
val copyLibsCompileTask = tasks.register("copyLibsCompile", Copy::class.java) {
1717
from(configurations["runtimeClasspath"])
1818
into(File(project.rootDir, "build/libs"))
1919
}
@@ -27,6 +27,6 @@ allprojects {
2727
}
2828
}
2929

30-
tasks.create("clean", Delete::class.java) {
31-
delete(rootProject.buildDir)
30+
tasks.register("clean", Delete::class.java) {
31+
delete(rootProject.layout.buildDirectory)
3232
}

email-service/build.gradle.kts

Lines changed: 48 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -1,28 +1,33 @@
1-
import java.util.Base64
2-
import kotlin.text.String
31
/*
42
* Copyright 2020 IceRock MAG Inc. Use of this source code is governed by the Apache 2.0 license.
53
*/
64

5+
import org.jreleaser.model.Active
6+
import java.util.Base64
7+
8+
79
plugins {
810
id("org.jetbrains.kotlin.jvm")
911
id("kotlin-kapt")
1012
id("maven-publish")
1113
id("java-library")
1214
id("signing")
15+
id("org.jreleaser") version "1.18.0"
1316
}
1417

1518
apply(plugin = "java")
1619
apply(plugin = "kotlin")
1720

1821
group = "com.icerockdev.service"
19-
version = "0.4.0"
22+
version = "0.5.2"
2023

2124
val sourcesJar by tasks.registering(Jar::class) {
2225
archiveClassifier.set("sources")
2326
from(sourceSets.main.get().allSource)
2427
}
2528

29+
val publishRepositoryName = "maven-central-portal-deploy"
30+
2631
dependencies {
2732

2833
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:${properties["coroutines_version"]}")
@@ -54,14 +59,7 @@ repositories {
5459
}
5560

5661
publishing {
57-
repositories.maven("https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/") {
58-
name = "OSSRH"
59-
60-
credentials {
61-
username = System.getenv("OSSRH_USER")
62-
password = System.getenv("OSSRH_KEY")
63-
}
64-
}
62+
repositories.maven(layout.buildDirectory.dir(publishRepositoryName))
6563
publications {
6664
register("mavenJava", MavenPublication::class) {
6765
from(components["java"])
@@ -103,16 +101,47 @@ publishing {
103101
}
104102
}
105103
}
104+
}
106105

107-
signing {
108-
setRequired({!properties.containsKey("libraryPublishToMavenLocal")})
109-
val signingKeyId: String? = System.getenv("SIGNING_KEY_ID")
110-
val signingPassword: String? = System.getenv("SIGNING_PASSWORD")
111-
val signingKey: String? = System.getenv("SIGNING_KEY")?.let { base64Key ->
112-
String(Base64.getDecoder().decode(base64Key))
106+
signing {
107+
setRequired({ !properties.containsKey("libraryPublishToMavenLocal") })
108+
val signingKeyId: String? = System.getenv("SIGNING_KEY_ID")
109+
val signingPassword: String? = System.getenv("SIGNING_PASSWORD")
110+
val signingKey: String? = System.getenv("SIGNING_KEY")?.let { base64Key ->
111+
String(Base64.getDecoder().decode(base64Key))
112+
}
113+
useInMemoryPgpKeys(signingKeyId, signingKey, signingPassword)
114+
sign(publishing.publications["mavenJava"])
115+
}
116+
}
117+
118+
jreleaser {
119+
gitRootSearch = true
120+
release {
121+
generic {
122+
skipRelease = true
123+
skipTag = true
124+
changelog {
125+
enabled = false
126+
}
127+
token = "EMPTY"
128+
}
129+
}
130+
deploy {
131+
maven {
132+
mavenCentral.create("sonatype") {
133+
enabled = !properties.containsKey("libraryPublishToMavenLocal")
134+
applyMavenCentralRules = true
135+
sign = false
136+
active = Active.ALWAYS
137+
url = "https://central.sonatype.com/api/v1/publisher"
138+
stagingRepository(layout.buildDirectory.dir(publishRepositoryName).get().toString())
139+
setAuthorization("Basic")
140+
retryDelay = 60
141+
username = System.getenv("OSSRH_USER")
142+
password = System.getenv("OSSRH_KEY")
113143
}
114-
useInMemoryPgpKeys(signingKeyId, signingKey, signingPassword)
115-
sign(publishing.publications["mavenJava"])
116144
}
117145
}
118146
}
147+

gradle/wrapper/gradle-wrapper.jar

-15.7 KB
Binary file not shown.
Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
distributionBase=GRADLE_USER_HOME
22
distributionPath=wrapper/dists
3-
distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.1-bin.zip
3+
distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-bin.zip
4+
networkTimeout=10000
5+
validateDistributionUrl=true
46
zipStoreBase=GRADLE_USER_HOME
57
zipStorePath=wrapper/dists

gradlew

Lines changed: 30 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,8 @@
1515
# See the License for the specific language governing permissions and
1616
# limitations under the License.
1717
#
18+
# SPDX-License-Identifier: Apache-2.0
19+
#
1820

1921
##############################################################################
2022
#
@@ -55,7 +57,7 @@
5557
# Darwin, MinGW, and NonStop.
5658
#
5759
# (3) This script is generated from the Groovy template
58-
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
60+
# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
5961
# within the Gradle project.
6062
#
6163
# You can find Gradle at https://github.com/gradle/gradle/.
@@ -80,13 +82,11 @@ do
8082
esac
8183
done
8284

83-
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
84-
85-
APP_NAME="Gradle"
85+
# This is normally unused
86+
# shellcheck disable=SC2034
8687
APP_BASE_NAME=${0##*/}
87-
88-
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
89-
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
88+
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
89+
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s\n' "$PWD" ) || exit
9090

9191
# Use the maximum available, or set MAX_FD != -1 to use that value.
9292
MAX_FD=maximum
@@ -133,22 +133,29 @@ location of your Java installation."
133133
fi
134134
else
135135
JAVACMD=java
136-
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
136+
if ! command -v java >/dev/null 2>&1
137+
then
138+
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
137139
138140
Please set the JAVA_HOME variable in your environment to match the
139141
location of your Java installation."
142+
fi
140143
fi
141144

142145
# Increase the maximum file descriptors if we can.
143146
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
144147
case $MAX_FD in #(
145148
max*)
149+
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
150+
# shellcheck disable=SC2039,SC3045
146151
MAX_FD=$( ulimit -H -n ) ||
147152
warn "Could not query maximum file descriptor limit"
148153
esac
149154
case $MAX_FD in #(
150155
'' | soft) :;; #(
151156
*)
157+
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
158+
# shellcheck disable=SC2039,SC3045
152159
ulimit -n "$MAX_FD" ||
153160
warn "Could not set maximum file descriptor limit to $MAX_FD"
154161
esac
@@ -193,18 +200,28 @@ if "$cygwin" || "$msys" ; then
193200
done
194201
fi
195202

196-
# Collect all arguments for the java command;
197-
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
198-
# shell script including quotes and variable substitutions, so put them in
199-
# double quotes to make sure that they get re-expanded; and
200-
# * put everything else in single quotes, so that it's not re-expanded.
203+
204+
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
205+
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
206+
207+
# Collect all arguments for the java command:
208+
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
209+
# and any embedded shellness will be escaped.
210+
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
211+
# treated as '${Hostname}' itself on the command line.
201212

202213
set -- \
203214
"-Dorg.gradle.appname=$APP_BASE_NAME" \
204215
-classpath "$CLASSPATH" \
205216
org.gradle.wrapper.GradleWrapperMain \
206217
"$@"
207218

219+
# Stop when "xargs" is not available.
220+
if ! command -v xargs >/dev/null 2>&1
221+
then
222+
die "xargs is not available"
223+
fi
224+
208225
# Use "xargs" to parse quoted args.
209226
#
210227
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.

gradlew.bat

Lines changed: 21 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -13,8 +13,10 @@
1313
@rem See the License for the specific language governing permissions and
1414
@rem limitations under the License.
1515
@rem
16+
@rem SPDX-License-Identifier: Apache-2.0
17+
@rem
1618

17-
@if "%DEBUG%" == "" @echo off
19+
@if "%DEBUG%"=="" @echo off
1820
@rem ##########################################################################
1921
@rem
2022
@rem Gradle startup script for Windows
@@ -25,7 +27,8 @@
2527
if "%OS%"=="Windows_NT" setlocal
2628

2729
set DIRNAME=%~dp0
28-
if "%DIRNAME%" == "" set DIRNAME=.
30+
if "%DIRNAME%"=="" set DIRNAME=.
31+
@rem This is normally unused
2932
set APP_BASE_NAME=%~n0
3033
set APP_HOME=%DIRNAME%
3134

@@ -40,13 +43,13 @@ if defined JAVA_HOME goto findJavaFromJavaHome
4043

4144
set JAVA_EXE=java.exe
4245
%JAVA_EXE% -version >NUL 2>&1
43-
if "%ERRORLEVEL%" == "0" goto execute
46+
if %ERRORLEVEL% equ 0 goto execute
4447

45-
echo.
46-
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
47-
echo.
48-
echo Please set the JAVA_HOME variable in your environment to match the
49-
echo location of your Java installation.
48+
echo. 1>&2
49+
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
50+
echo. 1>&2
51+
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
52+
echo location of your Java installation. 1>&2
5053

5154
goto fail
5255

@@ -56,11 +59,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
5659

5760
if exist "%JAVA_EXE%" goto execute
5861

59-
echo.
60-
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
61-
echo.
62-
echo Please set the JAVA_HOME variable in your environment to match the
63-
echo location of your Java installation.
62+
echo. 1>&2
63+
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
64+
echo. 1>&2
65+
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
66+
echo location of your Java installation. 1>&2
6467

6568
goto fail
6669

@@ -75,13 +78,15 @@ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
7578

7679
:end
7780
@rem End local scope for the variables with windows NT shell
78-
if "%ERRORLEVEL%"=="0" goto mainEnd
81+
if %ERRORLEVEL% equ 0 goto mainEnd
7982

8083
:fail
8184
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
8285
rem the _cmd.exe /c_ return code!
83-
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
84-
exit /b 1
86+
set EXIT_CODE=%ERRORLEVEL%
87+
if %EXIT_CODE% equ 0 set EXIT_CODE=1
88+
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
89+
exit /b %EXIT_CODE%
8590

8691
:mainEnd
8792
if "%OS%"=="Windows_NT" endlocal

0 commit comments

Comments
 (0)