https://github.com/nongfenqi/nexus3-rundeck-plugin
-
add file:
NEXUS_HOME/nexus/system/com/nongfenqi/nexus/plugin/${version}/nexus3-rundeck-plugin-${version}.jar
-
NEXUS_HOME/nexus/etc/karaf/profile.cfg
append configbundle.mvn\:com.nongfenqi.nexus.plugin/nexus3-rundeck-plugin/${version} = mvn:com.nongfenqi.nexus.plugin/nexus3-rundeck-plugin/${version}
-
NEXUS_HOME/nexus/etc/karaf/startup.properties
append configreference\:file\:com/nongfenqi/nexus/plugin/${version}/nexus3-rundeck-plugin-${version}.jar = 200
-
restart nexus3
If you installed and the bundle is activeed, like this.
Now you can add url options from the nexus3 to rundeck.
The plugin provides the following new HTTP resources :
-
http://NEXUS_HOST/service/siesta/rundeck/maven/options/version
: return a json array with the version of the matching artifacts. Parameters (all optional) :r
: repository ID to search in (null for searching in all indexed repositories)g
: groupId of the artifacts to matcha
: artifactId of the artifacts to matchp
: packaging of the artifacts to match ('jar', 'war', etc)c
: classifier of the artifacts to match ('sources', 'javadoc', etc)l
: limit - max number of results to return, default value is 10
-
http://NEXUS_HOST/service/siesta/rundeck/maven/options/content
: return artifact stream Parameters (all required) :r
: repository ID to search in (null for searching in all indexed repositories)g
: groupId of the artifacts to matcha
: artifactId of the artifacts to matchv
: artifact version, default value is latest versionc
: classifier of the artifacts to match ('sources', 'javadoc', etc)p
: packaging of the artifacts to match ('jar', 'war', etc), default value is jar
Note that if you want to retrieve the artifact from your Rundeck script, you can use content api, example is:
wget "http://NEXUS_HOST/service/siesta/rundeck/maven/options/content?r=reponame&g=${option.groupId}&a=${option.artifactId}&v=${option.version}" --content-disposition
Welcome to contribute
Welcome to contribute
- Java 1.8
- run "./gradlew jar"
You can build the plugin easily using a Docker image. With this method is not needed to install a local Gradle environment.
- docker run -it --rm --name nexus3-rundeck-plugin -v "$PWD":/tmp/nexus3-rundeck-plugin -w /tmp/nexus3-rundeck-plugin springyboing/docker-gradlew ./gradlew jar
This command run a build inside a Docker image (springyboing/docker-gradlew), with gradlew environment ready.
The following script allows you to run a Docker with Nexus 3 with nexus3-rundeck-plugin installed.
- chmod 700 run_docker.sh
- ./run_docker.sh
Nexus 3 will be running on http://localhost:8081/
The script build the plugin using a Docker image, as is explained in Using a Docker section. Using the compiled jar will build the Dockerfile and run a container with Nexus 3 with nexus3-rundeck-plugin installed.