public class MqttSender extends MqttFacade implements ISenderWithParameters
Modifier and Type | Field and Description |
---|---|
protected ParameterList |
paramList |
client, connectOptions, log
Constructor and Description |
---|
MqttSender() |
Modifier and Type | Method and Description |
---|---|
void |
addParameter(Parameter p) |
void |
close()
Stop/close the sender and deallocate resources.
|
void |
configure()
configure() is called once at startup of the framework in the configure method of the owner of this sender. |
ParameterList |
getParameterList() |
boolean |
isSynchronous()
When
true , the result of sendMessage is the reply of the request. |
void |
open()
This method will be called to start the sender.
|
SenderResult |
sendMessage(Message message,
PipeLineSession session)
Send a message to some destination (as configured in the Sender object).
|
Message |
sendMessage(Message message,
PipeLineSession session,
String soapHeader) |
getLogPrefix, getPhysicalDestinationName, setAuthAlias, setAutomaticReconnect, setBrokerUrl, setCharset, setCleanSession, setClientId, setKeepAliveInterval, setName, setPassword, setPersistenceDirectory, setQos, setTimeout, setTopic, setUsername, toString
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
consumesSessionVariable
sendMessageOrThrow
getName, setName
getApplicationContext, getName
getConfigurationClassLoader
setApplicationContext
getDomain
protected ParameterList paramList
public void configure() throws ConfigurationException
ISender
configure()
is called once at startup of the framework in the configure method of the owner of this sender.
Purpose of this method is to check whether the static configuration of the sender is correct.
As much as possible class-instantiating should take place in the configure()
or open()
method, to improve performance.configure
in interface IConfigurable
configure
in interface ISender
configure
in class MqttFacade
ConfigurationException
public void open() throws SenderException
ISender
sendMessage()
method.open
in interface ISender
open
in class MqttFacade
SenderException
public void close()
ISender
close
in interface ISender
close
in class MqttFacade
public void addParameter(Parameter p)
addParameter
in interface IWithParameters
public ParameterList getParameterList()
getParameterList
in interface IWithParameters
public SenderResult sendMessage(Message message, PipeLineSession session) throws SenderException, TimeoutException
ISender
configure()
method is called.
The following table shows the difference between synchronous and a-synchronous senders:
synchronous | a-synchronous | |
---|---|---|
ISender.isSynchronous() returns | true | false |
return value of sendMessage() is | the reply-message | the messageId of the message sent |
the correlationID specified with sendMessage() | may be ignored | is sent with the message |
a {link TimeOutException} | may be thrown if a timeout occurs waiting for a reply | should not be expected |
Multiple objects may try to call this method at the same time, from different threads.
Implementations of this method should therefore be thread-safe, or synchronized
.
sendMessage
in interface ISender
SenderException
TimeoutException
public Message sendMessage(Message message, PipeLineSession session, String soapHeader) throws SenderException, TimeoutException
SenderException
TimeoutException
public boolean isSynchronous()
ISender
true
, the result of sendMessage is the reply of the request.isSynchronous
in interface ISender
Copyright © 2023 Frank!Framework. All rights reserved.