openhab-addons/bundles/org.openhab.binding.webexteams
2024-01-03 11:50:55 +01:00
..
src/main Adapt to core changes (ThingHandlerService) (#16107) 2024-01-03 11:50:55 +01:00
NOTICE [webexteams] Initial contribution (#13492) 2022-12-04 12:15:42 +01:00
pom.xml Apply spotless after release (#16097) 2023-12-22 23:30:38 +01:00
README.md [Documentation] Markdown improvements t to z (#14371) 2023-04-11 12:54:54 +02:00

WebexTeams Binding

The Webex Team binding allows to send messages to Webex Teams users and rooms through a number of actions.

Messages can use markdown syntax, and attachments are supported.

Supported Things

  • account: A Webex Teams account

Discovery

No Things are being discovered by this binding.

Thing Configuration

Webex Teams supports two main types of app integration:

  • Bot: a separate identity that can be used to communicate with people and rooms.
  • Person integration: OAuth integration that allows the binding to act on behalf of a persons.

Both of these accounts must be first configured on the Webex Developers website. When creating a person integration, it's important you customize the redirect URL based on your OpenHab installation. For example if you run your openHAB server on http://openhab:8080 you should add http://openhab:8080/connectwebex to the redirect URIs.

To use a bot account, only configure the token (Authentication token).

To use a person integration, configure clientId and clientSecret. When the account is configured as a Thing in OpenHab, navigate to the redirect URL (as described above) and authorize your account.

You shouldn't configure both an authentication token (used for bots) AND clientId/clientSecret (used for person integrations). In that case the binding will use the authentication token.

A default room id is required for use with the sendMessage action.

account Thing Configuration

Name Type Description Default Required Advanced
token text (Bot) authentication token N/A no no
clientId text (Person) client id N/A no no
clientSecret text (Person) client secret N/A no no
refreshPeriod integer Refresh period for channels (seconds) 300 no no
roomId text ID of the default room N/A no no

Channels

Thing channel type description
WebexTeams Account status String Account presence status: active, call, inactive, ...
WebexTeams Account lastactivity DateTime The date and time of the person's last activity within Webex

Note: status and lastactivity are only updated for person integrations

Full Example

webexteams.things:

Configure a bot account:

Thing webexteams:account:bot [ token="XXXXXX", roomId="YYYYYY" ]

Configure a person integration account:

Thing webexteams:account:person [ clientId="XXXXXX", clientSecret="YYYYYY", roomId="ZZZZZZ" ]

Rule Action

DSL rules use getActions to get a reference to the thing.

val botActions = getActions("webexteams", "webexteams:account:bot")

This binding includes these rule actions for sending messages:

  • var success = botActions.sendMessage(String markdown) - Send a message to the default room.
  • var success = botActions.sendMessage(String markdown, String attach) - Send a message to the default room, with attachment.
  • var success = botActions.sendRoomMessage(String roomId, String markdown) - Send a message to a specific room.
  • var success = botActions.sendRoomMessage(String roomId, String markdown, String attach) - Send a message to a specific room, with attachment.
  • var success = botActions.sendPersonMessage(String personEmail, String markdown) - Send a direct message to a person.
  • var success = botActions.sendPersonMessage(String personEmail, String markdown, String attach) - Send a direct message to a person, with attachment.

Sending messages for bot or person accounts works exactly the same. Attachments must be URLs.
Sending local files is not supported at this moment.