I progress. If I create a camel bean processor containing the code to
setup initial context and cal openEJB, i get this error now
21:53:49,737 | ERROR | foo | DefaultErrorHandler
| ache.camel.processor.CamelLogger 232 | 55 -
org.apache.camel.camel-core - 2.8.0.SNAPSHOT | Failed delivery for
exchangeId: ID-biker-chm-local-61842-1308253897457-1-17. Exhausted
after delivery attempt: 1 caught: java.lang.IllegalArgumentException:
interface org.apache.openejb.client.EJBObjectProxy is not visible from
class loader
java.lang.IllegalArgumentException: interface
org.apache.openejb.client.EJBObjectProxy is not visible from class
loader
at java.lang.reflect.Proxy.getProxyClass(Proxy.java:353)[:1.6.0_24]
at java.lang.reflect.Proxy.newProxyInstance(Proxy.java:581)[:1.6.0_24]
at
org.apache.openejb.client.proxy.Jdk13ProxyFactory.newProxyInstance(Jdk13ProxyFactory.java:118)[66:org.apache.openejb.client:4.0.0.SNAPSHOT]
at
org.apache.openejb.client.proxy.ProxyManager.newProxyInstance(ProxyManager.java:107)[66:org.apache.openejb.client:4.0.0.SNAPSHOT]
at
org.apache.openejb.client.EJBObjectHandler.createEJBObjectProxy(EJBObjectHandler.java:126)[66:org.apache.openejb.client:4.0.0.SNAPSHOT]
at
org.apache.openejb.client.JNDIContext.createBusinessObject(JNDIContext.java:191)[66:org.apache.openejb.client:4.0.0.SNAPSHOT]
at
org.apache.openejb.client.JNDIContext.lookup(JNDIContext.java:232)[66:org.apache.openejb.client:4.0.0.SNAPSHOT]
at
javax.naming.InitialContext.lookup(InitialContext.java:392)[:1.6.0_24]
at
org.apache.camel.example.remote.ejb.EJBClientBean.process(EJBClientBean.java:41)[69:org.apache.camel.camel-example-remote-ejb:2.8.0.SNAPSHOT]
at sun.reflect.GeneratedMethodAccessor48.invoke(Unknown Source)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)[:1.6.0_24]
at java.lang.reflect.Method.invoke(Method.java:597)[:1.6.0_24]
at
org.apache.camel.component.bean.MethodInfo.invoke(MethodInfo.java:328)[55:org.apache.camel.camel-core:2.8.0.SNAPSHOT]
at
org.apache.camel.component.bean.MethodInfo$1.proceed(MethodInfo.java:230)[55:org.apache.camel.camel-core:2.8.0.SNAPSHOT]
at
org.apache.camel.component.bean.BeanProcessor.process(BeanProcessor.java:161)[55:org.apache.camel.camel-core:2.8.0.SNAPSHOT]
On Thu, Jun 16, 2011 at 8:55 PM, Romain Manni-Bucau
<[email protected]> wrote:
> were you able to check properties?
>
> i think there are ignored if you are not in testing envt.
>
> - Romain
>
> 2011/6/16 Charles Moulliard <[email protected]>
>
>> I have created a camel-example-remote-ejb project containing a test
>> case with a remote EJB deployed on openEJB and that works fine using
>> InitialContext with the properties provided in my first email. So the
>> project + remote EJB is in order. This is the camel + jndi in OSGI
>> container where we have a problem.
>>
>> On Thu, Jun 16, 2011 at 8:18 PM, Romain Manni-Bucau
>> <[email protected]> wrote:
>> > Charles, which part of code do you think is not working?
>> >
>> > I never tried the camel-ejb component in OSGi but i did openejb remote
>> > client in servicemix and it works fine and camel doesn't add anything on
>> it,
>> > just a way to get a bean not the initial context.
>> >
>> > Can you just check your properties are used and if it is the case can you
>> > try a manual client?
>> >
>> > I think i had some issues reading system.properties or jndi.properties
>> with
>> > camel in a non osgi envt some weeks ago (that's why i used spring to do
>> the
>> > lookup).
>> >
>> > - Romain
>> >
>> > 2011/6/16 Charles Moulliard <[email protected]>
>> >
>> >> The camel route has been deployed using deploy dir of servicemix and
>> >> DynamicImport package is enable. I have also installed the openEJB
>> >> client jar and wrapped it. So everything is in place
>> >>
>> >> On Thu, Jun 16, 2011 at 4:50 PM, Romain Manni-Bucau
>> >> <[email protected]> wrote:
>> >> > oh you are in an OSGi container?
>> >> >
>> >> > for openejb you have to import package org.apache.openejb.client and
>> >> > org.apache.openejb.client.proxy i think or something like that (i
>> don't
>> >> > really remember).
>> >> >
>> >> > - Romain
>> >> >
>> >> > 2011/6/16 Charles Moulliard <[email protected]>
>> >> >
>> >> >> I think that the code that we use to create the endpoint works fine
>> in
>> >> >> a non osgi environment but not on osgi as jndi is not really
>> supported
>> >> >>
>> >> >> @Override
>> >> >> protected Endpoint createEndpoint(String uri, String remaining,
>> >> >> Map<String, Object> parameters) throws Exception {
>> >> >> BeanEndpoint answer = new BeanEndpoint(uri, this);
>> >> >> answer.setBeanName(remaining);
>> >> >>
>> >> >> // plugin registry to lookup in jndi for the EJBs
>> >> >> Registry registry = new JndiRegistry(getContext());
>> >> >> answer.setBeanHolder(new EjbRegistryBean(registry,
>> >> >> getCamelContext(), answer.getBeanName()));
>> >> >>
>> >> >> Processor processor = answer.getProcessor();
>> >> >> setProperties(processor, parameters);
>> >> >> return answer;
>> >> >> }
>> >> >>
>> >> >>
>> >> >> On Wed, Jun 15, 2011 at 11:33 PM, Romain Manni-Bucau
>> >> >> <[email protected]> wrote:
>> >> >> > Hi,
>> >> >> >
>> >> >> > creating a list with spring should work but i think the problem is
>> the
>> >> >> > context creation here.
>> >> >> >
>> >> >> > personnaly i use the bean component and i ask to me (with java dsl)
>> or
>> >> >> > spring to do the lookup to put it in the camel registry.
>> >> >> >
>> >> >> > - Romain
>> >> >> >
>> >> >> > 2011/6/15 Charles Moulliard <[email protected]>
>> >> >> >
>> >> >> >> Hi,
>> >> >> >>
>> >> >> >> I try to use openejb from camel using camel-ejb but get this error
>> >> >> >> when camel looks to find the ejb stateless bean
>> >> >> >>
>> >> >> >> <beans xmlns="http://www.springframework.org/schema/beans"
>> >> >> >> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
>> >> >> >> xmlns:p="http://www.springframework.org/schema/util"
>> >> >> >> xsi:schemaLocation="
>> >> >> >> http://www.springframework.org/schema/beans
>> >> >> >> http://www.springframework.org/schema/beans/spring-beans.xsd
>> >> >> >> http://www.springframework.org/schema/util
>> >> >> >> http://www.springframework.org/schema/util/spring-util.xsd
>> >> >> >> http://camel.apache.org/schema/spring
>> >> >> >> http://camel.apache.org/schema/spring/camel-spring.xsd">
>> >> >> >>
>> >> >> >> <camelContext xmlns="http://camel.apache.org/schema/spring">
>> >> >> >> <route>
>> >> >> >> <from uri="timer://foo?fixedRate=true&period=5s"/>
>> >> >> >> <setBody>
>> >> >> >> <constant>4</constant>
>> >> >> >> <constant>3</constant>
>> >> >> >> </setBody>
>> >> >> >> <to uri="ejb:CalculatorImplRemote?method=sum"/>
>> >> >> >> <log message=">>> Result : ${body}"/>
>> >> >> >> </route>
>> >> >> >> </camelContext>
>> >> >> >>
>> >> >> >> <!-- setup Camel EJB component -->
>> >> >> >> <bean id="ejb"
>> >> class="org.apache.camel.component.ejb.EjbComponent">
>> >> >> >> <property name="properties" ref="jndiProperties"/>
>> >> >> >> </bean>
>> >> >> >>
>> >> >> >> <!-- use OpenEJB context factory -->
>> >> >> >> <p:properties id="jndiProperties">
>> >> >> >> <prop
>> >> >> >>
>> >> >>
>> >>
>> key="java.naming.factory.initial">org.apache.openejb.client.RemoteInitialContextFactory</prop>
>> >> >> >> <prop key="java.naming.provider.url">ejbd://127.0.0.1:4201
>> >> >> </prop>
>> >> >> >> <prop key="java.naming.security.principal">daniel</prop>
>> >> >> >> <prop
>> key="java.naming.security.credentials">password</prop>
>> >> >> >> </p:properties>
>> >> >> >>
>> >> >> >> </beans>
>> >> >> >>
>> >> >> >> 23:12:32,227 | ERROR | foo | DefaultErrorHandler
>> >> >> >> | ache.camel.processor.CamelLogger 232 | 64 -
>> >> >> >> org.apache.camel.camel-core - 2.7.0 | Failed delivery for
>> exchangeId:
>> >> >> >> ID-biker-chm-local-58833-1308171227583-5-6. Exhausted after
>> delivery
>> >> >> >> attempt: 1 caught: org.apache.camel.NoSuchBeanException: No bean
>> >> could
>> >> >> >> be found in the registry for: CalculatorImplRemote
>> >> >> >> org.apache.camel.NoSuchBeanException: No bean could be found in
>> the
>> >> >> >> registry for: CalculatorImplRemote
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.component.bean.RegistryBean.getBean(RegistryBean.java:68)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.component.bean.BeanProcessor.process(BeanProcessor.java:84)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.util.AsyncProcessorHelper.process(AsyncProcessorHelper.java:103)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.component.bean.BeanProcessor.process(BeanProcessor.java:74)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.impl.ProcessorEndpoint.onExchange(ProcessorEndpoint.java:102)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.impl.ProcessorEndpoint$1.process(ProcessorEndpoint.java:72)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >> at
>> >> >> >>
>> >> >>
>> >>
>> org.apache.camel.impl.converter.AsyncProcessorTypeConverter$ProcessorToAsyncProcessorBridge.process(AsyncProcessorTypeConverter.java:50)[64:org.apache.camel.camel-core:2.7.0]
>> >> >> >>
>> >> >> >>
>> >> >> >> How can we define using <setBody> tag the following two parameters
>> to
>> >> >> >> call the method sum of the stateless ejb CalculatorRemote ?
>> >> >> >>
>> >> >> >> public int sum(int add1, int add2);
>> >> >> >>
>> >> >> >> <setBody>
>> >> >> >> <constant>???</constant>
>> >> >> >> </setBody>
>> >> >> >>
>> >> >> >>
>> >> >> >> Regards,
>> >> >> >>
>> >> >> >> Charles Moulliard
>> >> >> >>
>> >> >> >> Apache Committer
>> >> >> >>
>> >> >> >> Blog : http://cmoulliard.blogspot.com
>> >> >> >> Twitter : http://twitter.com/cmoulliard
>> >> >> >> Linkedin : http://www.linkedin.com/in/charlesmoulliard
>> >> >> >> Skype: cmoulliard
>> >> >> >>
>> >> >> >
>> >> >>
>> >> >
>> >>
>> >
>>
>