All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jibx.ws.wsdl.tools.custom.WsdlCustom Maven / Gradle / Ivy

/*
 * Copyright (c) 2007, Dennis M. Sosnoski All rights reserved.
 * 
 * Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
 * following conditions are met:
 * 
 * Redistributions of source code must retain the above copyright notice, this list of conditions and the following
 * disclaimer. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the
 * following disclaimer in the documentation and/or other materials provided with the distribution. Neither the name of
 * JiBX nor the names of its contributors may be used to endorse or promote products derived from this software without
 * specific prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package org.jibx.ws.wsdl.tools.custom;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.jibx.custom.classes.IApply;
import org.jibx.custom.classes.IDocumentFormatter;
import org.jibx.custom.classes.SharedNestingBase;
import org.jibx.runtime.IUnmarshallingContext;
import org.jibx.schema.generator.FormatterCache;
import org.jibx.util.IClassLocator;
import org.jibx.util.StringArray;

/**
 * Global customization information for WSDL generation. This extends the binding customization model to include the
 * information used for service definitions.
 * 
 * @author Dennis M. Sosnoski
 */
public class WsdlCustom extends NestingBase implements IApply
{
    /** Enumeration of allowed attribute names */
    public static final StringArray s_allowedAttributes =
        new StringArray(new String[] { "wsdl-namespace" }, NestingBase.s_allowedAttributes);
    
    /** Customization value from unmarshalling. */
    private String m_wsdlNamespace;
    
    /** List of Fault definitions. */
    private final ArrayList m_faultList;
    
    /** Map from fully-qualified class name to Fault information. */
    private final Map m_faultMap;
    
    /** List of services, in order added. */
    private final ArrayList m_serviceList;
    
    /** Map from fully-qualified class name to service information. */
    private final Map m_serviceMap;
    
    /** Class locator. */
    private IClassLocator m_locator;
    
    /** JavaDoc formatter instance cache. */
    private FormatterCache m_formatCache;
    
    /**
     * Constructor.
     * 
     * @param parent
     */
    public WsdlCustom(SharedNestingBase parent) {
        super(parent);
        m_faultList = new ArrayList();
        m_faultMap = new HashMap();
        m_serviceList = new ArrayList();
        m_serviceMap = new HashMap();
    }
    
    /**
     * Make sure all attributes are defined.
     * 
     * @param uctx unmarshalling context
     */
    private void preSet(IUnmarshallingContext uctx) {
        validateAttributes(uctx, s_allowedAttributes);
    }
    
    /**
     * Get the namespace for WSDL definitions of services.
     * 
     * @return WSDL namespace (null if unspecified)
     */
    public String getWsdlNamespace() {
        return m_wsdlNamespace;
    }
    
    /**
     * Set the namespace for WSDL definitions of services.
     * 
     * @param uri WSDL namespace (null if to be derived from service class name)
     */
    public void setWsdlNamespace(String uri) {
        m_wsdlNamespace = uri;
    }
    
    /**
     * Get list of Faults.
     * 
     * @return fault list
     */
    public List getFaults() {
        return m_faultList;
    }
    
    /*
     * (non-Javadoc)
     * 
     * @see org.jibx.binding.generator.SharedNestingBase#getNameStyle()
     */
    public int getNameStyle() {
        return CAMEL_CASE_NAMES;
    }
    
    /**
     * Get fault customization information. This method should only be used after the {@link #apply(IClassLocator)}
     * method is called.
     * 
     * @param type fully qualified class name
     * @return fault customization (null if none)
     */
    public FaultCustom getFaultCustomization(String type) {
        return (FaultCustom)m_faultMap.get(type);
    }
    
    /**
     * Force fault customization information. This method should only be used after the {@link #apply(IClassLocator)}
     * method is called. If the fault customization information has not previously been created, it will be created by
     * this call.
     * 
     * @param type fully qualified exception class name
     * @return fault customization (null if none)
     */
    public FaultCustom forceFaultCustomization(String type) {
        FaultCustom fault = (FaultCustom)m_faultMap.get(type);
        if (fault == null) {
            fault = new FaultCustom(this, type);
            fault.apply(m_locator);
            m_faultMap.put(type, fault);
        }
        return fault;
    }
    
    /**
     * Get list of services.
     * 
     * @return service list
     */
    public List getServices() {
        return m_serviceList;
    }
    
    /**
     * Get service customization information. This method should only be used after the {@link #apply(IClassLocator)}
     * method is called.
     * 
     * @param type fully qualified class name
     * @return service customization (null if none)
     */
    public ServiceCustom getServiceCustomization(String type) {
        return (ServiceCustom)m_serviceMap.get(type);
    }
    
    /**
     * Add new service customization. This creates the service customization, using defaults, and adds it to the
     * internal structures. This method should only be used after first calling {@link #getServiceCustomization(String)}
     * and obtaining a null result.
     * 
     * @param type fully qualified class name
     * @return service customization
     */
    public ServiceCustom addServiceCustomization(String type) {
        ServiceCustom service = new ServiceCustom(this, type);
        service.apply(m_locator, getFormatter(service));
        m_serviceList.add(service);
        m_serviceMap.put(type, service);
        return service;
    }
    
    /**
     * Get a JavaDoc formatter instance for a class.
     *
     * @param custom customization information
     * @return formatter
     */
    public IDocumentFormatter getFormatter(SharedNestingBase custom) {
        return m_formatCache.getFormatter(custom);
    }
    
    /**
     * Unmarshalling factory. This gets the containing element and the name so that the standard constructor can be
     * used.
     * 
     * @param ictx
     * @return created instance
     */
    private static WsdlCustom factory(IUnmarshallingContext ictx) {
        return new WsdlCustom((SharedNestingBase)getContainingObject(ictx));
    }
    
    /**
     * Apply customizations to services to fill out members.
     * 
     * @param icl class locator
     */
    public void apply(IClassLocator icl) {
        
        // save locator for later use (when services are added)
        m_locator = icl;
        m_formatCache = new FormatterCache(icl);
        
        // inherit namespace directly from package level, if not specified
        String ns = getSpecifiedNamespace();
        if (ns == null) {
            ns = getParent().getNamespace();
        }
        setNamespace(ns);
        
        // fix Faults and create map
        for (int i = 0; i < m_faultList.size(); i++) {
            FaultCustom fault = (FaultCustom)m_faultList.get(i);
            fault.apply(icl);
            m_faultMap.put(fault.getExceptionType(), fault);
        }
        
        // register services with names supplied (priority over generated names)
        for (int i = 0; i < m_serviceList.size(); i++) {
            ServiceCustom service = (ServiceCustom)m_serviceList.get(i);
            String name = service.getServiceName();
            if (name != null) {
                if (registerName(name, service) != name) {
                    throw new IllegalStateException("Duplicate service name " + name);
                }
            }
        }
        
        // fix services and create map
        for (int i = 0; i < m_serviceList.size(); i++) {
            // TODO: this largely duplicates addServiceCustomization() - are both necessary?
            ServiceCustom service = (ServiceCustom)m_serviceList.get(i);
            service.apply(icl, getFormatter(service));
            m_serviceMap.put(service.getClassName(), service);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy