]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.repo/src/main/java/org/argeo/slc/repo/ArtifactIndexer.java
Clean session management.
[gpl/argeo-slc.git] / runtime / org.argeo.slc.repo / src / main / java / org / argeo / slc / repo / ArtifactIndexer.java
index 183a70ad3c6bc37672d076ef8ef209dad2e16993..f62142254bb6a27e7d9cc429804d03fe6ba2ad44 100644 (file)
@@ -34,6 +34,7 @@ import org.sonatype.aether.artifact.Artifact;
  */
 public class ArtifactIndexer implements NodeIndexer {
        private Log log = LogFactory.getLog(ArtifactIndexer.class);
+       private Boolean force = false;
 
        public Boolean support(String path) {
                String relativePath = getRelativePath(path);
@@ -52,6 +53,13 @@ public class ArtifactIndexer implements NodeIndexer {
        public void index(Node fileNode) {
                Artifact artifact = null;
                try {
+                       if (!support(fileNode.getPath()))
+                               return;
+
+                       // Already indexed
+                       if (!force && fileNode.isNodeType(SlcTypes.SLC_ARTIFACT))
+                               return;
+
                        if (!fileNode.isNodeType(NodeType.NT_FILE))
                                return;
 
@@ -73,13 +81,19 @@ public class ArtifactIndexer implements NodeIndexer {
                                        artifact.getClassifier());
                        JcrUtils.updateLastModified(fileNode);
 
-                       // make sure there is a checksum
+                       // make sure there are checksums
                        String shaNodeName = fileNode.getName() + ".sha1";
                        if (!fileNode.getParent().hasNode(shaNodeName)) {
                                String sha = JcrUtils.checksumFile(fileNode, "SHA-1");
                                JcrUtils.copyBytesAsFile(fileNode.getParent(), shaNodeName,
                                                sha.getBytes());
                        }
+                       String md5NodeName = fileNode.getName() + ".md5";
+                       if (!fileNode.getParent().hasNode(md5NodeName)) {
+                               String md5 = JcrUtils.checksumFile(fileNode, "MD5");
+                               JcrUtils.copyBytesAsFile(fileNode.getParent(), md5NodeName,
+                                               md5.getBytes());
+                       }
 
                        // set higher levels
                        Node artifactVersionBase = fileNode.getParent();
@@ -139,4 +153,9 @@ public class ArtifactIndexer implements NodeIndexer {
                String relativePath = nodePath.substring(basePath.length());
                return relativePath;
        }
+
+       public void setForce(Boolean force) {
+               this.force = force;
+       }
+
 }