X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.repo%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Frepo%2FArtifactIndexer.java;h=27c6806a3e98d062c43462e5ffcf67c95f8e6dbb;hb=e548555d4b18d90d5348be941013af2adb839726;hp=f62142254bb6a27e7d9cc429804d03fe6ba2ad44;hpb=0dc6d1ec9f5b7fe454bd3ea5101f90d40163faac;p=gpl%2Fargeo-slc.git
diff --git a/runtime/org.argeo.slc.repo/src/main/java/org/argeo/slc/repo/ArtifactIndexer.java b/runtime/org.argeo.slc.repo/src/main/java/org/argeo/slc/repo/ArtifactIndexer.java
index f62142254..27c6806a3 100644
--- a/runtime/org.argeo.slc.repo/src/main/java/org/argeo/slc/repo/ArtifactIndexer.java
+++ b/runtime/org.argeo.slc.repo/src/main/java/org/argeo/slc/repo/ArtifactIndexer.java
@@ -16,6 +16,8 @@
package org.argeo.slc.repo;
import javax.jcr.Node;
+import javax.jcr.NodeIterator;
+import javax.jcr.RepositoryException;
import javax.jcr.nodetype.NodeType;
import org.apache.commons.logging.Log;
@@ -25,6 +27,7 @@ import org.argeo.slc.SlcException;
import org.argeo.slc.aether.AetherUtils;
import org.argeo.slc.jcr.SlcNames;
import org.argeo.slc.jcr.SlcTypes;
+import org.osgi.framework.Constants;
import org.sonatype.aether.artifact.Artifact;
/**
@@ -32,7 +35,7 @@ import org.sonatype.aether.artifact.Artifact;
* name doesn't start with the artifact id (in order to skip Maven metadata XML
* files and other non artifact files).
*/
-public class ArtifactIndexer implements NodeIndexer {
+public class ArtifactIndexer implements NodeIndexer, SlcNames {
private Log log = LogFactory.getLog(ArtifactIndexer.class);
private Boolean force = false;
@@ -95,6 +98,27 @@ public class ArtifactIndexer implements NodeIndexer {
md5.getBytes());
}
+ // Create a default pom if none already exist
+ String fileNodeName = fileNode.getName();
+ String pomName = null;
+ if (fileNodeName.endsWith(".jar"))
+ pomName = fileNodeName.substring(0, fileNodeName.length()
+ - ".jar".length())
+ + ".pom";
+
+ if (pomName != null && !fileNode.getParent().hasNode(pomName)) {
+ String pom = generatePomForBundle(fileNode);
+ Node pomNode = JcrUtils.copyBytesAsFile(fileNode.getParent(),
+ pomName, pom.getBytes());
+ // corresponding check sums
+ String sha = JcrUtils.checksumFile(pomNode, "SHA-1");
+ JcrUtils.copyBytesAsFile(fileNode.getParent(), pomName
+ + ".sha1", sha.getBytes());
+ String md5 = JcrUtils.checksumFile(fileNode, "MD5");
+ JcrUtils.copyBytesAsFile(fileNode.getParent(),
+ pomName + ".md5", md5.getBytes());
+ }
+
// set higher levels
Node artifactVersionBase = fileNode.getParent();
if (!artifactVersionBase
@@ -158,4 +182,90 @@ public class ArtifactIndexer implements NodeIndexer {
this.force = force;
}
-}
+ private String generatePomForBundle(Node n) throws RepositoryException {
+ StringBuffer p = new StringBuffer();
+ p.append("\n");
+ p.append("\n");
+ p.append("4.0.0");
+
+ // Categorized name version
+ p.append("").append(JcrUtils.get(n, SLC_GROUP_ID))
+ .append("\n");
+ p.append("").append(JcrUtils.get(n, SLC_ARTIFACT_ID))
+ .append("\n");
+ p.append("").append(JcrUtils.get(n, SLC_ARTIFACT_VERSION))
+ .append("\n");
+ // TODO make it more generic
+ p.append("jar\n");
+ if (n.hasProperty(SLC_ + Constants.BUNDLE_NAME))
+ p.append("")
+ .append(JcrUtils.get(n, SLC_ + Constants.BUNDLE_NAME))
+ .append("\n");
+ if (n.hasProperty(SLC_ + Constants.BUNDLE_DESCRIPTION))
+ p.append("")
+ .append(JcrUtils
+ .get(n, SLC_ + Constants.BUNDLE_DESCRIPTION))
+ .append("\n");
+
+ // Dependencies in case of a distribution
+ if (n.isNodeType(SlcTypes.SLC_MODULAR_DISTRIBUTION)) {
+ p.append(getDependenciesSnippet(n.getNode(SlcNames.SLC_MODULES)
+ .getNodes()));
+ p.append(getDependencyManagementSnippet(n.getNode(
+ SlcNames.SLC_MODULES).getNodes()));
+ }
+ p.append("\n");
+ return p.toString();
+ }
+
+ private String getDependenciesSnippet(NodeIterator nit)
+ throws RepositoryException {
+ StringBuilder b = new StringBuilder();
+ b.append("\n");
+ while (nit.hasNext()) {
+ Node currModule = nit.nextNode();
+ if (currModule.isNodeType(SlcTypes.SLC_MODULE_COORDINATES)) {
+ b.append(getDependencySnippet(
+ currModule.getProperty(SlcNames.SLC_CATEGORY)
+ .getString(),
+ currModule.getProperty(SlcNames.SLC_NAME).getString(),
+ null));
+ }
+ }
+ b.append("\n");
+ return b.toString();
+ }
+
+ private String getDependencyManagementSnippet(NodeIterator nit)
+ throws RepositoryException {
+ StringBuilder b = new StringBuilder();
+ b.append("\n");
+ b.append("\n");
+ while (nit.hasNext()) {
+ Node currModule = nit.nextNode();
+ if (currModule.isNodeType(SlcTypes.SLC_MODULE_COORDINATES)) {
+ b.append(getDependencySnippet(
+ currModule.getProperty(SlcNames.SLC_CATEGORY)
+ .getString(),
+ currModule.getProperty(SlcNames.SLC_NAME).getString(),
+ currModule.getProperty(SlcNames.SLC_VERSION)
+ .getString()));
+ }
+ }
+ b.append("\n");
+ b.append("\n");
+ return b.toString();
+ }
+
+ private String getDependencySnippet(String category, String name,
+ String version) {
+ StringBuilder b = new StringBuilder();
+ b.append("\n");
+ b.append("\t").append(category).append("\n");
+ b.append("\t").append(name).append("\n");
+ if (version != null)
+ b.append("\t").append(version).append("\n");
+ b.append("\n");
+ return b.toString();
+ }
+}
\ No newline at end of file