]> git.argeo.org Git - lgpl/argeo-commons.git/blobdiff - org.argeo.cms/src/org/argeo/cms/internal/kernel/Activator.java
Introduce aggregating node user admin
[lgpl/argeo-commons.git] / org.argeo.cms / src / org / argeo / cms / internal / kernel / Activator.java
index 4d166eaf63db619ed0b761034299a154f30cfd39..6bad825ddda3a629b324c4d15b73936a369c5f8f 100644 (file)
@@ -1,15 +1,31 @@
 package org.argeo.cms.internal.kernel;
 
+import java.util.UUID;
+
+import org.argeo.security.SystemAuthentication;
 import org.osgi.framework.BundleActivator;
 import org.osgi.framework.BundleContext;
 
+/**
+ * Activates the {@link Kernel} from the provided {@link BundleContext}. Gives
+ * access to kernel information for the rest of the bundle (and only it)
+ */
 public class Activator implements BundleActivator {
+       private final static String systemKey;
+       static {
+               systemKey = UUID.randomUUID().toString();
+               System.setProperty(SystemAuthentication.SYSTEM_KEY_PROPERTY, systemKey);
+       }
+
+       private static BundleContext bundleContext;
        private Kernel kernel;
 
        @Override
        public void start(BundleContext context) throws Exception {
+               assert bundleContext == null;
                assert kernel == null;
-               kernel = new Kernel(context);
+               bundleContext = context;
+               kernel = new Kernel();
                kernel.init();
        }
 
@@ -17,6 +33,25 @@ public class Activator implements BundleActivator {
        public void stop(BundleContext context) throws Exception {
                kernel.destroy();
                kernel = null;
+               bundleContext = null;
        }
 
+       /**
+        * Singleton interface to the {@link BundleContext} related to the calling
+        * thread.
+        * 
+        * @BundleScope
+        */
+       public static BundleContext getBundleContext() {
+               return bundleContext;
+       }
+
+       /**
+        * @return a String which is guaranteed to be unique between and constant
+        *         within a Java static context (typically a VM launch)
+        * @BundleScope
+        */
+       public final static String getSystemKey() {
+               return systemKey;
+       }
 }