ee.ria.xroad.common.message.SoapFault.java Source code

Java tutorial

Introduction

Here is the source code for ee.ria.xroad.common.message.SoapFault.java

Source

/**
 * The MIT License
 * Copyright (c) 2015 Estonian Information System Authority (RIA), Population Register Centre (VRK)
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package ee.ria.xroad.common.message;

import ee.ria.xroad.common.CodedException;
import lombok.SneakyThrows;
import org.apache.commons.lang3.StringEscapeUtils;

import javax.xml.soap.SOAPFault;

/**
 * Soap interface implementation representing an error message.
 */
public class SoapFault implements Soap {

    static final String SOAP_NS_SOAP_ENV = "http://schemas.xmlsoap.org/soap/envelope/";

    private final String faultCode;
    private final String faultString;
    private final String faultActor;
    private final String faultDetail;

    private final byte[] rawXml;
    private final String charset;

    /**
     * Creates a new SOAP fault from the given parts.
     * @param faultCode the fault code
     * @param faultString the fault string
     * @param faultActor the fault actor
     * @param faultDetail the fault detail
     * @param rawXml the raw XML data
     * @param charset the charset of the XML
     */
    public SoapFault(String faultCode, String faultString, String faultActor, String faultDetail, byte[] rawXml,
            String charset) {
        this.faultCode = faultCode;
        this.faultString = faultString;
        this.faultActor = faultActor;
        this.faultDetail = faultDetail;
        this.rawXml = rawXml;
        this.charset = charset;
    }

    /**
     * Creates a new SOAP fault from a SOAPFault DOM element.
     * @param soapFault the DOM element used in created of the fault
     */
    public SoapFault(SOAPFault soapFault) {
        this(soapFault, null, null);
    }

    /**
     * Creates a new SOAP fault from a SOAPFault DOM element.
     * @param soapFault the DOM element used in created of the fault
     * @param rawXml the raw XML data
     * @param charset the charset of the XML
     */
    public SoapFault(SOAPFault soapFault, byte[] rawXml, String charset) {
        this.faultCode = soapFault.getFaultCode();
        this.faultString = soapFault.getFaultString();
        this.faultActor = soapFault.getFaultActor();
        this.faultDetail = getFaultDetail(soapFault);
        this.rawXml = rawXml;
        this.charset = charset;
    }

    /**
     * Gets the fault code of the SOAP fault.
     * @return a String with the fault code
     */
    public String getCode() {
        return faultCode;
    }

    /**
     * Gets the fault string of the SOAP fault.
     * @return a String giving an explanation of the fault
     */
    public String getString() {
        return faultString;
    }

    /**
     * Gets the fault actor of the SOAP fault.
     * @return a String giving the actor in the message path that caused this fault
     */
    public String getActor() {
        return faultActor;
    }

    /**
     * Gets the fault detail of the SOAP fault.
     * @return a String with application-specific error information
     */
    public String getDetail() {
        return faultDetail;
    }

    /**
     * Converts this SOAP fault into a coded exception.
     * @return CodedException
     */
    @SneakyThrows
    public CodedException toCodedException() {
        return CodedException.fromFault(faultCode, faultString, faultActor, faultDetail,
                new String(rawXml, charset));
    }

    @Override
    public String getXml() throws Exception {
        if (rawXml != null) {
            return new String(rawXml, charset);
        } else {
            return createFaultXml(faultCode, faultString, faultActor, faultDetail);
        }
    }

    /**
     * Creates SOAP fault message from exception.
     * @param ex exception representing a SOAP fault
     * @return a String containing XML of the SOAP fault represented by the given coded exception
     */
    public static String createFaultXml(CodedException ex) {
        if (ex instanceof CodedException.Fault) {
            return ((CodedException.Fault) ex).getFaultXml();
        } else {
            return createFaultXml(ex.getFaultCode(), ex.getFaultString(), ex.getFaultActor(), ex.getFaultDetail());
        }
    }

    /**
     * Creates a SOAP fault message.
     * @param faultCode code of the new SOAP fault
     * @param faultString string of the new SOAP fault
     * @param faultActor actor of the new SOAP fault
     * @param detail detail of the new SOAP fault
     * @return a String containing XML of the SOAP fault represented by the given parameters
     */
    public static String createFaultXml(String faultCode, String faultString, String faultActor, String detail) {
        return "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" + "<SOAP-ENV:Envelope " + "xmlns:SOAP-ENV=\""
                + SOAP_NS_SOAP_ENV + "\">" + "<SOAP-ENV:Body>" + "<SOAP-ENV:Fault>" + "<faultcode>" + faultCode
                + "</faultcode>" + "<faultstring>" + StringEscapeUtils.escapeXml(faultString) + "</faultstring>"
                + (faultActor != null ? "<faultactor>" + StringEscapeUtils.escapeXml(faultActor) + "</faultactor>"
                        : "")
                + (detail != null
                        ? "<detail><faultDetail xmlns=\"\">" + StringEscapeUtils.escapeXml(detail)
                                + "</faultDetail>" + "</detail>"
                        : "")
                + "</SOAP-ENV:Fault>" + "</SOAP-ENV:Body>" + "</SOAP-ENV:Envelope>";
    }

    private static String getFaultDetail(SOAPFault soapFault) {
        if (soapFault.getDetail() != null && soapFault.getDetail().getFirstChild() != null) {
            return soapFault.getDetail().getFirstChild().getTextContent();
        }

        return null;
    }

}