diff --git a/kie-aries-blueprint/pom.xml b/kie-aries-blueprint/pom.xml
index dfb569e08c..1d56802fbe 100644
--- a/kie-aries-blueprint/pom.xml
+++ b/kie-aries-blueprint/pom.xml
@@ -143,6 +143,18 @@
test
-->
+
+
+ org.kie
+ kie-ci
+ test
+
+
+ org.drools
+ drools-core
+ test-jar
+ test
+
diff --git a/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/KieNamespaceHandler.java b/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/KieNamespaceHandler.java
index b9001efb2e..7a6d738c5f 100644
--- a/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/KieNamespaceHandler.java
+++ b/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/KieNamespaceHandler.java
@@ -15,23 +15,35 @@
*/
package org.kie.aries.blueprint;
-import java.net.URL;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.Callable;
-
import org.apache.aries.blueprint.ParserContext;
import org.apache.aries.blueprint.mutable.MutableBeanMetadata;
import org.apache.aries.blueprint.mutable.MutablePassThroughMetadata;
-import org.kie.aries.blueprint.namespace.*;
+import org.kie.aries.blueprint.namespace.AbstractElementParser;
+import org.kie.aries.blueprint.namespace.KieBaseElementParser;
+import org.kie.aries.blueprint.namespace.KieContainerElementParser;
+import org.kie.aries.blueprint.namespace.KieEnvironmentElementParser;
+import org.kie.aries.blueprint.namespace.KieEventListenersElementParser;
+import org.kie.aries.blueprint.namespace.KieImportElementParser;
+import org.kie.aries.blueprint.namespace.KieModuleElementParser;
+import org.kie.aries.blueprint.namespace.KieObjectsInjector;
+import org.kie.aries.blueprint.namespace.KieRuntimeManagerElementParser;
+import org.kie.aries.blueprint.namespace.KieRuntimeManagerSessionElementParser;
+import org.kie.aries.blueprint.namespace.KieSessionElementParser;
+import org.kie.aries.blueprint.namespace.KieStoreElementParser;
+import org.kie.aries.blueprint.namespace.ReleaseIdElementParser;
import org.osgi.service.blueprint.container.ComponentDefinitionException;
import org.osgi.service.blueprint.reflect.ComponentMetadata;
import org.osgi.service.blueprint.reflect.Metadata;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
+import java.net.URL;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.concurrent.Callable;
+
public class KieNamespaceHandler implements org.apache.aries.blueprint.NamespaceHandler {
/** The list of Aries Blueprint XML files*/
@@ -43,7 +55,6 @@ public class KieNamespaceHandler implements org.apache.aries.blueprint.Namespace
private static final String BLUEPRINT_NS = "http://www.osgi.org/xmlns/blueprint/v1.0.0";
public static final String ELEMENT_RELEASE_ID = "releaseId";
- public static final String ELEMENT_KBASE_REF = "kbase-ref";
public static final String ELEMENT_KBASE = "kbase";
public static final String ELEMENT_KCONTAINER = "kcontainer-ref";
public static final String ELEMENT_KSTORE = "kstore";
@@ -54,11 +65,11 @@ public class KieNamespaceHandler implements org.apache.aries.blueprint.Namespace
public static final String ELEMENT_KRUNTIMEMANAGER = "kruntimeManager";
public static final String ELEMENT_KSESSION_RUNTIMEMANAGER = "kruntimeManagerSession";
public static final String ELEMENT_KMODULE = "kmodule";
+ public static final String ELEMENT_IMPORT = "import";
protected static Map droolsElementParserMap = new HashMap();
static {
droolsElementParserMap.put(ELEMENT_RELEASE_ID, new ReleaseIdElementParser());
- droolsElementParserMap.put(ELEMENT_KBASE_REF, new KieBaseElementParser());
droolsElementParserMap.put(ELEMENT_KBASE, new KieBaseElementParser());
droolsElementParserMap.put(ELEMENT_KSESSION, new KieSessionElementParser());
droolsElementParserMap.put(ELEMENT_KSESSION_REF, new KieSessionElementParser());
@@ -69,6 +80,7 @@ public class KieNamespaceHandler implements org.apache.aries.blueprint.Namespace
droolsElementParserMap.put(ELEMENT_KRUNTIMEMANAGER, new KieRuntimeManagerElementParser());
droolsElementParserMap.put(ELEMENT_KSESSION_RUNTIMEMANAGER, new KieRuntimeManagerSessionElementParser());
droolsElementParserMap.put(ELEMENT_KMODULE, new KieModuleElementParser());
+ droolsElementParserMap.put(ELEMENT_IMPORT, new KieImportElementParser() );
}
public KieNamespaceHandler() {
@@ -100,12 +112,14 @@ public Metadata parse(Element element, ParserContext parserContext) {
throw new ComponentDefinitionException("Unsupported Kie Blueprint Element '"+elementName+"'");
}
if (ELEMENT_KMODULE.equalsIgnoreCase(elementName)) {
- addKieObjectsProcessor(element, parserContext, elementParser);
+ addProcessor( element, parserContext, elementParser, "afterKmoduleSet" );
+ } else if (ELEMENT_IMPORT.equalsIgnoreCase(elementName)) {
+ addProcessor( element, parserContext, elementParser, "afterImportSet" );
}
return elementParser.parseElement(parserContext, element);
}
- private void addKieObjectsProcessor(Element element, ParserContext context, AbstractElementParser elementParser) {
+ private void addProcessor( Element element, ParserContext context, AbstractElementParser elementParser, String initMethodName ) {
// Register processors
MutablePassThroughMetadata beanProcessorFactory = context.createMetadata(MutablePassThroughMetadata.class);
@@ -121,7 +135,7 @@ private void addKieObjectsProcessor(Element element, ParserContext context, Abst
beanProcessor.setFactoryComponent(beanProcessorFactory);
beanProcessor.setFactoryMethod("call");
beanProcessor.setProcessor(true);
- beanProcessor.setInitMethod("afterPropertiesSet");
+ beanProcessor.setInitMethod(initMethodName);
beanProcessor.addProperty("blueprintContainer", AbstractElementParser.createRef(context, "blueprintContainer"));
context.getComponentDefinitionRegistry().registerComponentDefinition(beanProcessor);
}
diff --git a/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/factorybeans/AbstractKieObjectsResolver.java b/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/factorybeans/AbstractKieObjectsResolver.java
index 4377d97183..06a0897f32 100644
--- a/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/factorybeans/AbstractKieObjectsResolver.java
+++ b/kie-aries-blueprint/src/main/java/org/kie/aries/blueprint/factorybeans/AbstractKieObjectsResolver.java
@@ -29,9 +29,7 @@
import org.osgi.framework.BundleContext;
import org.osgi.framework.wiring.BundleWiring;
-import java.util.concurrent.Callable;
-
-public abstract class AbstractKieObjectsResolver implements Callable