1 /*******************************************************************************
2 * Copyright (c) 2007, 2010 Association for Decentralized Information Management
4 * All rights reserved. This program and the accompanying materials
5 * are made available under the terms of the Eclipse Public License v1.0
6 * which accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
10 * VTT Technical Research Centre of Finland - initial API and implementation
11 *******************************************************************************/
12 package org.simantics.db.services;
14 import org.eclipse.core.runtime.CoreException;
15 import org.eclipse.core.runtime.IConfigurationElement;
16 import org.eclipse.core.runtime.IExtensionPoint;
17 import org.eclipse.core.runtime.IExtensionRegistry;
18 import org.eclipse.core.runtime.IStatus;
19 import org.eclipse.core.runtime.MultiStatus;
20 import org.eclipse.core.runtime.Platform;
21 import org.eclipse.core.runtime.Status;
22 import org.simantics.db.Session;
23 import org.slf4j.Logger;
24 import org.slf4j.LoggerFactory;
27 * @author Tuukka Lehtonen
29 public class GlobalServiceInitializer implements ServiceInitializer {
31 private static final Logger LOGGER = LoggerFactory.getLogger(GlobalServiceInitializer.class);
33 private static final String PLUGIN_ID = "org.simantics.db.services";
35 private static final String SERVICE_INITIALIZER = "serviceInitializer";
37 public static final int INITIALIZER_ERROR = 1;
40 public IStatus initialize(final Session s) {
41 MultiStatus problems = new MultiStatus(PLUGIN_ID, INITIALIZER_ERROR, "ServiceInitializer errors:", null);
43 LOGGER.info("Initializing..");
44 // Initialize adaption service
45 merge(problems, new AdaptionServiceInitializer().initialize(s));
47 //s.registerService(StructuralResourceListener.class, new StructuralResourceListenerImpl(s));
49 // Find extensions if any are available
50 IExtensionRegistry er = Platform.getExtensionRegistry();
52 IExtensionPoint ep = er.getExtensionPoint(PLUGIN_ID, SERVICE_INITIALIZER);
54 for (IConfigurationElement conf : ep.getConfigurationElements()) {
56 LOGGER.info("initialize: " + conf.getAttribute("class") + " (id=" + conf.getAttribute("id") + ")");
57 ServiceInitializer initializer = (ServiceInitializer) conf.createExecutableExtension("class");
58 merge(problems, initializer.initialize(s));
59 } catch (CoreException e) {
60 IStatus status = new Status(IStatus.ERROR, conf.getDeclaringExtension().getNamespaceIdentifier(), "ServiceInitializer instantiation failed, see exception for details.", e);
61 problems.merge(status);
67 return Status.OK_STATUS;
71 public IStatus initialize(Session s, String initializerId) {
72 if (initializerId == null)
73 throw new IllegalArgumentException("null initializer id");
75 // Find the matching service initializer extension
76 for (IConfigurationElement conf : Platform.getExtensionRegistry().getExtensionPoint(PLUGIN_ID, SERVICE_INITIALIZER).getConfigurationElements()) {
78 String id = conf.getAttribute("id");
79 if (initializerId.equals(id)) {
80 // System.out.println("initialize: " + conf.getAttribute("class"));
81 ServiceInitializer initializer = (ServiceInitializer) conf.createExecutableExtension("class");
82 return initializer.initialize(s);
84 } catch (CoreException e) {
85 return new Status(IStatus.ERROR, conf.getDeclaringExtension().getNamespaceIdentifier(), "ServiceInitializer instantiation failed, see exception for details.", e);
88 return new Status(IStatus.ERROR, PLUGIN_ID, "ServiceInitializer extension with id '" + initializerId + "' not found.", null);
91 private void merge(MultiStatus result, IStatus status) {