Sorry, that;s misleasding debug, as the reply-to isnt in the message
context.
Stopping the server and inspecting the message on the queue shows that the
JMS (cough, MQ) reply-to variable is set correctly.


On 01/12/06, Ruth, Brice D <[EMAIL PROTECTED]> wrote:

 Hmm, odd. The DEBUG logs seem to indicate that the reply-to still isn't
being set ... good that its working, though! :)

1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
msgctx.getProp(REPLY_TO):null

 -----Original Message-----
*From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
*Sent:* Friday, December 01, 2006 3:36 AM
*To:* [email protected]
*Subject:* Re: [xfire-user] Set JMSChannel replyTo

This works fine now.  I had some (duplicate) server side test code messing
things up on the service registry side.

On 30/11/06, Wayne Keenan < [EMAIL PROTECTED]> wrote:
>
> It works, and I  have discovered that this line in the client:
>
>         ((XFireProxy) Proxy.getInvocationHandler
> (echo)).getClient().setEndpointUri("jms://ARSYSTEM_OUTBOUND");
>
> sets the replyto queue.  (see server log below)
>
> I have added my own additional logging and have also created and
> additional JMS sessions (1 'in', 1 'out') in JMSChannel to get around the MQ
> asych error, I dont think this is a 'proper all encompasing fix', it just
> solves my needs at the moment.
>
> But, my problem at the moment is that the Service (in this case Echo)
> does not seem to come accross:
>
> client log:
> 719  [main] DEBUG org.codehaus.xfire.client.XFireProxy  - Method [echo]
> [hello]
> 719  [main] DEBUG org.codehaus.xfire.transport.jms.JMSTransport  -
> Creating new channel for uri: jms://ARSYSTEM_OUTBOUND
> 735  [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> DestName :ARSYSTEM_OUTBOUND
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   - adding
> handler [EMAIL PROTECTED] to phase send
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - adding
> handler [EMAIL PROTECTED] to
> phase transport
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - adding
> handler [EMAIL PROTECTED] to
> phase post-invoke
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> Invoking phase post-invoke
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - Invoking
> handler org.codehaus.xfire.soap.handler.SoapSerializerHandler in phase
> post-invoke
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> Invoking phase policy
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - Invoking
> phase user
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - Invoking
> phase transport
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - Invoking
> handler org.codehaus.xfire.soap.handler.SoapActionOutHandler in phase
> transport
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - Invoking
> phase send
> 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - Invoking
> handler org.codehaus.xfire.handler.OutMessageSender in phase send
> 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> ResponseURI:jms://ARSYSTEM_INBOUND?Echo
> 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> msgtxt:<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/";
> xmlns:xsd=" http://www.w3.org/2001/XMLSchema"; 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance";><soap:Body><echo
> xmlns=" 
http://test.xfire.codehaus.org";><in0>hello</in0></echo></soap:Body></soap:Envelope>
>
> 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel   -
> corrid:11649244730150-704411791
> 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> msgctx.getProp(REPLY_TO):null
> 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> selector=
> 1250 [main] INFO  org.codehaus.xfire.transport.jms.JMSChannel  - Sent
> message: Source ID: 65B4422E-55DF-C388-8ABA-6D2E56F491E3 Destination: null
> JMSType: null
> 11407 [main] DEBUG org.codehaus.xfire.client.XFireProxy  - Result [null]
> response:null
>
>
>
>
>
> server log:
>
>
> 30/11/2006 22:07:53,171 DEBUG asyncDelivery2 JMSChannel.onMessage - recv 
msg=<soap:Envelope xmlns:soap="
> http://schemas.xmlsoap.org/soap/envelope/
> " xmlns:xsd="http://www.w3.org/2001/XMLSchema
> " xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance
> "><soap:Body><echo xmlns="
> 
http://test.xfire.codehaus.org";><in0>hello</in0></echo></soap:Body></soap:Envelope>
>
>
> 30/11/2006 22:07:53,171 DEBUG asyncDelivery2 JMSChannel.onMessage - dest 
name=ARSYSTEM_INBOUND
> 30/11/2006 22:07:53,171 DEBUG asyncDelivery2 JMSChannel.onMessage - 
reply-to=queue:///ARSYSTEM_OUTBOUND
> 30/11/2006 22:07:53,171 DEBUG asyncDelivery2
>
> DefaultEndpoint.onReceive - Received message to jms://ARSYSTEM_INBOUND
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler [EMAIL PROTECTED]
>  to phase dispatch
>
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler [EMAIL PROTECTED] to phase parse
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> HandlerPipeline.addHandler
>  - adding handler [EMAIL PROTECTED] to phase pre-invoke
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler
> [EMAIL PROTECTED]
>  to phase dispatch
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler [EMAIL PROTECTED]
>  to phase dispatch
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> HandlerPipeline.addHandler - adding handler [EMAIL PROTECTED] to phase 
dispatch
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> HandlerPipeline.invoke - Invoking phase transport
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> HandlerPipeline.invoke - Invoking phase parse
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.invoke - 
Invoking handler
> org.codehaus.xfire.soap.handler.ReadHeadersHandler in phase parse
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> HandlerPipeline.invoke - Invoking phase pre-dispatch
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.invoke
>  - Invoking phase dispatch
> 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.invoke - 
Invoking handler
> org.codehaus.xfire.handler.LocateBindingHandler in phase dispatch
> 30/11/2006 22:07:53,187 INFO asyncDelivery2
> DefaultFaultHandler.invoke - Fault occurred!
> org.codehaus.xfire.fault.XFireFault: Could not find a service to invoke.
>
>
>    at 
org.codehaus.xfire.handler.LocateBindingHandler.invoke(LocateBindingHandler.java:39)
>
>
>
>
>
>
>
> On 30/11/06, Ruth, Brice D < [EMAIL PROTECTED]> wrote:
> >
> >  Wow, I had no idea you could use the XFire client for JMS. That's
> > pretty cool (if it works).
> >
> > Um ... the problem here seems to be that you're not setting the
> > ReplyTo. That may be what MQ is balking on as well. Hmmm.
> >
> > It looks like JMSChannel.java in XFire sets the JMSReplyTo from a
> > javax.jms.Destination (say, a Queue) that is stored in the
> > MessageContext under the key "REPLY_TO". Look here:
> >
> >
> > 
http://svn.xfire.codehaus.org/browse/xfire/trunk/xfire/xfire-jms/src/main/org/codehaus/xfire/transport/jms/JMSChannel.java?r=trunk
> >
> > At approx. lines 194,205.
> >
> > It looks like the XFire client (org.codehaus.xfire.client.Client)
> > extends org.codehaus.xfire.AbstractContext, so just calling:
> >
> > getClient().setProperty("REPLY_TO", <destination>)
> >
> > might work. I don't have a working MQ setup at the moment, otherwise
> > I'd try.
> >
> > Cheers,
> > Brice
> >
> >  -----Original Message-----
> > *From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
> > *Sent:* Thursday, November 30, 2006 2:39 PM
> > *To:* [email protected]
> > *Subject:* Re: [xfire-user] Set JMSChannel replyTo
> >
> > Thanks for the response.  I think I need to set ws addressing on the
> > dynamic client, but Im a unsure how.
> > I am registering the JMS transport before creating the dynamic client,
> > below are the logs.  perhaps what im trying
> > is completely wrong w/ dynamic client as im getting a MQ error:
> > Caused by: javax.jms.JMSException: MQJMS1013: operation invalid whilst
> > session is using asynchronous delivery
> >
> > my test client is:
> >
> >
> >
> > import java.lang.reflect.Proxy;
> > import java.net.MalformedURLException;
> > import java.net.URL;
> >
> > import javax.jms.QueueConnectionFactory;
> >
> > import org.codehaus.xfire.DefaultXFire;
> > import org.codehaus.xfire.XFire ;
> > import org.codehaus.xfire.client.Client;
> > import org.codehaus.xfire.client.XFireProxy;
> > import org.codehaus.xfire.client.XFireProxyFactory;
> > import org.codehaus.xfire.service.Service;
> > import org.codehaus.xfire.service.binding.ObjectServiceFactory ;
> >
> > import org.codehaus.xfire.test.Echo;
> > import org.codehaus.xfire.transport.jms.JMSTransport;
> >
> > import com.ibm.mq.jms.JMSC;
> > import com.ibm.mq.jms.MQQueueConnectionFactory;
> >
> >
> > public class JMSWSEchoTest {
> >
> >     private XFire xfire;
> >     private QueueConnectionFactory factory;
> >     private JMSTransport transport;
> >
> >
> >     public void setUp()
> >         throws Exception
> >     {
> >         factory = new MQQueueConnectionFactory();
> >         ((MQQueueConnectionFactory)factory).setTransportType(
> > JMSC.MQJMS_TP_BINDINGS_MQ);
> >         ((MQQueueConnectionFactory)factory).setHostName("localhost");
> >
> > ((MQQueueConnectionFactory)factory).setQueueManager("QM_server");
> >         ((MQQueueConnectionFactory)factory).setPort(1414);
> >
> >         xfire = new DefaultXFire();
> >         transport = (JMSTransport) new JMSTransport(xfire,
> > factory);
> >         xfire.getTransportManager ().register(transport);
> >     }
> >
> >     public void testClient1() throws Exception {
> >
> >
> >         // Create a ServiceFactory to create the ServiceModel.
> >         // We need to add the JMSTransport to the list of bindings to
> > create.
> >         ObjectServiceFactory sf = new ObjectServiceFactory(
> > xfire.getTransportManager());
> >         sf.addSoap11Transport(JMSTransport.BINDING_ID);
> >
> >         // Create the service model
> >         Service serviceModel = sf.create(Echo.class);
> >
> >         // Create a proxy for the service
> >         XFireProxyFactory factory = new XFireProxyFactory(xfire);
> >         Echo echo = (Echo) factory.create(serviceModel,
> > "jms://ARSYSTEM_OUTBOUND");
> >
> >         // Since JMS doesn't really have a concept of anonymous
> > endpoints, we
> >         // need
> >         // need to let xfire know what JMS endpoint we should use
> >         ((XFireProxy) 
Proxy.getInvocationHandler(echo)).getClient().setEndpointUri("jms://ARSYSTEM_INBOUND");
> >
> >         // run the client!
> >         String resString = echo.echo("hello");
> >         //assertEquals("hello", resString);
> >         System.out.println("response:" + resString);
> >     }
> >     public void testClient2() throws MalformedURLException, Exception
> >     {
> >         Client client = new Client(new URL("http://localhost:8191/Echo?wsdl
> > "));
> >         Object[] response = client.invoke("echo", new Object[]
> > {"hello"});
> >         System.out.println((String) response[0]);
> >
> >     }
> >      public static void main(String args[]) throws Exception
> >         {
> >
> >             try
> >             {
> >                 JMSWSEchoTest jwt = new JMSWSEchoTest();
> >
> >                 jwt.setUp();
> >                 jwt.testClient1();
> >
> >             }
> >             catch (/*MalformedURL*/Exception e)
> >             {
> >                 e.printStackTrace();
> >             }
> >         }
> >
> >
> > }
> >
> >
> >
> >
> > 0    [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager  - 
Registered transport
> > [EMAIL PROTECTED]
> > 0    [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager
> > - Registered transport
> > [EMAIL PROTECTED]
> > 15   [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager
> > - Registered transport
> > [EMAIL PROTECTED]
> > 15   [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager  - 
Registered transport
> > [EMAIL PROTECTED]
> > 15   [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager
> > - Registered transport
> > [EMAIL PROTECTED]
> > 1422 [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager
> > - Registered transport
> > [EMAIL PROTECTED]
> > 1422 [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager  - 
Registered transport
> > [EMAIL PROTECTED]
> > 1422 [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager
> > - Registered transport
> > [EMAIL PROTECTED]
> > 1422 [main] DEBUG org.codehaus.xfire.transport.DefaultTransportManager
> > - Registered transport
> > [EMAIL PROTECTED]
> > 2734 [main] DEBUG org.codehaus.xfire.client.XFireProxy  - Method
> > [echo] [hello]
> > 2734 [main] DEBUG org.codehaus.xfire.transport.jms.JMSTransport  -
> > Creating new channel for uri: jms://ARSYSTEM_INBOUND
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - adding
> > handler [EMAIL PROTECTED] to phase
> > send
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - adding
> > handler [EMAIL PROTECTED] to
> > phase transport
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > adding handler
> > [EMAIL PROTECTED] to phase
> > post-invoke
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase post-invoke
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > Invoking handler org.codehaus.xfire.soap.handler.SoapSerializerHandlerin 
phase post-invoke
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase policy
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > Invoking phase user
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase transport
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking handler org.codehaus.xfire.soap.handler.SoapActionOutHandlerin 
phase transport
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase send
> > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking handler org.codehaus.xfire.handler.OutMessageSender in phase
> > send
> > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > ResponseURI:jms://ARSYSTEM_OUTBOUND
> > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > msgtxt:<soap:Envelope xmlns:soap="
> > http://schemas.xmlsoap.org/soap/envelope/"; xmlns:xsd="
> > http://www.w3.org/2001/XMLSchema"; xmlns:xsi="
> > http://www.w3.org/2001/XMLSchema-instance";><soap:Body><echo xmlns="
> > 
http://test.xfire.codehaus.org";><in0>hello</in0></echo></soap:Body></soap:Envelope>
> >
> > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > corrid:11649131364370-593738066
> > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > msgctx.getProp(REPLY_TO):null
> > org.codehaus.xfire.XFireRuntimeException : Could not invoke service..
> > Nested exception is org.codehaus.xfire.fault.XFireFault: Error sending
> > message
> > org.codehaus.xfire.fault.XFireFault: Error sending message
> >     at org.codehaus.xfire.transport.jms.JMSChannel.send (
> > JMSChannel.java:246)
> >     at org.codehaus.xfire.handler.OutMessageSender.invoke(
> > OutMessageSender.java:26)
> >     at org.codehaus.xfire.handler.HandlerPipeline.invoke(
> > HandlerPipeline.java:131)
> >     at org.codehaus.xfire.client.Invocation.invoke (Invocation.java
> > :75)
> >     at org.codehaus.xfire.client.Client.invoke(Client.java:335)
> >     at org.codehaus.xfire.client.XFireProxy.handleRequest(
> > XFireProxy.java:77)
> >     at org.codehaus.xfire.client.XFireProxy.invoke (XFireProxy.java
> > :57)
> >     at $Proxy0.echo(Unknown Source)
> >     at com.turingsmi.messagelogic.net.tests.JMSWSEchoTest.testClient1(
> > JMSWSEchoTest.java:66)
> >     at com.turingsmi.messagelogic.net.tests.JMSWSEchoTest.main (
> > JMSWSEchoTest.java:85)
> > Caused by: javax.jms.JMSException: MQJMS1013: operation invalid whilst
> > session is using asynchronous delivery
> >     at com.ibm.mq.jms.services.ConfigEnvironment.newException(
> > ConfigEnvironment.java :567)
> >     at com.ibm.mq.jms.MQMessageProducer.send(MQMessageProducer.java
> > :1193)
> >     at com.ibm.mq.jms.MQMessageProducer.send(MQMessageProducer.java
> > :3123)
> >     at org.codehaus.xfire.transport.jms.JMSChannel.send(
> > JMSChannel.java :238)
> >     ... 9 more
> >
> >
> > On 30/11/06, Ruth, Brice D <[EMAIL PROTECTED]> wrote:
> > >
> > >  I'm not sure what you mean w/ dynamic client ... I don't think the
> > > dynamic client understands JMS, does it? Maybe it does and I've missed
> > > something. When we've setup JMS with XFire in an MQ Series environment, 
the
> > > MQ client application set the ReplyTo in the API calls to the MQ jars - so
> > > its specified in the JMS message. XFire just picks it up from there and 
does
> > > the right thing. You don't need to specify the reply-to on the server 
side,
> > > if memory serves.
> > >
> > > Cheers,
> > > Brice
> > >
> > >  -----Original Message-----
> > > *From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
> > > *Sent:* Thursday, November 30, 2006 12:15 PM
> > > *To:* [email protected]
> > > *Subject: *[xfire-user] Set JMSChannel replyTo
> > >
> > > Hi,
> > >
> > > Please can someone advise me on how I set the JMS ReplyTo property
> > > on the serverside service.xml and also for a 'DynamicClient'?
> > >
> > > Thanks
> > > Wayne
> > >
> >
> >
>

Reply via email to