- if (defaultSession == null)
- return null;
- else {
- Query groupQuery = defaultSession
- .getWorkspace()
- .getQueryManager()
- .createQuery(
- "select * from [" + SlcTypes.SLC_GROUP_BASE
- + "] as group order by group.["
- + SlcNames.SLC_GROUP_BASE_ID + "]",
- Query.JCR_SQL2);
- NodeIterator groups = groupQuery.execute().getNodes();
- while (groups.hasNext()) {
- addChild(new GroupBaseElem(WorkspaceElem.this, groups
- .nextNode()
- .getProperty(SlcNames.SLC_GROUP_BASE_ID)
- .getString()));
+ // Lazy connect the first time we retrieve children
+ if (currSession == null)
+ login();
+
+ // Retrieve already existing distribution
+ Query groupQuery = currSession
+ .getWorkspace()
+ .getQueryManager()
+ .createQuery(
+ "select * from ["
+ + SlcTypes.SLC_MODULAR_DISTRIBUTION
+ + "]", Query.JCR_SQL2);
+ NodeIterator distributions = groupQuery.execute().getNodes();
+ distribs: while (distributions.hasNext()) {
+ Node currDist = distributions.nextNode();
+ Node distBase = currDist.getParent().getParent();
+ if (!distBase.isNodeType(SlcTypes.SLC_ARTIFACT_BASE))
+ continue distribs;
+ String groupId = distBase
+ .getProperty(SlcNames.SLC_GROUP_ID).getString();
+ String artifactId = distBase.getProperty(
+ SlcNames.SLC_ARTIFACT_ID).getString();
+
+ String name;
+ String type;
+ if (ModularDistBaseElem.AETHER_BINARIES_TYPE
+ .equals(artifactId)) {
+ name = groupId;
+ type = ModularDistBaseElem.AETHER_BINARIES_TYPE;
+ } else {
+ name = artifactId;
+ type = ModularDistBaseElem.AETHER_DEP_TYPE;