X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.cms%2Fsrc%2Forg%2Fargeo%2Fcms%2Finternal%2Fkernel%2FActivator.java;h=01e842caa6043326223fe9be65c666975bf4a6c8;hb=44990a14a843b1eac4c0dfca228559c9e86c256b;hp=5ba7c01e8bc18864b9aeba4f40de56ea7c263985;hpb=344dfc1d20780c3453a07f5573259ccdc76f6160;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.cms/src/org/argeo/cms/internal/kernel/Activator.java b/org.argeo.cms/src/org/argeo/cms/internal/kernel/Activator.java index 5ba7c01e8..01e842caa 100644 --- a/org.argeo.cms/src/org/argeo/cms/internal/kernel/Activator.java +++ b/org.argeo.cms/src/org/argeo/cms/internal/kernel/Activator.java @@ -26,6 +26,7 @@ import org.osgi.framework.Constants; import org.osgi.framework.ServiceReference; import org.osgi.service.log.LogReaderService; import org.osgi.service.useradmin.UserAdmin; +import org.osgi.util.tracker.ServiceTracker; /** * Activates the kernel. Gives access to kernel information for the rest of the @@ -37,6 +38,7 @@ public class Activator implements BundleActivator { private static Activator instance; private BundleContext bc; + private LogReaderService logReaderService; private NodeLogger logger; @@ -44,6 +46,8 @@ public class Activator implements BundleActivator { private CmsDeployment nodeDeployment; private CmsInstance nodeInstance; + private ServiceTracker userAdminSt; + @Override public void start(BundleContext bundleContext) throws Exception { Runtime.getRuntime().addShutdownHook(new CmsShutdown()); @@ -55,6 +59,9 @@ public class Activator implements BundleActivator { initSecurity(); initArgeoLogger(); initNode(); + + userAdminSt = new ServiceTracker<>(instance.bc, UserAdmin.class, null); + userAdminSt.open(); log.debug("Kernel bundle started"); } catch (Throwable e) { log.error("## FATAL: CMS activator failed", e); @@ -127,6 +134,9 @@ public class Activator implements BundleActivator { if (nodeState != null) nodeState.shutdown(); + if (userAdminSt != null) + userAdminSt.close(); + instance = null; this.bc = null; this.logReaderService = null; @@ -155,10 +165,25 @@ public class Activator implements BundleActivator { return getNodeUserAdmin().isSingleUser(); } + public static UserAdmin getUserAdmin() { + return (UserAdmin) getNodeUserAdmin(); + } + private static NodeUserAdmin getNodeUserAdmin() { - ServiceReference sr = instance.bc.getServiceReference(UserAdmin.class); - NodeUserAdmin userAdmin = (NodeUserAdmin) instance.bc.getService(sr); - return userAdmin; + NodeUserAdmin res; + try { + res = instance.userAdminSt.waitForService(60000); + } catch (InterruptedException e) { + throw new CmsException("Cannot retrieve Node user admin", e); + } + if (res == null) + throw new CmsException("No Node user admin found"); + + return res; + // ServiceReference sr = + // instance.bc.getServiceReference(UserAdmin.class); + // NodeUserAdmin userAdmin = (NodeUserAdmin) instance.bc.getService(sr); + // return userAdmin; }