@SuppressWarnings("restriction")
final class Kernel {
private final static Log log = LogFactory.getLog(Kernel.class);
+ private static final String PROP_WORKBENCH_AUTOSTART = "org.eclipse.rap.workbenchAutostart";
private final BundleContext bundleContext;
repositoryFactory = new OsgiJackrabbitRepositoryFactory();
nodeSecurity = new NodeSecurity(bundleContext, node);
nodeHttp = new NodeHttp(bundleContext, node, nodeSecurity);
- WorkbenchApplicationConfiguration wac = new WorkbenchApplicationConfiguration();
// Publish services to OSGi
nodeSecurity.publish();
bundleContext.registerService(RepositoryFactory.class,
repositoryFactory, null);
nodeHttp.publish();
- registerWorkbench(wac);
+
+ if ("false".equals(bundleContext
+ .getProperty(PROP_WORKBENCH_AUTOSTART))) {
+ WorkbenchApplicationConfiguration wac = new WorkbenchApplicationConfiguration();
+ registerWorkbench(wac);
+ }
} catch (Exception e) {
log.error("Cannot initialize Argeo CMS", e);
throw new ArgeoException("Cannot initialize", e);
void destroy() {
long begin = System.currentTimeMillis();
-
+
// OSGi
workbenchReg.unregister();
+ (duration % 1000) + "s ##");
}
- private ServiceRegistration<ApplicationConfiguration> registerWorkbench(
- WorkbenchApplicationConfiguration wac) {
- Hashtable<String, String> props = new Hashtable<String, String>();
- props.put(ApplicationLauncher.PROPERTY_CONTEXT_NAME, "ui");
- return bundleContext.registerService(ApplicationConfiguration.class,
- wac, props);
+ private void registerWorkbench(final WorkbenchApplicationConfiguration wac) {
+ new Thread("Worbench Launcher") {
+ public void run() {
+ Hashtable<String, String> props = new Hashtable<String, String>();
+ props.put(ApplicationLauncher.PROPERTY_CONTEXT_NAME, "ui");
+ workbenchReg = bundleContext.registerService(
+ ApplicationConfiguration.class, wac, props);
+ }
+ }.start();
}
private void directorsCut() {