X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fconfig%2Fconfig-manager%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fconfig%2Fmanager%2Fimpl%2Fosgi%2Fmapping%2FModuleInfoBundleTracker.java;h=1006513fe9bcf7efeff49074f57ac8f4256b8407;hp=7680f72612cd40468f3758d8030b55b6a6908afc;hb=de1885b0d6abdabf6074d251332f1919bcdb9ac6;hpb=0974e04645015a507fd88c2bc79b01c8f741462d diff --git a/opendaylight/config/config-manager/src/main/java/org/opendaylight/controller/config/manager/impl/osgi/mapping/ModuleInfoBundleTracker.java b/opendaylight/config/config-manager/src/main/java/org/opendaylight/controller/config/manager/impl/osgi/mapping/ModuleInfoBundleTracker.java index 7680f72612..1006513fe9 100644 --- a/opendaylight/config/config-manager/src/main/java/org/opendaylight/controller/config/manager/impl/osgi/mapping/ModuleInfoBundleTracker.java +++ b/opendaylight/config/config-manager/src/main/java/org/opendaylight/controller/config/manager/impl/osgi/mapping/ModuleInfoBundleTracker.java @@ -8,70 +8,93 @@ package org.opendaylight.controller.config.manager.impl.osgi.mapping; import static java.lang.String.format; - -import java.io.InputStream; +import com.google.common.base.Charsets; +import com.google.common.io.Resources; +import java.io.IOException; import java.net.URL; import java.util.Collection; import java.util.LinkedList; import java.util.List; - -import org.apache.commons.io.IOUtils; import org.opendaylight.yangtools.concepts.ObjectRegistration; -import org.opendaylight.yangtools.sal.binding.generator.impl.GeneratedClassLoadingStrategy; -import org.opendaylight.yangtools.sal.binding.generator.impl.ModuleInfoBackedContext; import org.opendaylight.yangtools.yang.binding.YangModelBindingProvider; import org.opendaylight.yangtools.yang.binding.YangModuleInfo; import org.osgi.framework.Bundle; +import org.osgi.framework.BundleContext; import org.osgi.framework.BundleEvent; +import org.osgi.util.tracker.BundleTracker; import org.osgi.util.tracker.BundleTrackerCustomizer; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** - * Tracks bundles and attempts to retrieve YangModuleInfo. + * Tracks bundles and attempts to retrieve YangModuleInfo, which is then fed into ModuleInfoRegistry */ -public final class ModuleInfoBundleTracker implements BundleTrackerCustomizer>> { +public final class ModuleInfoBundleTracker implements AutoCloseable, + BundleTrackerCustomizer>> { - private static final Logger logger = LoggerFactory.getLogger(ModuleInfoBundleTracker.class); - public static final String GET_MODULE_INFO_METHOD = "getModuleInfo"; + private static final Logger LOG = LoggerFactory.getLogger(ModuleInfoBundleTracker.class); public static final String MODULE_INFO_PROVIDER_PATH_PREFIX = "META-INF/services/"; - private final ModuleInfoBackedContext moduleInfoLoadingStrategy = ModuleInfoBackedContext.create(); - public GeneratedClassLoadingStrategy getModuleInfoLoadingStrategy() { - return moduleInfoLoadingStrategy; + private final RefreshingSCPModuleInfoRegistry moduleInfoRegistry; + private final BundleTracker>> bundleTracker; + private boolean starting; + + public ModuleInfoBundleTracker(BundleContext context, RefreshingSCPModuleInfoRegistry moduleInfoRegistry) { + this.moduleInfoRegistry = moduleInfoRegistry; + bundleTracker = new BundleTracker<>(context, Bundle.RESOLVED | Bundle.STARTING | + Bundle.STOPPING | Bundle.ACTIVE, this); + } + + public void open() { + LOG.debug("ModuleInfoBundleTracker open starting"); + + starting = true; + bundleTracker.open(); + + starting = false; + moduleInfoRegistry.updateService(); + + LOG.debug("ModuleInfoBundleTracker open complete"); + } + + @Override + public void close() { + bundleTracker.close(); } @Override public Collection> addingBundle(Bundle bundle, BundleEvent event) { URL resource = bundle.getEntry(MODULE_INFO_PROVIDER_PATH_PREFIX + YangModelBindingProvider.class.getName()); - + LOG.debug("Got addingBundle({}) with YangModelBindingProvider resource {}", bundle, resource); if(resource==null) { return null; } - List> registrations = new LinkedList<>(); - try (InputStream inputStream = resource.openStream()) { - List lines = IOUtils.readLines(inputStream); - for (String moduleInfoName : lines) { + try { + for (String moduleInfoName : Resources.readLines(resource, Charsets.UTF_8)) { + LOG.trace("Retrieve ModuleInfo({}, {})", moduleInfoName, bundle); YangModuleInfo moduleInfo = retrieveModuleInfo(moduleInfoName, bundle); - registrations.add(moduleInfoLoadingStrategy.registerModuleInfo(moduleInfo)); + registrations.add(moduleInfoRegistry.registerModuleInfo(moduleInfo)); } - - } catch (Exception e) { - logger.error("Error while reading {}", resource, e); - throw new RuntimeException(e); + if(!starting) { + moduleInfoRegistry.updateService(); + } + } catch (IOException e) { + LOG.error("Error while reading {} from bundle {}", resource, bundle, e); + } catch (RuntimeException e) { + LOG.error("Failed to process {} for bundle {}", resource, bundle, e); } + LOG.trace("Got following registrations {}", registrations); return registrations; } @Override public void modifiedBundle(Bundle bundle, BundleEvent event, Collection> object) { - // NOOP } @Override @@ -84,7 +107,7 @@ public final class ModuleInfoBundleTracker implements BundleTrackerCustomizer