001: /*
002: * The Apache Software License, Version 1.1
003: *
004: *
005: * Copyright (c) 2002 The Apache Software Foundation. All rights
006: * reserved.
007: *
008: * Redistribution and use in source and binary forms, with or without
009: * modification, are permitted provided that the following conditions
010: * are met:
011: *
012: * 1. Redistributions of source code must retain the above copyright
013: * notice, this list of conditions and the following disclaimer.
014: *
015: * 2. Redistributions in binary form must reproduce the above copyright
016: * notice, this list of conditions and the following disclaimer in
017: * the documentation and/or other materials provided with the
018: * distribution.
019: *
020: * 3. The end-user documentation included with the redistribution,
021: * if any, must include the following acknowledgment:
022: * "This product includes software developed by the
023: * Apache Software Foundation (http://www.apache.org/)."
024: * Alternately, this acknowledgment may appear in the software itself,
025: * if and wherever such third-party acknowledgments normally appear.
026: *
027: * 4. The names "WSIF" and "Apache Software Foundation" must
028: * not be used to endorse or promote products derived from this
029: * software without prior written permission. For written
030: * permission, please contact apache@apache.org.
031: *
032: * 5. Products derived from this software may not be called "Apache",
033: * nor may "Apache" appear in their name, without prior written
034: * permission of the Apache Software Foundation.
035: *
036: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
037: * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
038: * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
039: * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
040: * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
041: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
042: * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
043: * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
044: * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
045: * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
046: * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
047: * SUCH DAMAGE.
048: * ====================================================================
049: *
050: * This software consists of voluntary contributions made by many
051: * individuals on behalf of the Apache Software Foundation and was
052: * originally based on software copyright (c) 2001, 2002, International
053: * Business Machines, Inc., http://www.apache.org. For more
054: * information on the Apache Software Foundation, please see
055: * <http://www.apache.org/>.
056: */
057:
058: package clients.zipcode;
059:
060: import java.io.IOException;
061: import java.io.Writer;
062:
063: import org.apache.soap.Utils;
064: import org.apache.soap.rpc.SOAPContext;
065: import org.apache.soap.util.Bean;
066: import org.apache.soap.util.xml.NSStack;
067: import org.apache.soap.util.xml.QName;
068: import org.apache.soap.util.xml.XMLJavaMappingRegistry;
069: import org.apache.wsif.providers.soap.apachesoap.PartSerializer;
070: import org.w3c.dom.Element;
071: import org.w3c.dom.Node;
072:
073: /**
074: * @version 1.0
075: * @author
076: */
077: public class LiteralSerializer implements PartSerializer {
078:
079: private Object customBean;
080: private javax.xml.namespace.QName customBeanQName;
081:
082: /*
083: * @see PartSerializer#setCustomBean(Object)
084: */
085: public void setPart(Object aCustomBean) {
086: this .customBean = aCustomBean;
087: }
088:
089: /*
090: * @see PartSerializer#getCustomBean()
091: */
092: public Object getPart() {
093: return this .customBean;
094: }
095:
096: public Object getPart(Class resultClass) {
097: return null;
098: }
099:
100: /*
101: * @see Serializer#marshall(String, Class, Object, Object, Writer, NSStack, XMLJavaMappingRegistry, SOAPContext)
102: */
103: public void marshall(String inScopeEncStyle, Class javaType,
104: Object src, Object context, Writer sink, NSStack nsStack,
105: XMLJavaMappingRegistry xjmr, SOAPContext ctx)
106: throws IllegalArgumentException, IOException {
107:
108: // Invoke utility method to get the FormatHandler
109: PartFormatHandler fh = new ShortZipCodeFormatHandler();
110: fh.setCustomBean(customBean);
111: fh.setCustomBeanQName(this .customBeanQName);
112: Element element = fh.getElement();
113: Utils.marshallNode((Node) element, sink);
114: }
115:
116: /*
117: * @see Deserializer#unmarshall(String, QName, Node, XMLJavaMappingRegistry, SOAPContext)
118: */
119: public Bean unmarshall(String inScopeEncStyle, QName elementType,
120: Node src, XMLJavaMappingRegistry xjmr, SOAPContext ctx)
121: throws IllegalArgumentException {
122: // Invoke utility method to get the FormatHandler
123: // PartFormatHandler fh = getFormatHandler(customBean, customBeanQName);
124: PartFormatHandler fh = new ShortZipCodeResponseFormatHandler();
125: fh.setElement((Element) src);
126: this .customBean = fh.getCustomBean();
127: return new Bean(this .customBean.getClass(), this .customBean);
128: }
129:
130: private PartFormatHandler getFormatHandler(Object bean,
131: QName namespace) {
132:
133: // Invoke utility method to get the FormatHandler
134: // PartFormatHandler fh = (PartFormatHandler)JCAUtil.getFormatHandler(bean, namespace, "soap", "literal");
135: // return fh;
136: return null;
137: }
138:
139: /**
140: * Gets the customBeanQName.
141: * @return Returns a QName
142: */
143: public javax.xml.namespace.QName getPartQName() {
144: return customBeanQName;
145: }
146:
147: /**
148: * Sets the customBeanQName.
149: * @param customBeanQName The customBeanQName to set
150: */
151: public void setPartQName(javax.xml.namespace.QName customBeanQName) {
152: this.customBeanQName = customBeanQName;
153:
154: }
155:
156: }
|