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

com.arjuna.webservices11.SoapFault11 Maven / Gradle / Ivy

The newest version!
/*
   Copyright The Narayana Authors
   SPDX-License-Identifier: Apache-2.0
 */
package com.arjuna.webservices11;

import com.arjuna.webservices.SoapFault;
import com.arjuna.webservices.SoapFaultType;
import com.arjuna.webservices.util.InvalidEnumerationException;
import org.w3c.dom.Element;
import org.xmlsoap.schemas.soap.envelope.Fault;
import org.xmlsoap.schemas.soap.envelope.ObjectFactory;

import javax.xml.namespace.QName;
import jakarta.xml.soap.Detail;
import jakarta.xml.soap.DetailEntry;
import jakarta.xml.soap.SOAPFault;
import jakarta.xml.ws.soap.SOAPFaultException;

/**
 * Created by IntelliJ IDEA.
 * User: adinn
 * Date: Feb 1, 2008
 * Time: 4:57:16 PM
 * To change this template use File | Settings | File Templates.
 */
public class SoapFault11 extends SoapFault {
    /**
      * The detailElement element.
      */
     private Element detailElement;
     /**
      * The header elements.
      */
     private Element[] headerElements ;
     /**
      * Default constructor.
      */
     public SoapFault11()
     {
         super();
     }

     /**
      * Construct a SOAP fault based on a throwable.
      * @param th The throwable.
      */
     public SoapFault11(final Throwable th)
     {
         super(th);
     }

     /**
      * Construct a SOAP header fault based on a throwable.
      * @param th The throwable.
      * @param headerElements The header elements.
      */
     public SoapFault11(final Throwable th, final Element[] headerElements)
     {
         super(th);
         this.headerElements = headerElements;
     }

     /**
      * Create a custom SOAP fault.
      * @param soapFaultType the soap fault type.
      * @param subcode The fault subcode.
      * @param reason The fault reason.
      */
     public SoapFault11(final SoapFaultType soapFaultType, final QName subcode, final String reason)
     {
         super(soapFaultType, subcode, reason) ;
     }

     /**
      * Create a custom SOAP fault.
      * @param soapFaultType the soap fault type.
      * @param subcode The fault subcode.
      * @param reason The fault reason.
      * @param headerElements The header elements.
      */
     public SoapFault11(final SoapFaultType soapFaultType, final QName subcode, final String reason, final Element[] headerElements)
     {
         super(soapFaultType, subcode, reason, null);
         this.headerElements = headerElements ;
     }

     /**
      * Create a custom SOAP fault.
      * @param soapFaultType the soap fault type.
      * @param subcode The fault subcode.
      * @param reason The fault reason.
      * @param detailElement The fault detailElement.
      */
     public SoapFault11(final SoapFaultType soapFaultType, final QName subcode, final String reason, final Element detailElement)
     {
         super(soapFaultType, subcode, reason, getDetailString(detailElement)) ;
         this.detailElement = detailElement;
     }

     /**
      * Create a custom SOAP fault.
      * @param soapFaultType the soap fault type.
      * @param reason The fault reason.
      */
     public SoapFault11(final SoapFaultType soapFaultType, final String reason)
     {
         this(soapFaultType, null, reason, null, null) ;
     }

     /**
      * Create a custom SOAP fault.
      * @param soapFaultType the soap fault type.
      * @param reason The fault reason.
      * @param detailElement The fault detailElement.
      */
     public SoapFault11(final SoapFaultType soapFaultType,
         final String reason, final Element detailElement)
     {
         this(soapFaultType, null, reason, detailElement, null) ;
     }

     /**
      * Create a custom SOAP fault.
      * @param soapFaultType the soap fault type.
      * @param subcode The fault subcode.
      * @param reason The fault reason.
      * @param detailElement The fault detailElement.
      * @param headerElements The fault header elements.
      */
     public SoapFault11(final SoapFaultType soapFaultType, final QName subcode,
         final String reason, final Element detailElement, final Element[] headerElements)
     {
         this.soapFaultType = soapFaultType ;
         this.subcode = subcode ;
         this.reason = reason ;
         this.detailElement = detailElement;
         this.headerElements = headerElements ;
     }

    /**
     * factory to use for creating faults
     */
    private static ObjectFactory factory = new ObjectFactory();

    // convert to/from fault we can send via the SoapFaultService

    public Fault toFault()
    {
        Fault fault = factory.createFault();
        QName faultcode = subcode;
        String faultstring = getReason();
        fault.setFaultcode(faultcode);
        fault.setFaultstring(faultstring);
        return fault;
    }

    public static SoapFault11 fromFault(Fault fault)
    {
        try {
            QName subcode = fault.getFaultcode();
            String reason = fault.getFaultstring();
            return new SoapFault11(SoapFaultType.FAULT_SENDER, subcode, reason);
        } catch (Throwable th) {
            return new SoapFault11(th);
        }
    }

    public static SoapFault11 create(SOAPFaultException sfe)
    {
        try {
            SOAPFault cause = sfe.getFault();
            QName faultCode = cause.getFaultCodeAsQName();
            String reason = cause.getFaultString();
            SoapFaultType soapFaultType = SoapFaultType.toState(reason);
            Detail detail = cause.getDetail();
            return new SoapFault11(soapFaultType, faultCode, null, detail);
        } catch (InvalidEnumerationException e) {
            return new SoapFault11(e);
        }

    }
     /**
      * Get the SOAP fault detailElement.
      * @return The SOAP fault detailElement.
      */
     public Element getDetailElement()
     {
         return detailElement;
     }

     /**
      * Set the SOAP fault detailElement.
      * @param detailElement The SOAP fault detailElement.
      */
     public void setDetailElement(final Element detailElement)
     {
         this.detailElement = detailElement;
     }

     /**
      * Get the SOAP fault header elements.
      * @return The SOAP fault header elements.
      */
     public Element[] getHeaderElements()
     {
         return headerElements ;
     }

     /**
      * Set the SOAP fault header elements.
      * @param headerElements The SOAP fault header elements.
      */
     public void setHeaderElements(final Element[] headerElements)
     {
         this.headerElements = headerElements ;
     }

     /**
      * return a String representing the supplied detail element
      * @param detailElement
      * @return
      */

     private static String getDetailString(Element detailElement)
     {
         return detailElement.getTextContent();
     }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy