Skip to content

Commit

Permalink
Release to maven.
Browse files Browse the repository at this point in the history
Signed-off-by: dblock <[email protected]>
  • Loading branch information
dblock committed Jul 28, 2022
1 parent a42e97b commit 50f177a
Show file tree
Hide file tree
Showing 4 changed files with 114 additions and 142 deletions.
6 changes: 3 additions & 3 deletions java-client/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -250,12 +250,12 @@ publishing {
repositories{
if (version.toString().endsWith("SNAPSHOT")) {
maven("https://aws.oss.sonatype.org/content/repositories/snapshots/") {
name = "snapshots"
name = "snapshotRepo"
credentials(PasswordCredentials::class)
}
} else {
maven {
uri("${rootProject.buildDir}/repository")
maven("${rootProject.buildDir}/repository") {
name = "localRepo"
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion jenkins/publish-snapshot.jenkinsfile
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ pipeline {
sh './gradlew --no-daemon publishPublishMavenPublicationToSnapshotsRepository'
}
}
post() {
post {
always {
cleanWs disableDeferredWipeout: true, deleteDirs: true
}
Expand Down
110 changes: 110 additions & 0 deletions jenkins/stage-maven-release.jenkinsfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
pipeline {
agent {
docker {
label 'Jenkins-Agent-AL2-X64-C54xlarge-Docker-Host'
image 'opensearchstaging/ci-runner:ci-runner-centos7-opensearch-build-v2'
args '-e JAVA_HOME=/opt/java/openjdk-11'
alwaysPull true
}
}
environment {
VERSION = "${params.VERSION}"
ARTIFACT_PATH = "$WORKSPACE/build/repository/org/opensearch/client/opensearch-java/${VERSION}"
}
stages {
stage('parameters') {
steps {
script {
properties([
parameters([
string(
name: 'REF',
trim: true
),
string(
name: 'VERSION',
trim: true
)
])
])
if (params.REF.isEmpty() || params.VERSION.isEmpty()) {
currentBuild.result = 'ABORTED'
error('Missing REF and/or VERSION.')
}
}
}
}
stage('Publish to Maven Local') {
steps {
// checkout the commit
git url: 'https://github.com/opensearch-project/opensearch-java.git', branch: 'main'
sh('git checkout ${REF}')

// publish maven artifacts
sh('./gradlew --no-daemon publishPublishMavenPublicationToLocalRepoRepository')
}
}
stage('Sign') {
environment {
// these ENV variables are required by https://github.com/opensearch-project/opensearch-signer-client
// this client is invoked internally by the sign script
ROLE = "${SIGNER_CLIENT_ROLE}"
EXTERNAL_ID = "${SIGNER_CLIENT_EXTERNAL_ID}"
UNSIGNED_BUCKET = "${SIGNER_CLIENT_UNSIGNED_BUCKET}"
SIGNED_BUCKET = "${SIGNER_CLIENT_SIGNED_BUCKET}"
}
steps {
// fetch opensearch public key and add to keyring
sh('curl https://artifacts.opensearch.org/publickeys/opensearch.pgp -o $WORKSPACE/opensearch.pgp')
sh('gpg --import $WORKSPACE/opensearch.pgp')

// sign artifacts
git credentialsId: 'jenkins-staging-github-bot-token',
url: 'https://github.com/opensearch-project/opensearch-signer-client.git',
branch: 'main'

dir('src') {
sh ('./bootstrap')
sh('rm config.cfg')
sh('ls -d ${ARTIFACT_PATH}/* | xargs -I {} sh -c \'./opensearch-signer-client -i {} -o {}.sig -p pgp\'')

// transform the binary signature to an ascii armored file
sh("for i in `ls -d ${ARTIFACT_PATH}/*.sig`; do (cat \$i | gpg --enarmor | sed 's/ARMORED FILE/SIGNATURE/g') > \${i%%.sig}.asc; done")

// verify they are ANSI with PGP SIGNATURE
sh('ls -d ${ARTIFACT_PATH}/*.asc | xargs -I {} sh -c \'cat {} | grep PGP\'')

// verify the signatures
sh('ls -d ${ARTIFACT_PATH}/*.asc | xargs -I {} sh -c \'gpg --verify {} \'')

// remove sig files
sh('rm -f ${ARTIFACT_PATH}/*.sig')
}
}
}
stage('Stage Maven Artifacts') {
tools {
maven 'maven-3.8.2'
}
environment {
REPO_URL = 'https://aws.oss.sonatype.org/'
STAGING_PROFILE_ID = "${SONATYPE_STAGING_PROFILE_ID}"
BUILD_ID = "${BUILD_NUMBER}"
}
steps {
// checkout the build repo
git url: 'https://github.com/opensearch-project/opensearch-build.git', branch: 'main'

// stage artifacts for release with Sonatype
withCredentials([usernamePassword(credentialsId: 'Sonatype', usernameVariable: 'SONATYPE_USERNAME', passwordVariable: 'SONATYPE_PASSWORD')]) {
sh('$WORKSPACE/publish/stage-maven-release.sh $ARTIFACT_PATH')
}
}
}
}
post {
always {
cleanWs disableDeferredWipeout: true, deleteDirs: true
}
}
}
138 changes: 0 additions & 138 deletions jenkins/stage-maven-release/JenkinsFile

This file was deleted.

0 comments on commit 50f177a

Please sign in to comment.