From 24f076f570e65718014b58179b3f1b002c7d6085 Mon Sep 17 00:00:00 2001 From: Mathieu Baudier Date: Wed, 16 May 2018 13:11:56 +0200 Subject: [PATCH] Publish CNDs at once per bundle --- .../cms/internal/kernel/CmsDeployment.java | 40 ++++++++++++------- .../cms/internal/kernel/LocalRepository.java | 11 ++--- 2 files changed, 29 insertions(+), 22 deletions(-) diff --git a/org.argeo.cms/src/org/argeo/cms/internal/kernel/CmsDeployment.java b/org.argeo.cms/src/org/argeo/cms/internal/kernel/CmsDeployment.java index 33cc588a9..4d5b68e64 100644 --- a/org.argeo.cms/src/org/argeo/cms/internal/kernel/CmsDeployment.java +++ b/org.argeo.cms/src/org/argeo/cms/internal/kernel/CmsDeployment.java @@ -7,6 +7,7 @@ import java.io.InputStreamReader; import java.io.Reader; import java.lang.management.ManagementFactory; import java.net.URL; +import java.util.ArrayList; import java.util.HashSet; import java.util.Hashtable; import java.util.List; @@ -266,20 +267,27 @@ public class CmsDeployment implements NodeDeployment { for (BundleWire wire : requiredWires) { processWiring(cn, adminSession, wire.getProviderWiring(), processed); } + + List publishAsLocalRepo = new ArrayList<>(); List capabilities = wiring.getCapabilities(CMS_DATA_MODEL_NAMESPACE); for (BundleCapability capability : capabilities) { - registerDataModelCapability(cn, adminSession, capability, processed); + boolean publish = registerDataModelCapability(cn, adminSession, capability, processed); + if (publish) + publishAsLocalRepo.add((String) capability.getAttributes().get(DataModelNamespace.NAME)); } + // Publish all at once, so that bundles with multiple CNDs are consistent + for (String dataModelName : publishAsLocalRepo) + publishLocalRepo(dataModelName, adminSession.getRepository()); } - private void registerDataModelCapability(String cn, Session adminSession, BundleCapability capability, + private boolean registerDataModelCapability(String cn, Session adminSession, BundleCapability capability, Set processed) { Map attrs = capability.getAttributes(); String name = (String) attrs.get(DataModelNamespace.NAME); if (processed.contains(name)) { if (log.isTraceEnabled()) log.trace("Data model " + name + " has already been processed"); - return; + return false; } // CND @@ -304,7 +312,7 @@ public class CmsDeployment implements NodeDeployment { } if (KernelUtils.asBoolean((String) attrs.get(DataModelNamespace.ABSTRACT))) - return; + return false; // Non abstract boolean isStandalone = deployConfig.isStandalone(name); boolean publishLocalRepo; @@ -315,17 +323,19 @@ public class CmsDeployment implements NodeDeployment { else publishLocalRepo = false; - if (publishLocalRepo) { - Hashtable properties = new Hashtable<>(); - // properties.put(LEGACY_JCR_REPOSITORY_ALIAS, name); - properties.put(NodeConstants.CN, name); - if (name.equals(NodeConstants.NODE)) - properties.put(Constants.SERVICE_RANKING, Integer.MAX_VALUE); - LocalRepository localRepository = new LocalRepository(adminSession.getRepository(), capability); - bc.registerService(Repository.class, localRepository, properties); - if (log.isDebugEnabled()) - log.debug("Published data model " + name); - } + return publishLocalRepo; + } + + private void publishLocalRepo(String dataModelName, Repository repository) { + Hashtable properties = new Hashtable<>(); + // properties.put(LEGACY_JCR_REPOSITORY_ALIAS, name); + properties.put(NodeConstants.CN, dataModelName); + if (dataModelName.equals(NodeConstants.NODE)) + properties.put(Constants.SERVICE_RANKING, Integer.MAX_VALUE); + LocalRepository localRepository = new LocalRepository(repository, dataModelName); + bc.registerService(Repository.class, localRepository, properties); + if (log.isDebugEnabled()) + log.debug("Published data model " + dataModelName); } @Override diff --git a/org.argeo.cms/src/org/argeo/cms/internal/kernel/LocalRepository.java b/org.argeo.cms/src/org/argeo/cms/internal/kernel/LocalRepository.java index 6211ccd37..4356d18ff 100644 --- a/org.argeo.cms/src/org/argeo/cms/internal/kernel/LocalRepository.java +++ b/org.argeo.cms/src/org/argeo/cms/internal/kernel/LocalRepository.java @@ -1,21 +1,18 @@ package org.argeo.cms.internal.kernel; -import java.util.Map; - import javax.jcr.Repository; import org.argeo.jcr.JcrRepositoryWrapper; -import org.argeo.node.DataModelNamespace; import org.argeo.node.NodeConstants; -import org.osgi.framework.wiring.BundleCapability; class LocalRepository extends JcrRepositoryWrapper { private final String cn; - public LocalRepository(Repository repository, BundleCapability dataModelCapability) { + public LocalRepository(Repository repository, String cn) { super(repository); - Map attrs = dataModelCapability.getAttributes(); - cn = (String) attrs.get(DataModelNamespace.NAME); + this.cn = cn; + // Map attrs = dataModelCapability.getAttributes(); + // cn = (String) attrs.get(DataModelNamespace.NAME); putDescriptor(NodeConstants.CN, cn); } -- 2.30.2