X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.init%2Fsrc%2Forg%2Fargeo%2Finit%2Fosgi%2FOsgiRuntimeContext.java;h=6c3e40ce57eadf8189f9aa8c8687c4c3d2c1c27e;hb=dea32138f55d1c80f75515793ed15be0e89e6d61;hp=91756e32b6759921484c0c1bf6b937408ccd4ab7;hpb=b7d8618ce593bbeca7e311d32a4d98988e27f877;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.init/src/org/argeo/init/osgi/OsgiRuntimeContext.java b/org.argeo.init/src/org/argeo/init/osgi/OsgiRuntimeContext.java index 91756e32b..6c3e40ce5 100644 --- a/org.argeo.init/src/org/argeo/init/osgi/OsgiRuntimeContext.java +++ b/org.argeo.init/src/org/argeo/init/osgi/OsgiRuntimeContext.java @@ -1,24 +1,42 @@ package org.argeo.init.osgi; +import java.util.Collections; +import java.util.Hashtable; import java.util.Map; +import java.util.Objects; import java.util.Optional; import java.util.ServiceLoader; +import java.util.concurrent.Flow; +import java.util.function.Consumer; import org.argeo.init.RuntimeContext; +import org.argeo.init.logging.ThinLoggerFinder; import org.osgi.framework.BundleContext; import org.osgi.framework.BundleException; +import org.osgi.framework.Constants; +import org.osgi.framework.ServiceRegistration; import org.osgi.framework.launch.Framework; import org.osgi.framework.launch.FrameworkFactory; +/** An OSGi runtime context. */ public class OsgiRuntimeContext implements RuntimeContext { private Map config; private Framework framework; private OsgiBoot osgiBoot; + @SuppressWarnings("rawtypes") + private ServiceRegistration loggingConfigurationSr; + @SuppressWarnings("rawtypes") + private ServiceRegistration logEntryPublisherSr; + public OsgiRuntimeContext(Map config) { this.config = config; } + public OsgiRuntimeContext(BundleContext bundleContext) { + start(bundleContext); + } + @Override public void run() { ServiceLoader sl = ServiceLoader.load(FrameworkFactory.class); @@ -29,13 +47,46 @@ public class OsgiRuntimeContext implements RuntimeContext { try { framework.start(); BundleContext bundleContext = framework.getBundleContext(); - osgiBoot = new OsgiBoot(bundleContext); - osgiBoot.bootstrap(); + start(bundleContext); } catch (BundleException e) { throw new IllegalStateException("Cannot start OSGi framework", e); } } + public void start(BundleContext bundleContext) { + // logging + loggingConfigurationSr = bundleContext.registerService(Consumer.class, + ThinLoggerFinder.getConfigurationConsumer(), + new Hashtable<>(Collections.singletonMap(Constants.SERVICE_PID, "argeo.logging.configuration"))); + logEntryPublisherSr = bundleContext.registerService(Flow.Publisher.class, + ThinLoggerFinder.getLogEntryPublisher(), + new Hashtable<>(Collections.singletonMap(Constants.SERVICE_PID, "argeo.logging.publisher"))); + + osgiBoot = new OsgiBoot(bundleContext); + osgiBoot.bootstrap(); + + } + + public void update() { + Objects.requireNonNull(osgiBoot); + osgiBoot.update(); + } + + public void stop(BundleContext bundleContext) { +// if (loggingConfigurationSr != null) +// try { +// loggingConfigurationSr.unregister(); +// } catch (Exception e) { +// // silent +// } +// if (logEntryPublisherSr != null) +// try { +// logEntryPublisherSr.unregister(); +// } catch (Exception e) { +// // silent +// } + } + @Override public void waitForStop(long timeout) throws InterruptedException { if (framework == null) @@ -45,6 +96,7 @@ public class OsgiRuntimeContext implements RuntimeContext { @Override public void close() throws Exception { + stop(framework.getBundleContext()); if (framework != null) framework.stop(); }