mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-10 15:11:59 +01:00
[mqtt] Support birth and shutdown message (#12152)
Signed-off-by: Jimmy Tanagra <jcode@tanagra.id.au>
This commit is contained in:
parent
ca1e2b0e42
commit
80819ca503
@ -38,10 +38,22 @@ Reconnect parameters are:
|
|||||||
|
|
||||||
An MQTT last will and testament can be configured:
|
An MQTT last will and testament can be configured:
|
||||||
|
|
||||||
* __lwtMessage__: An optional last will and testament message. Defaults to empty.
|
* __lwtMessage__: An optional last will and testament message. Defaults to empty.
|
||||||
* __lwtTopic__: The last will topic. Defaults to empty and therefore disables the last will.
|
* __lwtTopic__: The last will topic. Defaults to empty and therefore disables the last will.
|
||||||
* __lwtQos__: The optional qos of the last will. Defaults to 0.
|
* __lwtQos__: The optional qos of the last will. Defaults to 0.
|
||||||
* __lwtRetain__: Retain last will message. Defaults to false.
|
* __lwtRetain__: Retain last will message. Defaults to true.
|
||||||
|
|
||||||
|
An MQTT message can be published upon a successful connection to the MQTT broker with these parameters:
|
||||||
|
|
||||||
|
* __birthMessage__: An optional message to be published once the bridge established a connection to the MQTT broker. Defaults to empty.
|
||||||
|
* __birthTopic__: The birth topic. Defaults to empty and therefore no birth message will be published.
|
||||||
|
* __birthRetain__: Retain the birth message. Defaults to true.
|
||||||
|
|
||||||
|
An MQTT message can be published just before disconnecting from the broker with these parameters:
|
||||||
|
|
||||||
|
* __shutdownMessage__: An optional message to be published before the bridge disconnects from the MQTT broker. Defaults to empty.
|
||||||
|
* __shutdownTopic__: The shutdown topic. Defaults to empty and therefore no shutdown message will be published.
|
||||||
|
* __shutdownRetain__: Retain the shutdown message. Defaults to true.
|
||||||
|
|
||||||
For more security, the following optional parameters can be altered:
|
For more security, the following optional parameters can be altered:
|
||||||
|
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
package org.openhab.binding.mqtt.handler;
|
package org.openhab.binding.mqtt.handler;
|
||||||
|
|
||||||
import java.security.NoSuchAlgorithmException;
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.concurrent.ExecutionException;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.TimeoutException;
|
import java.util.concurrent.TimeoutException;
|
||||||
@ -44,6 +45,7 @@ import org.slf4j.LoggerFactory;
|
|||||||
* connection to the {@link MqttService}.
|
* connection to the {@link MqttService}.
|
||||||
*
|
*
|
||||||
* @author David Graeff - Initial contribution
|
* @author David Graeff - Initial contribution
|
||||||
|
* @author Jimmy Tanagra - Add birth and shutdown message
|
||||||
*/
|
*/
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
public class BrokerHandler extends AbstractBrokerHandler implements PinnedCallback {
|
public class BrokerHandler extends AbstractBrokerHandler implements PinnedCallback {
|
||||||
@ -60,12 +62,16 @@ public class BrokerHandler extends AbstractBrokerHandler implements PinnedCallba
|
|||||||
// Store generated client ID if none was set by the user
|
// Store generated client ID if none was set by the user
|
||||||
final MqttBrokerConnection connection = this.connection;
|
final MqttBrokerConnection connection = this.connection;
|
||||||
String clientID = config.clientID;
|
String clientID = config.clientID;
|
||||||
if (connection != null && state == MqttConnectionState.CONNECTED && (clientID == null || clientID.isBlank())) {
|
if (connection != null && state == MqttConnectionState.CONNECTED) {
|
||||||
clientID = connection.getClientId();
|
if (clientID == null || clientID.isBlank()) {
|
||||||
config.clientID = clientID;
|
clientID = connection.getClientId();
|
||||||
Configuration editConfig = editConfiguration();
|
config.clientID = clientID;
|
||||||
editConfig.put("clientid", clientID);
|
Configuration editConfig = editConfiguration();
|
||||||
updateConfiguration(editConfig);
|
editConfig.put("clientid", clientID);
|
||||||
|
updateConfiguration(editConfig);
|
||||||
|
} else {
|
||||||
|
publish(config.birthTopic, config.birthMessage, config.birthRetain);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -114,6 +120,8 @@ public class BrokerHandler extends AbstractBrokerHandler implements PinnedCallba
|
|||||||
public void dispose() {
|
public void dispose() {
|
||||||
try {
|
try {
|
||||||
if (connection != null) {
|
if (connection != null) {
|
||||||
|
publish(config.shutdownTopic, config.shutdownMessage, config.shutdownRetain).get(1000,
|
||||||
|
TimeUnit.MILLISECONDS);
|
||||||
connection.stop().get(1000, TimeUnit.MILLISECONDS);
|
connection.stop().get(1000, TimeUnit.MILLISECONDS);
|
||||||
} else {
|
} else {
|
||||||
logger.warn("Trying to dispose handler {} but connection is already null. Most likely this is a bug.",
|
logger.warn("Trying to dispose handler {} but connection is already null. Most likely this is a bug.",
|
||||||
@ -236,4 +244,15 @@ public class BrokerHandler extends AbstractBrokerHandler implements PinnedCallba
|
|||||||
|
|
||||||
super.initialize();
|
super.initialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calls the @NonNull MqttBrokerConnection::publish() with @Nullable topic and message
|
||||||
|
*/
|
||||||
|
private CompletableFuture<Boolean> publish(@Nullable String topic, @Nullable String message, boolean retain) {
|
||||||
|
if (topic == null || connection == null) {
|
||||||
|
return CompletableFuture.completedFuture(true);
|
||||||
|
}
|
||||||
|
String nonNullMessage = message != null ? message : "";
|
||||||
|
return connection.publish(topic, nonNullMessage.getBytes(), connection.getQos(), retain);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -36,4 +36,14 @@ public class BrokerHandlerConfig extends MqttBrokerConnectionConfig {
|
|||||||
public String publickey = "";
|
public String publickey = "";
|
||||||
|
|
||||||
public boolean enableDiscovery = true;
|
public boolean enableDiscovery = true;
|
||||||
|
|
||||||
|
// Birth message parameters
|
||||||
|
public @Nullable String birthTopic;
|
||||||
|
public @Nullable String birthMessage;
|
||||||
|
public Boolean birthRetain = true;
|
||||||
|
|
||||||
|
// Shutdown message parameters
|
||||||
|
public @Nullable String shutdownTopic;
|
||||||
|
public @Nullable String shutdownMessage;
|
||||||
|
public Boolean shutdownRetain = true;
|
||||||
}
|
}
|
||||||
|
@ -94,6 +94,44 @@
|
|||||||
<advanced>true</advanced>
|
<advanced>true</advanced>
|
||||||
</parameter>
|
</parameter>
|
||||||
|
|
||||||
|
<parameter name="birthMessage" type="text">
|
||||||
|
<label>Birth Message</label>
|
||||||
|
<description>The message to send to the broker when a connection is established.</description>
|
||||||
|
<advanced>true</advanced>
|
||||||
|
</parameter>
|
||||||
|
|
||||||
|
<parameter name="birthTopic" type="text">
|
||||||
|
<label>Birth Topic</label>
|
||||||
|
<description>Defaults to empty and therefore disables the birth message.</description>
|
||||||
|
<advanced>true</advanced>
|
||||||
|
</parameter>
|
||||||
|
|
||||||
|
<parameter name="birthRetain" type="boolean">
|
||||||
|
<label>Birth Message Retain</label>
|
||||||
|
<description>True if the birth message should be retained (defaults to true)</description>
|
||||||
|
<default>true</default>
|
||||||
|
<advanced>true</advanced>
|
||||||
|
</parameter>
|
||||||
|
|
||||||
|
<parameter name="shutdownMessage" type="text">
|
||||||
|
<label>Shutdown Message</label>
|
||||||
|
<description>The message to send to the broker before the connection terminates.</description>
|
||||||
|
<advanced>true</advanced>
|
||||||
|
</parameter>
|
||||||
|
|
||||||
|
<parameter name="shutdownTopic" type="text">
|
||||||
|
<label>Shutdown Topic</label>
|
||||||
|
<description>Defaults to empty and therefore disables the shutdown message.</description>
|
||||||
|
<advanced>true</advanced>
|
||||||
|
</parameter>
|
||||||
|
|
||||||
|
<parameter name="shutdownRetain" type="boolean">
|
||||||
|
<label>Shutdown Message Retain</label>
|
||||||
|
<description>True if the shutdown message should be retained (defaults to true)</description>
|
||||||
|
<default>false</default>
|
||||||
|
<advanced>true</advanced>
|
||||||
|
</parameter>
|
||||||
|
|
||||||
<parameter name="username" type="text">
|
<parameter name="username" type="text">
|
||||||
<label>Username</label>
|
<label>Username</label>
|
||||||
<description>The MQTT username</description>
|
<description>The MQTT username</description>
|
||||||
|
Loading…
Reference in New Issue
Block a user