We're using Artifactory 3.9.2
and had to merge parts of two repositories (by copying over the artifacts) which had the same (SNAPSHOT
-versioned) artifact. This screwed up the maven-metadata.xml
. In Nexus its possible to simply rebuild the metadata for this artifact and let the repository manager sort out things for you. I can't seem to find any links/explanations on how to do this with Artifactory. Could somebody please tell me how I can do this?
I'm not sure if this is possible in the UI, but you can do it using the REST API. Try posting a request using curl
:
curl -v -X POST http://www.myartifactory.com/artifactory/api/maven/calculateMetadata/my-repository/com/foo/bar
They decided to call it "calculate metadata" instead of "rebuild metadata" which is not very suitable IMHO.
We are using artifactory 4.4.2
and I came here since the maven-metadata.xml
files were missing from folders in our artifactory where we had deployed war files manually using the REST API.
The important thing to note is that calculateMetadata
will not do anything if there are no pom.xml
files in place! (source)
Therefore, after we deployed com/company/project/art/1.0/art-1.0.war
, we needed to make a "blank" art-1.0.pom
and deploy it to the correct place.
Here's an example of a blank pom.
<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>
<groupId>com.company.project</groupId>
<artifactId>art</artifactId>
<version>1.0</version>
<description>POM was created from a script</description>
</project>
Now, the second thing we notice - once you deploy art-1.0.pom
the maven metadata is calculcated automatically (at least, for a local repo with default maven2 layout).
Therefore we didnt need to call calculateMetadata
via REST api at all - it seems to be automatic whenever you upload a pom.
pom.xml
. I mean on what will the maven-metadata.xml
be based? This is the same for all repository managers. –
Jehiah .jar
, .dll
, etc) and you can have classifiers and checksums... and the repository manager has to figure out what your artifacts really are... What the main artifact is, what the sub-artifacts are, what are checksums, archives, etc... and, while it can be implemented, you can't be sure whether or not the actual user may be doing something incorrectly, or abusing the system... So, I guess this is why repository managers are not going so far. –
Jehiah pom.xml
under META-INF/maven/${groupId}/${artifactId}/pom.xml
and you could argue that if the .pom
of the artifact is not present on the file system, then you could regenerate the maven-metadata.xml
based on the on in the META-INF
, but... if you have a massive amount of artifacts (and versions of them), this can take a lot longer than just scanning the file system directly. So... the performance could be quite bad, hence nobody's doing it like this (as far as I know)... –
Jehiah pom.xml
from META-INF
and it refers to a pom which is not available in your repos or from maven central then builds will fail! Experienced this today - so we crafted "blank" pom's with just artifactId
, groupId
, version
and a comment, and it worked fine. –
Derzon <dependencies/>
and transitive dependencies for any artifacts depending on these... Also if these are released versions and the pom
files have already been downloaded for these, then they will have to be removed from the local caches... –
Jehiah The accepted answer talks about Artifactory REST API solution, which indeed is the correct solution. But, due to proxy configured in my organization, it did not work for me. Also, I had to specify basic authentication details. So, posting the complete command that worked for me :-
curl -x http://{proxy_host}:{proxy_port} -kLu {username}:{password} -X POST https://{artifactory-link}/artifactory/api/maven/calculateMetadata/{repository-name}/{location}
This is the documentation of the REST API.
© 2022 - 2024 — McMap. All rights reserved.