This page is part of archived documentation for openHAB 2.5. Go to the current stable version
# XMPP Actions v1
This set of actions allows you to send a message to an XMPP user or multi-user chat, or send a message with an attachment to an XMPP user.
# Actions
sendXMPP(String to, String message)
: Sends a message to an XMPP usersendXMPP(String to, String message, String attachmentUrl)
: Sends a message with an attachment to an XMPP userchatXMPP(String message)
: Sends a message to a multi user chat
# Configuration
The XMPP Action service can be configured in services/xmpp.cfg
.
Property | Default | Required | Description |
---|---|---|---|
username | The username of the XMPP account used by openHAB. Most services will require that you use only the localpart of the account's JID. For example if your account's JID is myuser@example.org , then only configure myuser . | ||
password | The password of the XMPP account used by openHAB | ||
servername | The XMPP service to use, e.g. jabber.de . A list of public XMPP services can be found at https://xmpp.net/directory.php (opens new window) | ||
securitymode | disabled | No | The Security mode used for the XMPP connection. Can be either required or disabled . Defaults to disabled , which means that TLS will not be used. Warning: If you change this to non-disabled, then you must make sure that your TLS server certificate can be validated, otherwhise the connection will fail. |
tlspin | The TLS Pin used to verify the XMPP service's certificate. Set this in case openHAB's default SSLContext is unable to verify it (e.g. because the XMPP service uses a self-signed certificate). The PIN value is basically the hash of the certificate in hexadecimal notation. Set securitymode to required to enable TLS for XMPP connections. PIN generation is discussed in detail here (opens new window) or see this example. Example: tlspin=CERTSHA256:83:F9:17:1E:06:A3:13:11:88:89:F7:D7:93:02:BD:1B:7A:20:42:EE:0C:FD:02:9A:BF:8D:D0:6F:FA:6C:D9:D3 | ||
proxy | The XMPP Proxyserver to use, e.g. gmail.com | ||
port | 5222 | The server port to use | |
consoleusers | A comma-separated list of users that are allowed to use the XMPP console | ||
chatroom | The multi user chat to join, e.g. openhab@chat.example.com | ||
chatnickname | openhab-bot | No | The nickname used in the multi-user chat |
chatpassword | The password required to join the multi user chat |
Note: openHAB does not resolve SRV entries like other XMPP clients do, you have to setup the server details manually.
Generally, if joe@example.org
is your XMPP user ID and xmpp.example.net
points to the server running the service, set servername
to the actual server xmpp.example.net
, the user name username
to joe
and proxy
to the domain name part of your user ID example.org
.
# Example: Google
servername=talk.google.com
securitymode=required
# You need this "tlspin" if openhab cannot verify the certificate from the google server <Badge type="warn" text="v1"/>
tlspin=CERTSHA256:9e670d6624fc0c451d8d8e3efa81d4d8246ff9354800de09b549700e8d2a730a
proxy=gmail.com
username=my.openhab@gmail.com
password=mysecret
# you may need to add the cryptic talk.google.com address of your private google account to the allowed users <Badge type="warn" text="v1"/>
# check you openhab.log to found the address after you send something via Hangouts to your openHAB account <Badge type="warn" text="v1"/>
consoleusers=**cryptic**@public.talk.google.com,myname@gmail.com
# Example: Generate PIN
Assuming the PEM-encoded certificate is in a file called jabber.crt
(it is PEM encoded if it contains the lines BEGIN CERTIFICATE
and END CERTIFICATE
with lots of dashes in them) this shell invocation prints the required value for the tlspin=
configuration setting:
$ echo "CERTSHA256:$(openssl x509 -in "jabber.crt" -noout -fingerprint -sha256 | sed 's/.*=//')"
CERTSHA256:D8:8E:B1:....:7D:84
You then copy the whole last line into tlspin
.