mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
31cca5ee1f
* Add null annotations * Introduce re-connect logic Signed-off-by: lsiepel <leosiepel@gmail.com> Signed-off-by: Leo Siepel <leosiepel@gmail.com>
89 lines
4.0 KiB
Markdown
89 lines
4.0 KiB
Markdown
# XMPPClient Binding
|
|
|
|
XMPPClient binding provides support for sending and receiving XMPP (Jabber) messages.
|
|
|
|
## Supported Things
|
|
|
|
xmppBridge - Basic XMPP (Jabber) client thing, that can send and receive messages.
|
|
|
|
## Thing Configuration
|
|
|
|
Sample configurations:
|
|
|
|
```java
|
|
Bridge xmppclient:xmppBridge:xmpp "XMPP Client" [ username="openhab", domain="example.com", password="********" ] {
|
|
Channels:
|
|
Trigger String : xmpp_command [ separator="##" ]
|
|
}
|
|
```
|
|
|
|
```java
|
|
Bridge xmppclient:xmppBridge:xmpp "XMPP Client" [ host="xmpp.example.com", port=7222, username="openhab", domain="example.com", password="********" ] {
|
|
Channels:
|
|
Trigger String : xmpp_command [ separator="##" ]
|
|
}
|
|
```
|
|
|
|
**xmppBridge** parameters:
|
|
|
|
| Name | Label | Description | Required | Default value |
|
|
|--------------|--------------------|--------------------------------------------------------------------|----------|-----------------------|
|
|
| username | Username | The XMPP username (left part of JID) | true | - |
|
|
| domain | Domain | The XMPP domain name (right part of JID) | true | - |
|
|
| password | Password | The XMPP user password | true | - |
|
|
| host | Server Hostname/IP | The IP/Hostname of the XMPP server | false | as "domain" parameter |
|
|
| port | XMPP server Port | The typical port is 5222 | false | 5222 |
|
|
| securityMode | Security Mode | Sets the TLS security mode: `required`, `ifpossible` or `disabled` | false | `required` |
|
|
|
|
## Channels
|
|
|
|
**publishTrigger** parameters:
|
|
|
|
| Name | Label | Description | Required |
|
|
|-----------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|
|
| payload | Payload condition | An optional condition on the value | false |
|
|
| separator | Separator character | The trigger channel payload usually only contains the received text. If you define a separator character, for example '#', the sender UID and received text will be in the trigger channel payload. For example: pavel@example.com#My Message Text | false |
|
|
|
|
## Example Rules
|
|
|
|
Send message:
|
|
|
|
```java
|
|
rule "Leak detected"
|
|
when
|
|
Item Xi_Leak changed
|
|
then
|
|
if(Xi_Leak.state == ON) {
|
|
val actions = getActions("xmppclient","xmppclient:xmppBridge:xmpp")
|
|
actions.publishXMPP("pavel@example.com","Warning! Leak detected!")
|
|
}
|
|
end
|
|
```
|
|
|
|
Receive and process message:
|
|
|
|
```java
|
|
rule "Turn off all lights without separator"
|
|
when
|
|
Channel "xmppclient:xmppBridge:xmpp:xmpp_command" triggered
|
|
then
|
|
var actionName = receivedEvent
|
|
if(actionName.toLowerCase() == "turn off lights") {
|
|
Group_Light_Home_All.sendCommand(OFF)
|
|
}
|
|
end
|
|
|
|
rule "Turn off all lights with separator and reply"
|
|
when
|
|
Channel "xmppclient:xmppBridge:xmpp:xmpp_command" triggered
|
|
then
|
|
var actionName = receivedEvent.split("##")
|
|
if(actionName.get(1).toLowerCase() == "turn off lights") {
|
|
Group_Light_Home_All.sendCommand(OFF)
|
|
|
|
val actions = getActions("xmppclient","xmppclient:xmppBridge:xmpp")
|
|
actions.publishXMPP(actionName.get(0),"All lights was turned off")
|
|
}
|
|
end
|
|
```
|