2020-09-21 01:58:32 +02:00
# Gardena Binding
2020-12-12 20:16:23 +01:00
This is the binding for [Gardena smart system ](https://www.gardena.com/smart ).
2020-09-21 01:58:32 +02:00
This binding allows you to integrate, view and control Gardena smart system devices in the openHAB environment.
## Supported Things
Devices connected to Gardena smart system, currently:
2020-12-12 20:16:23 +01:00
| Thing type | Name |
|--------------------------|----------------------------------------------------|
| bridge | smart Gateway |
| mower | smart SILENO(+), SILENO city, SILENO life Mower |
| sensor | smart Sensor |
| pump | smart Pressure Pump |
| power | smart Power Adapter |
| water_control | smart Water Control |
| irrigation_control | smart Irrigation Control |
2020-09-21 01:58:32 +02:00
## Discovery
An account must be specified, all things for an account are discovered automatically.
## Account Configuration
There are several settings for an account:
2022-07-01 17:38:39 +02:00
| Name | Required | Description |
|-----------------------|----------|-----------------------------------------------------------------------------------------------|
| **apiSecret** | yes | The Gardena smart system integration API secret |
| **apiKey** | yes | The Gardena smart system integration API key |
| **connectionTimeout** | no | The timeout in seconds for connections to Gardena smart system integration API (default = 10) |
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
### Obtaining your API Key
2020-09-21 01:58:32 +02:00
2022-12-08 21:36:05 +01:00
1. Goto < https: // developer . husqvarnagroup . cloud /> , sign in using your GARDENA smart system account and accept the terms of use
1. Create and save a new application via the 'Create application' button. The Redirect URLs do not matter, you can enter what you want (e.g. < http: // localhost:8080 > )
1. Connect both _Authentication API_ and _GARDENA smart system API_ to your application via the 'Connect new API' button
1. Copy the application key to use with this binding as _apiKey_
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
## Examples
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
### Things
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
Minimal Thing configuration:
2020-09-21 01:58:32 +02:00
```java
2022-07-01 17:38:39 +02:00
Bridge gardena:account:home [ apiSecret="...", apiKey="..." ]
2020-09-21 01:58:32 +02:00
```
Configuration of multiple bridges:
```java
2022-07-01 17:38:39 +02:00
Bridge gardena:account:home1 [ apiSecret="...", apiKey="..." ]
Bridge gardena:account:home2 [ apiSecret="...", apiKey="..." ]
2020-09-21 01:58:32 +02:00
```
Once a connection to an account is established, connected Things are discovered automatically.
2020-12-12 20:16:23 +01:00
Alternatively, you can manually configure Things:
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
```java
2022-07-01 17:38:39 +02:00
Bridge gardena:account:home [ apiSecret="...", apiKey="..." ]
2020-09-21 01:58:32 +02:00
{
Thing mower myMower [ deviceId="c81ad682-6e45-42ce-bed1-6b4eff5620c8" ]
2020-12-12 20:16:23 +01:00
Thing water_control myWaterControl [ deviceId="c81ad682-6e45-42ce-bed1-6b4eff5620c8" ]
Thing sensor mySensor [ deviceId="c81ad682-6e45-42ce-bed1-6b4eff5620c8" ]
Thing pump myEPP [ deviceId="c81ad682-6e45-42ce-bed1-6b4eff5620c8" ]
Thing power myPowerSocket [ deviceId="c81ad682-6e45-42ce-bed1-6b4eff5620c8" ]
Thing irrigation_control myIrrigationControl [ deviceId="c81ad682-6e45-42ce-bed1-6b4eff5620c8" ]
2020-09-21 01:58:32 +02:00
}
```
2020-12-12 20:16:23 +01:00
### Items
2020-09-21 01:58:32 +02:00
In the items file, you can link items to channels of your Things:
```java
2020-12-12 20:16:23 +01:00
Number Mower_Battery_Level "Battery [%d %%]" {channel="gardena:mower:home:myMower:common#batteryLevel"}
2020-09-21 01:58:32 +02:00
```
2020-12-12 20:16:23 +01:00
### Sensor refresh
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
Sensor refresh commands are not yet supported by the Gardena smart system integration API.
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
### Example configuration
2020-09-21 01:58:32 +02:00
2022-12-08 21:36:05 +01:00
```java
2020-12-12 20:16:23 +01:00
// smart Water Control
String WC_Valve_Activity "Valve Activity" { channel="gardena:water_control:home:myWateringComputer:valve#activity" }
2023-09-02 23:50:58 +02:00
Number:Time WC_Valve_Duration "Last Watering Duration [%d min]" { channel="gardena:water_control:home:myWateringComputer:valve#duration" }
2020-09-21 01:58:32 +02:00
2023-09-02 23:50:58 +02:00
Number:Time WC_Valve_cmd_Duration "Command Duration [%d min]" { channel="gardena:water_control:home:myWateringComputer:valve_commands#commandDuration" }
Switch WC_Valve_cmd_OpenWithDuration "Start Watering Timer" { channel="gardena:water_control:home:myWateringComputer:valve_commands#start_seconds_to_override" }
2020-12-12 20:16:23 +01:00
Switch WC_Valve_cmd_CloseValve "Stop Switch" { channel="gardena:water_control:home:myWateringComputer:valve_commands#stop_until_next_task" }
2020-09-21 01:58:32 +02:00
2020-12-13 09:19:51 +01:00
openhab:status WC_Valve_Duration // returns the duration of the last watering request if still active, or 0
openhab:status WC_Valve_Activity // returns the current valve activity (CLOSED|MANUAL_WATERING|SCHEDULED_WATERING)
2020-09-21 01:58:32 +02:00
```
2020-12-12 20:16:23 +01:00
All channels are read-only, except the command group and the lastUpdate timestamp
2020-09-21 01:58:32 +02:00
2022-12-08 21:36:05 +01:00
```shell
2023-09-02 23:50:58 +02:00
openhab:send WC_Valve_cmd_Duration.sendCommand(600) // set the duration for the command to 10min
2020-12-13 09:19:51 +01:00
openhab:send WC_Valve_cmd_OpenWithDuration.sendCommand(ON) // start watering
2020-12-13 17:38:07 +01:00
openhab:send WC_Valve_cmd_CloseValve.sendCommand(ON) // stop any active watering
2020-09-21 01:58:32 +02:00
```
2020-12-12 20:16:23 +01:00
If you send a REFRESH command to the last update timestamp (no matter which thing), **ALL** items from **ALL** things are updated
2022-06-16 21:44:25 +02:00
2022-12-08 21:36:05 +01:00
```java
2020-12-12 20:16:23 +01:00
DateTime LastUpdate "LastUpdate [%1$td.%1$tm.%1$tY %1$tH:%1$tM]" { channel="gardena:water_control:home:myWateringComputer:common#lastUpdate_timestamp" }
2022-12-08 21:36:05 +01:00
```
2020-09-21 01:58:32 +02:00
2022-12-08 21:36:05 +01:00
```shell
2020-12-12 20:16:23 +01:00
// refresh ALL items
2020-12-13 09:19:51 +01:00
openhab:send LastUpdate REFRESH
2020-09-21 01:58:32 +02:00
```
2022-08-04 20:20:40 +02:00
### Server Call Rate Limitation
The Gardena server imposes call rate limits to prevent malicious use of its API.
The limits are:
- On average not more than one call every 15 minutes.
- 3000 calls per month.
Normally the binding does not exceed these limits.
But from time to time the server may nevertheless consider the limits to have been exceeded, in which case it reports an HTTP 429 Error (Limit Exceeded).
If such an error occurs you will be locked out of your Gardena account for 24 hours.
In this case the binding will wait in an offline state for the respective 24 hours, after which it will automatically try to reconnect again.
Attempting to force reconnect within the 24 hours causes the call rate to be exceeded further, and therefore just exacerbates the problem.
2020-09-21 01:58:32 +02:00
### Debugging and Tracing
If you want to see what's going on in the binding, switch the loglevel to TRACE in the Karaf console
2022-12-08 21:36:05 +01:00
```shell
2020-09-21 01:58:32 +02:00
log:set TRACE org.openhab.binding.gardena
```
Set the logging back to normal
2022-12-08 21:36:05 +01:00
```shell
2020-09-21 01:58:32 +02:00
log:set INFO org.openhab.binding.gardena
```
2022-12-08 21:36:05 +01:00
**Notes and known limitations:**
2020-12-12 20:16:23 +01:00
When the binding sends a command to a device, it communicates only with the Gardena smart system integration API.
It has no control over whether the command is sent from the online service via your gateway to the device.
2020-09-21 01:58:32 +02:00
It is the same as if you send the command in the Gardena App.
2020-12-12 20:16:23 +01:00
Schedules, sensor-refresh commands, irrigation control master valve configuration etc. are not supported.
This binding relies on the GARDENA smart system integration API.
2022-12-08 21:36:05 +01:00
Further API documentation: < https: / / developer . 1689 . cloud / apis / GARDENA + smart + system + API >
### Troubleshooting
2020-12-12 20:16:23 +01:00
Occasionally it can happen that the API key is no longer valid.
2022-12-08 21:36:05 +01:00
```text
2020-12-12 20:16:23 +01:00
HTTP protocol violation: Authentication challenge without WWW-Authenticate header
```
If this error message appears in the log file, simply renew or delete/create a new API key as described in 'Obtaining your API Key' and restart openHAB.