]> git.argeo.org Git - gpl/argeo-slc.git/blob - runtime/org.argeo.slc.repo/src/main/java/org/argeo/slc/repo/osgi/ProcessDistribution.java
d852fb623b249fe9a41312797c484b5db4a139b8
[gpl/argeo-slc.git] / runtime / org.argeo.slc.repo / src / main / java / org / argeo / slc / repo / osgi / ProcessDistribution.java
1 package org.argeo.slc.repo.osgi;
2
3 import java.util.Iterator;
4
5 import javax.jcr.RepositoryException;
6 import javax.jcr.Session;
7
8 import org.apache.commons.logging.Log;
9 import org.apache.commons.logging.LogFactory;
10 import org.argeo.jcr.JcrUtils;
11 import org.argeo.slc.CategorizedNameVersion;
12 import org.argeo.slc.NameVersion;
13 import org.argeo.slc.SlcException;
14 import org.argeo.slc.repo.ArgeoOsgiDistribution;
15 import org.argeo.slc.repo.ModularDistributionFactory;
16 import org.argeo.slc.repo.OsgiFactory;
17 import org.argeo.slc.repo.maven.MavenConventionsUtils;
18 import org.sonatype.aether.artifact.Artifact;
19 import org.sonatype.aether.util.artifact.DefaultArtifact;
20
21 /** Executes the processes required so that all managed bundles are available. */
22 public class ProcessDistribution implements Runnable {
23 private final static Log log = LogFactory.getLog(ProcessDistribution.class);
24
25 private ArgeoOsgiDistribution osgiDistribution;
26 private OsgiFactory osgiFactory;
27
28 public void run() {
29 Session javaSession = null;
30 try {
31 javaSession = osgiFactory.openJavaSession();
32
33 for (Iterator<? extends NameVersion> it = osgiDistribution
34 .nameVersions(); it.hasNext();)
35 processNameVersion(javaSession, it.next());
36
37 ModularDistributionFactory mdf = new ModularDistributionFactory(
38 javaSession, osgiDistribution);
39 mdf.run();
40 // javaSession.save();
41
42 // osgiFactory.indexNode(node);
43 // Node artifact = createDistributionArtifact(javaSession,
44 // osgiDistribution);
45
46 } catch (RepositoryException e) {
47 throw new SlcException("Cannot process distribution "
48 + osgiDistribution, e);
49 } finally {
50 JcrUtils.logoutQuietly(javaSession);
51 }
52 }
53
54 protected void processNameVersion(Session javaSession,
55 NameVersion nameVersion) throws RepositoryException {
56 if (log.isTraceEnabled())
57 log.trace("Check " + nameVersion + "...");
58 if (!(nameVersion instanceof CategorizedNameVersion))
59 throw new SlcException("Unsupported type " + nameVersion.getClass());
60 CategorizedNameVersion nv = (CategorizedNameVersion) nameVersion;
61 Artifact artifact = new DefaultArtifact(nv.getCategory(), nv.getName(),
62 "jar", nv.getVersion());
63 String path = MavenConventionsUtils.artifactPath("/", artifact);
64 if (!javaSession.itemExists(path)) {
65 if (nv instanceof BndWrapper) {
66 if (log.isDebugEnabled())
67 log.debug("Run factory for : " + nv + "...");
68 ((BndWrapper) nv).getFactory().run();
69 } else {
70 log.warn("Skip unsupported : " + nv);
71 }
72 } else {
73 if (log.isDebugEnabled())
74 log.debug("Already available : " + nv);
75 }
76 }
77
78 /* DEPENDENCY INJECTION */
79 public void setOsgiDistribution(ArgeoOsgiDistribution osgiDistribution) {
80 this.osgiDistribution = osgiDistribution;
81 }
82
83 public void setOsgiFactory(OsgiFactory osgiFactory) {
84 this.osgiFactory = osgiFactory;
85 }
86 }