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
2020-12-12 20:16:23 +01:00
1. Goto https://developer.husqvarnagroup.cloud/, sign in using your GARDENA smart system account and accept the terms of use
2022-07-01 17:38:39 +02:00
2. 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)
2020-12-12 20:16:23 +01:00
3. Connect both _Authentication API_ and _GARDENA smart system API_ to your application via the 'Connect new API' button
4. 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
```
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" }
Number WC_Valve_Duration "Last Watering Duration [%d min]" { channel="gardena:water_control:home:myWateringComputer:valve#duration" }
2020-09-21 01:58:32 +02:00
2020-12-12 20:16:23 +01:00
Number WC_Valve_cmd_Duration "Command Duration [%d min]" { channel="gardena:water_control:home:myWateringComputer:valve_commands#commandDuration" }
Switch WC_Valve_cmd_OpenWithDuration "Watering Timer [%d min]" { channel="gardena:water_control:home:myWateringComputer:valve_commands#start_seconds_to_override" }
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
```
2020-12-13 09:19:51 +01:00
openhab:send WC_Valve_cmd_Duration.sendCommand(10) // set the duration for the command to 10min
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
2020-09-21 01:58:32 +02:00
```
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" }
2020-09-21 01:58:32 +02:00
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
```
### Debugging and Tracing
If you want to see what's going on in the binding, switch the loglevel to TRACE in the Karaf console
```
log:set TRACE org.openhab.binding.gardena
```
Set the logging back to normal
```
log:set INFO org.openhab.binding.gardena
```
2020-12-12 20:16:23 +01:00
**Notes and known limitations:**
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.
Further API documentation: https://developer.1689.cloud/apis/GARDENA+smart+system+API
###Troubleshooting
Occasionally it can happen that the API key is no longer valid.
```
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.