Class HttpClientRequestSOAP11Encoder
- All Implemented Interfaces:
Component
,DestructableComponent
,InitializableComponent
,UnmodifiableComponent
,HttpClientRequestMessageEncoder
,MessageEncoder
- Direct Known Subclasses:
HttpClientRequestSOAP11Encoder
,HttpClientRequestSOAP11Encoder
HttpRequest
.-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate SOAPObjectBuilder<Body>
SOAP Body builder.private SOAPObjectBuilder<Envelope>
SOAP Envelope builder.private final org.slf4j.Logger
Class logger. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected void
buildAndStoreSOAPMessage
(XMLObject payload) Builds the SOAP message to be encoded.protected org.apache.http.HttpEntity
createRequestEntity
(Envelope message, Charset charset) Create the request entity that makes up the POST message body.protected void
doEncode()
Performs the encoding logic.org.apache.http.client.methods.HttpPost
Get the HTTP client request on which to operate.protected XMLObject
Get the XMLObject which will be logged as the protocol message.protected String
Determine the value of the SOAPAction HTTP header to send.protected Envelope
Retrieve the previously stored SOAP envelope from the message context.void
This method should prepare the message context by creating and populating any binding-specific data structures required in the MessageContext, prior to actually encoding.protected void
This implementation performs the following actions on the context'sHttpRequest
:void
setHttpRequest
(org.apache.http.HttpRequest httpRequest) Set the HTTP client request on which to operate.protected void
storeSOAPEnvelope
(Envelope envelope) Store the constructed SOAP envelope in the message context for later encoding.Methods inherited from class org.opensaml.messaging.encoder.httpclient.BaseHttpClientRequestXMLMessageEncoder
encode, logEncodedMessage, marshallMessage
Methods inherited from class org.opensaml.messaging.encoder.httpclient.AbstractHttpClientRequestMessageEncoder
doDestroy, doInitialize
Methods inherited from class org.opensaml.messaging.encoder.AbstractMessageEncoder
getMessageContext, setMessageContext
Methods inherited from class net.shibboleth.utilities.java.support.component.AbstractInitializableComponent
destroy, initialize, isDestroyed, isInitialized
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface net.shibboleth.utilities.java.support.component.DestructableComponent
destroy, isDestroyed
Methods inherited from interface net.shibboleth.utilities.java.support.component.InitializableComponent
initialize, isInitialized
Methods inherited from interface org.opensaml.messaging.encoder.MessageEncoder
setMessageContext
-
Field Details
-
log
private final org.slf4j.Logger logClass logger. -
envBuilder
SOAP Envelope builder. -
bodyBuilder
SOAP Body builder.
-
-
Constructor Details
-
HttpClientRequestSOAP11Encoder
public HttpClientRequestSOAP11Encoder()Constructor.
-
-
Method Details
-
getHttpRequest
@Nullable public org.apache.http.client.methods.HttpPost getHttpRequest()Get the HTTP client request on which to operate.This encoder implementation only operates on instances of
HttpPost
.- Specified by:
getHttpRequest
in interfaceHttpClientRequestMessageEncoder
- Overrides:
getHttpRequest
in classAbstractHttpClientRequestMessageEncoder
- Returns:
- the HTTP client request
-
setHttpRequest
public void setHttpRequest(org.apache.http.HttpRequest httpRequest) Set the HTTP client request on which to operate.This encoder implementation only operates on instances of
HttpPost
.- Specified by:
setHttpRequest
in interfaceHttpClientRequestMessageEncoder
- Overrides:
setHttpRequest
in classAbstractHttpClientRequestMessageEncoder
- Parameters:
httpRequest
- the HTTP client request
-
prepareContext
This method should prepare the message context by creating and populating any binding-specific data structures required in the MessageContext, prior to actually encoding.This method should be called after the MessageContext has been set, and before any binding-specific Handler or HandlerChains are invoked.
Example: For a SOAP encoder, this method would create and store the basic SOAP Envelope structure in the message context, so that Handlers that are invoked have a place to which to add headers.
This method may be a no-op if not required by the binding, or if the message type of the context implies that the binding-specific structures have already been created elsewhere (e.g. message-oriented code where the calling code already knows its SOAP, and is operating on the raw SOAP envelope anyway).
. Default implementation is a no-op.- Specified by:
prepareContext
in interfaceMessageEncoder
- Overrides:
prepareContext
in classAbstractMessageEncoder
- Throws:
MessageEncodingException
- if there is a problem preparing the message context for encoding
-
doEncode
Performs the encoding logic. By the time this is called, this encoder has already been initialized and checked to ensure that it has not been destroyed.- Specified by:
doEncode
in classAbstractMessageEncoder
- Throws:
MessageEncodingException
- thrown if there is a problem encoding the message
-
createRequestEntity
protected org.apache.http.HttpEntity createRequestEntity(@Nonnull Envelope message, @Nullable Charset charset) throws MessageEncodingException Create the request entity that makes up the POST message body.- Parameters:
message
- message to be sentcharset
- character set used for the message- Returns:
- request entity that makes up the POST message body
- Throws:
MessageEncodingException
- thrown if the message could not be marshalled
-
storeSOAPEnvelope
Store the constructed SOAP envelope in the message context for later encoding.- Parameters:
envelope
- the SOAP envelope
-
getSOAPEnvelope
Retrieve the previously stored SOAP envelope from the message context.- Returns:
- the previously stored SOAP envelope
-
buildAndStoreSOAPMessage
Builds the SOAP message to be encoded.- Parameters:
payload
- body of the SOAP message
-
prepareHttpRequest
This implementation performs the following actions on the context's
HttpRequest
:- Sets the SOAPAction HTTP header the value returned by
getSOAPAction()
, if that returns non-null.
Subclasses should NOT set the SOAPAction HTTP header in this method. Instead, they should override the method
getSOAPAction()
.- Throws:
MessageEncodingException
- thrown if there is a problem preprocessing the transport
- Sets the SOAPAction HTTP header the value returned by
-
getSOAPAction
Determine the value of the SOAPAction HTTP header to send.The default behavior is to return the value of the SOAP Envelope's WS-Addressing Action header, if present.
- Returns:
- a SOAPAction HTTP header URI value
-
getMessageToLog
Get the XMLObject which will be logged as the protocol message.- Overrides:
getMessageToLog
in classBaseHttpClientRequestXMLMessageEncoder
- Returns:
- the XMLObject message considered to be the protocol message for logging purposes
-