Fault Mediator
The Fault Mediator (also called the Makefault Mediator) transforms the current message into a fault message. However, this mediator does not send the converted message. The Send Mediator needs to be invoked to send a fault message created via the Fault mediator. The fault message's To
header is set to the Fault-To
of the original message (if such a header exists in the original message). You can create the fault message as a SOAP 1.1, SOAP 1.2, or plain-old XML (POX) fault.
For more information on faults and errors, see Error Handling.
Syntax
<makefault [version="soap11|soap12|pox"]> <code (value="literal" | expression="xpath")/> <reason (value="literal" | expression="xpath")> <node>? <role>? <detail>? </makefault>
UI Configuration
Click on the relevant tab to view the required UI configuration pending on whether you want to create the fault message as a SOAP 1.1 fault, SOAP 1.2 fault or a plain-old XML (POX) fault.
Note
You can configure the mediator using XML. Click switch to source view in the Mediator window.
Examples
Following are examples of different usages of the Fault Mediator.
Example one
In the following example, the testmessage
string value is given as the reason for the SOAP error versionMismatch
.
<makefault xmlns="http://ws.apache.org/ns/synapse" version="soap11"> <code xmlns:soap11Env="http://schemas.xmlsoap.org/soap/envelope/" value="soap11Env:VersionMismatch" /> <reason value="test message " /> <role></role> </makefault>
Example two
The following sample proxy validates the content type using the Filter Mediator based on the Content-Type
header property. If the result is true, it sends an exception back to the client using the Fault Mediator. Else, if the result is false, it continues the flow.
<proxy xmlns="http://ws.apache.org/ns/synapse" name="CheckContentType" transports="https http" startOnLoad="true" trace="disable"> <description/> <target> <inSequence> <log level="custom"> <property name="_______Content-Type" expression="get-property('transport','Content-Type')"/> </log> <filter source="get-property('transport','Content-Type')" regex="application/xhtml\+xml"> <then> <log> <property name="Content-Type" expression="get-property('transport','Content-Type')"/> <property name="Decision" value="Exception, due to unexpected Content-Type."/> </log> <makefault version="soap11"> <code xmlns:soap11Env="http://schemas.xmlsoap.org/soap/envelope/" value="soap11Env:Client"/> <reason value="Content-Type Error"/> <role/> <detail>Content-Type: application/xhtml+xml is not a valid content type.</detail> </makefault> <header name="To" scope="default" action="remove"/> <send/> </then> <else> <log> <property name="Content-Type" expression="get-property('transport','Content-Type')"/> <property name="Decision" value="Continue the mediation flow..."/> </log> <send> <endpoint> <address uri="http://localhost:9000/services/SimpleStockQuoteService"/> </endpoint> </send> </else> </filter> </inSequence> <outSequence> <send/> </outSequence> </target> <publishWSDL uri="http://localhost:9000/services/SimpleStockQuoteService?wsdl"/> </proxy>
Samples
Sample 5: Creating SOAP Fault Messages and Changing the Direction of a Message.