KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > apache > wsif > wsdl > extensions > jms > JMSFaultSerializer


1 /*
2  * The Apache Software License, Version 1.1
3  *
4  *
5  * Copyright (c) 2002 The Apache Software Foundation. All rights
6  * reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * 1. Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  *
15  * 2. Redistributions in binary form must reproduce the above copyright
16  * notice, this list of conditions and the following disclaimer in
17  * the documentation and/or other materials provided with the
18  * distribution.
19  *
20  * 3. The end-user documentation included with the redistribution,
21  * if any, must include the following acknowledgment:
22  * "This product includes software developed by the
23  * Apache Software Foundation (http://www.apache.org/)."
24  * Alternately, this acknowledgment may appear in the software itself,
25  * if and wherever such third-party acknowledgments normally appear.
26  *
27  * 4. The names "WSIF" and "Apache Software Foundation" must
28  * not be used to endorse or promote products derived from this
29  * software without prior written permission. For written
30  * permission, please contact apache@apache.org.
31  *
32  * 5. Products derived from this software may not be called "Apache",
33  * nor may "Apache" appear in their name, without prior written
34  * permission of the Apache Software Foundation.
35  *
36  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
40  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47  * SUCH DAMAGE.
48  * ====================================================================
49  *
50  * This software consists of voluntary contributions made by many
51  * individuals on behalf of the Apache Software Foundation and was
52  * originally based on software copyright (c) 2001, 2002, International
53  * Business Machines, Inc., http://www.apache.org. For more
54  * information on the Apache Software Foundation, please see
55  * <http://www.apache.org/>.
56  */

57
58 package org.apache.wsif.wsdl.extensions.jms;
59
60 import java.io.Serializable JavaDoc;
61
62 import javax.wsdl.Definition;
63 import javax.wsdl.WSDLException;
64 import javax.wsdl.extensions.ExtensibilityElement;
65 import javax.wsdl.extensions.ExtensionDeserializer;
66 import javax.wsdl.extensions.ExtensionRegistry;
67 import javax.wsdl.extensions.ExtensionSerializer;
68 import javax.xml.namespace.QName JavaDoc;
69
70 import org.apache.wsif.logging.Trc;
71 import org.w3c.dom.Element JavaDoc;
72
73 import com.ibm.wsdl.Constants;
74 import com.ibm.wsdl.util.xml.DOMUtils;
75
76 /**
77  * WSDL Jms extension
78  *
79  * @author Mark Whitlock <whitlock@apache.org>
80  */

81 public class JMSFaultSerializer
82     implements ExtensionSerializer, ExtensionDeserializer, Serializable JavaDoc {
83
84     private static final long serialVersionUID = 1L;
85
86     /**
87      * @see ExtensionSerializer#marshall(Class, QName, ExtensibilityElement, PrintWriter, Definition, ExtensionRegistry)
88      */

89     public void marshall(
90         Class JavaDoc parentType,
91         QName JavaDoc elementType,
92         javax.wsdl.extensions.ExtensibilityElement extension,
93         java.io.PrintWriter JavaDoc pw,
94         javax.wsdl.Definition def,
95         javax.wsdl.extensions.ExtensionRegistry extReg)
96         throws javax.wsdl.WSDLException {
97         Trc.entry(parentType, elementType, extension, pw, def, extReg);
98
99         if (extension == null) {
100             Trc.exit();
101             return;
102         }
103
104         JMSFault jmsFault = (JMSFault) extension;
105         String JavaDoc tagName =
106             DOMUtils.getQualifiedValue(JMSConstants.NS_URI_JMS, "fault", def);
107         pw.print(" <" + tagName);
108
109         /**
110          * handle attributes
111          */

112         if (jmsFault.getParts() != null) {
113             DOMUtils.printAttribute(
114                 JMSConstants.ATTR_PARTS,
115                 com.ibm.wsdl.util.StringUtils.getNMTokens(jmsFault.getParts()),
116                 pw);
117         }
118
119         Boolean JavaDoc required = extension.getRequired();
120         if (required != null) {
121             DOMUtils.printQualifiedAttribute(
122                 Constants.Q_ATTR_REQUIRED,
123                 required.toString(),
124                 def,
125                 pw);
126         }
127
128         pw.println("/>");
129
130         Trc.exit();
131     }
132
133     /**
134      * Registers the serializer.
135      */

136     public void registerSerializer(ExtensionRegistry registry) {
137         Trc.entry(this, registry);
138
139         // fault
140
registry.registerSerializer(
141             javax.wsdl.BindingFault.class,
142             JMSConstants.Q_ELEM_JMS_FAULT,
143             this);
144         registry.registerDeserializer(
145             javax.wsdl.BindingFault.class,
146             JMSConstants.Q_ELEM_JMS_FAULT,
147             this);
148         registry.mapExtensionTypes(
149             javax.wsdl.BindingFault.class,
150             JMSConstants.Q_ELEM_JMS_FAULT,
151             JMSFault.class);
152
153         Trc.exit();
154     }
155
156     /**
157      * @see ExtensionDeserializer#unmarshall(Class, QName, Element, Definition, ExtensionRegistry)
158      */

159     public ExtensibilityElement unmarshall(
160         Class JavaDoc parentType,
161         QName JavaDoc elementType,
162         Element el,
163         Definition def,
164         ExtensionRegistry extReg)
165         throws WSDLException {
166         Trc.entry(this, parentType, elementType, el, def, extReg);
167
168         JMSFault jmsFault = (JMSFault) extReg.createExtension(parentType, elementType);
169
170         String JavaDoc parts = DOMUtils.getAttribute(el, JMSConstants.ATTR_PARTS);
171         if (parts != null) {
172             jmsFault.setParts(com.ibm.wsdl.util.StringUtils.parseNMTokens(parts));
173         }
174
175         Trc.exit(jmsFault);
176         return jmsFault;
177     }
178 }
Popular Tags