01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one
03: * or more contributor license agreements. See the NOTICE file
04: * distributed with this work for additional information
05: * regarding copyright ownership. The ASF licenses this file
06: * to you under the Apache License, Version 2.0 (the
07: * "License"); you may not use this file except in compliance
08: * with the License. You may obtain a copy of the License at
09: *
10: * http://www.apache.org/licenses/LICENSE-2.0
11: *
12: * Unless required by applicable law or agreed to in writing,
13: * software distributed under the License is distributed on an
14: * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15: * KIND, either express or implied. See the License for the
16: * specific language governing permissions and limitations
17: * under the License.
18: */
19: package org.apache.axis2.jaxws.dispatch;
20:
21: import javax.xml.soap.SOAPMessage;
22: import javax.xml.stream.XMLInputFactory;
23: import javax.xml.stream.XMLStreamReader;
24: import javax.xml.transform.Source;
25: import javax.xml.ws.AsyncHandler;
26: import javax.xml.ws.Response;
27:
28: import org.apache.axis2.jaxws.message.util.Reader2Writer;
29: import org.apache.axis2.jaxws.TestLogger;
30:
31: public class CallbackHandler<T> implements AsyncHandler<T> {
32:
33: public void handleResponse(Response response) {
34: TestLogger.logger.debug(">> Processing async reponse");
35: try {
36: T res = (T) response.get();
37:
38: if (res instanceof SOAPMessage) {
39: SOAPMessage message = (SOAPMessage) res;
40: message.writeTo(System.out);
41:
42: }
43:
44: if (res instanceof String) {
45: TestLogger.logger.debug("Response [" + res + "]");
46: } else if (Source.class.isAssignableFrom(res.getClass())) {
47: Source source = (Source) res;
48:
49: XMLInputFactory inputFactory = XMLInputFactory
50: .newInstance();
51: XMLStreamReader reader = inputFactory
52: .createXMLStreamReader(source);
53: Reader2Writer r2w = new Reader2Writer(reader);
54: String responseText = r2w.getAsString();
55:
56: TestLogger.logger.debug(responseText);
57: }
58: TestLogger.logger
59: .debug("---------------------------------------------");
60: } catch (Exception e) {
61: e.printStackTrace();
62: }
63: }
64: }
|