summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--branches/sca-java-1.x/modules/contribution-jee-impl/src/main/java/org/apache/tuscany/sca/contribution/jee/JavaEEModuleHelper.java60
1 files changed, 60 insertions, 0 deletions
diff --git a/branches/sca-java-1.x/modules/contribution-jee-impl/src/main/java/org/apache/tuscany/sca/contribution/jee/JavaEEModuleHelper.java b/branches/sca-java-1.x/modules/contribution-jee-impl/src/main/java/org/apache/tuscany/sca/contribution/jee/JavaEEModuleHelper.java
index ccb66e8965..a903f6dbc0 100644
--- a/branches/sca-java-1.x/modules/contribution-jee-impl/src/main/java/org/apache/tuscany/sca/contribution/jee/JavaEEModuleHelper.java
+++ b/branches/sca-java-1.x/modules/contribution-jee-impl/src/main/java/org/apache/tuscany/sca/contribution/jee/JavaEEModuleHelper.java
@@ -25,7 +25,9 @@ import org.apache.openejb.OpenEJBException;
import org.apache.openejb.config.AnnotationDeployer;
import org.apache.openejb.config.AppModule;
import org.apache.openejb.config.DeploymentLoader;
+import org.apache.openejb.config.EjbModule;
import org.apache.openejb.config.ReadDescriptors;
+import org.apache.openejb.config.WebModule;
import org.apache.tuscany.sca.contribution.service.ContributionReadException;
/**
@@ -42,6 +44,64 @@ public class JavaEEModuleHelper {
throw new ContributionReadException(e);
}
+ // Set the Thread context class loader as the module's class loader and all the Web and EJB modules
+ // inside. Otherwise, SCA annotations could not be processed
+ // TODO: Eliminate the use of reflection for setting the class loader
+ java.lang.reflect.Field field = null;
+ try {
+ field = appModule.getClass().getDeclaredField("classLoader");
+ } catch (SecurityException e) {
+ throw new ContributionReadException(e);
+ } catch (NoSuchFieldException e) {
+ throw new ContributionReadException(e);
+ }
+ field.setAccessible(true);
+ try{
+ field.set(appModule, Thread.currentThread().getContextClassLoader());
+ } catch (IllegalArgumentException e) {
+ throw new ContributionReadException(e);
+ } catch (IllegalAccessException e) {
+ throw new ContributionReadException(e);
+ }
+
+ for(EjbModule ejbModule:appModule.getEjbModules()) {
+ java.lang.reflect.Field field1 = null;
+ try {
+ field1 = ejbModule.getClass().getDeclaredField("classLoader");
+ } catch (SecurityException e) {
+ throw new ContributionReadException(e);
+ } catch (NoSuchFieldException e) {
+ throw new ContributionReadException(e);
+ }
+ field1.setAccessible(true);
+ try {
+ field1.set(ejbModule, Thread.currentThread().getContextClassLoader());
+ } catch (IllegalArgumentException e) {
+ throw new ContributionReadException(e);
+ } catch (IllegalAccessException e) {
+ throw new ContributionReadException(e);
+ }
+ }
+
+ for(WebModule webModule:appModule.getWebModules()) {
+ java.lang.reflect.Field field1 = null;
+ try {
+ field1 = webModule.getClass().getDeclaredField("classLoader");
+ } catch (SecurityException e) {
+ throw new ContributionReadException(e);
+ } catch (NoSuchFieldException e) {
+ throw new ContributionReadException(e);
+ }
+ field1.setAccessible(true);
+ try {
+ field1.set(webModule, Thread.currentThread().getContextClassLoader());
+ } catch (IllegalArgumentException e) {
+ throw new ContributionReadException(e);
+ } catch (IllegalAccessException e) {
+ throw new ContributionReadException(e);
+ }
+ }
+
// Process deployment descriptor files
ReadDescriptors readDescriptors = new ReadDescriptors();
try {