This Java library is turns binary storage (files, S3 objects, anything) into Maven repository. It
implements and can work with Maven repository structure and provides fully-functionable
mvn support in Artipie
binary repository manager service.
A dependency is identified by its coordinates - groupId, artifactId and version.
JAR files may contain a classifier suffix - sources or javadoc.
By coordinates you can determine the artifact path in local or remote repository and vice versa.
Repositories must handle following types of files:
A primary artifact - a main JAR file.
Secondary artifacts - a POM file, files with a classifier.
Attribute files - checksums, signatures, lastUpdate files for primary and secondary artifacts.
Metadata files - maven-metadata.xml, containing information about artifact versions
including snapshot versions.
File naming convention is:
artifactId-version[-classifier]-extension
Layout
(Default) naming convention is - in groupId replace all dots with directory separator ('/')
then put artifactId, version and then go files.
For example, for an artifact org.example:artifact:1.0 (Gradle-style notation is used for clarity)
the path would be org/example/artifact/1.0/artifact-1.0.jar (and other files).
Snapshot support
Maven supports the use of snapshot repositories. These repositories are used only when resolving SNAPSHOT dependencies.
SNAPSHOT dependencies are just like regular dependencies, with -SNAPSHOT appended to it:
This feature allows anyone which depends on the SNAPSHOT version get the latest changes on every build.
In the repository layout snapshots subdirectories usually contain several versions of the package,
files creation timestamps are appended to the filenames. Also, snapshots have their own maven metadata.
Upload process
On deploy maven client sends to the server package artifacts with the help of the PUT HTTP requests,
at the end of the deploy process maven client sends package metadata.
Here an example of maven request set:
PUT /com/artipie/helloworld/1.0/helloworld-1.0.jar
PUT /com/artipie/helloworld/1.0/helloworld-1.0.jar.sha1
PUT /com/artipie/helloworld/1.0/helloworld-1.0.pom
PUT /com/artipie/helloworld/1.0/helloworld-1.0.pom.sha1
GET /com/artipie/helloworld/maven-metadata.xml
PUT /com/artipie/helloworld/maven-metadata.xml
PUT /com/artipie/helloworld/maven-metadata.xml.sha1
Uploaded data are saved to the temporary upload location with the following layout:
Repository update is started when an artifact (any, nondeterministic) and package maven-metadata.xml
have the same set of checksums. On the repository update checksums are verified,
package metadata are processed and all the received artifacts are saved to the repository.
How to contribute
Fork repository, make changes, send us a pull request. We will review
your changes and apply them to the master branch shortly, provided
they don't violate our quality standards. To avoid frustration, before
sending us your pull request please run full Maven build:
$ mvn clean install -Pqulice
To avoid build errors use Maven 3.2+ and please read contributing rules.
请发表评论