2020-09-21 01:58:32 +02:00
# OpenGarage Binding
2022-12-14 16:52:43 +01:00
The OpenGarage binding allows you to control an OpenGarage controller (< https: / / opensprinkler . com / product / opengarage / > ) using openHAB
2020-09-21 01:58:32 +02:00
## Supported Things
2023-12-14 22:09:23 +01:00
OpenGarage controllers from < https: / / opensprinkler . com / product / opengarage / > are supported.
2020-09-21 01:58:32 +02:00
## Discovery
2022-12-14 16:52:43 +01:00
Auto-discover is not currently supported.
2020-09-21 01:58:32 +02:00
You need to manually add a new item using its IP address.
## Thing Configuration
As a minimum, the IP address is needed:
2022-12-14 16:52:43 +01:00
- `hostname` - The hostname of the OpenGarage controller. Typically you'd use an IP address such as `192.168.0.5` for this field.
- `port` - the port the OpenGarage is listening on. Defaults to port 80
- `refresh` - The frequency with which to refresh information from the OpenGarage controller specified in seconds. Defaults to 10 seconds.
- `password` - The password to send commands to the OpenGarage. Defaults to "opendoor"
2023-12-14 22:09:23 +01:00
- `doorTransitionTimeSeconds` - Specifies how long it takes the garage door
to fully open / close after triggering it from OpenGarage, including auditory
beeps. Recommend to round up or pad by a second or two.
- `doorOpeningState` - Text state to report when garage is opening. Defaults to "OPENING".
- `doorOpenState` - Text state to report when garage is open (and not in transition). Defaults to "OPEN".
- `doorClosingState` - Text state to report when garage is closing. Defaults to "CLOSING".
- `doorClosedState` - Text state to report when garage is closed (and not in transition). Defaults to "CLOSED".
2020-09-21 01:58:32 +02:00
## Channels
| channel | type | description |
|----------------------|---------------|---------------------------------------------------------------------------------------|
| distance | Number:Length | Distance reading from the OpenGarage controller (default in cm) |
| status-switch | Switch | Door status (OFF = Closed, ON = Open), set "invert=true" on channel to invert switch |
2023-12-14 22:09:23 +01:00
| status-text | String | Text status of the current door state, including transition, using values from configuration: doorOpeningState, doorOpenState, doorClosingState, doorClosedState. |
2020-09-21 01:58:32 +02:00
| status-contact | Contact | Door status (Open or Closed) |
| status-rollershutter | Rollershutter | Door status (DOWN = Closed, UP = Open) |
| vehicle-status | Number | Report vehicle presence (0=Not Detected, 1=Detected, 2=Unknown) |
## Full Example
opengarage.things:
2022-12-14 16:52:43 +01:00
```java
2020-09-21 01:58:32 +02:00
opengarage:opengarage:OpenGarage [ hostname="192.168.0.5" ]
```
opengarage.items:
2022-12-14 16:52:43 +01:00
```java
2020-09-21 01:58:32 +02:00
Switch OpenGarage_Status { channel="opengarage:opengarage:OpenGarage:status" }
Contact OpenGarage_Status_Contact { channel="opengarage:opengarage:OpenGarage:status-contact" }
Rollershutter OpenGarage_Status_Rollershutter { channel="opengarage:opengarage:OpenGarage:status-rollershutter" }
Number:Length OpenGarage_Distance { channel="opengarage:opengarage:OpenGarage:setpoint" }
String OpenGarage_Vehicle { channel="opengarage:opengarage:OpenGarage:vehicle" }
2023-12-14 22:09:23 +01:00
String OpenGarage_StatusText { channel="opengarage:opengarage:OpenGarage:status-text" }
2020-09-21 01:58:32 +02:00
```
opengarage.sitemap:
2022-12-14 16:52:43 +01:00
```perl
2023-12-14 22:09:23 +01:00
Text item=OpenGarage_StatusText label="Status"
2020-09-21 01:58:32 +02:00
Switch item=OpenGarage_Status icon="garagedoorclosed" mappings=[ON=Open] visibility=[OpenGarage_Status == OFF]
Switch item=OpenGarage_Status icon="garagedooropen" mappings=[OFF=Close] visibility=[OpenGarage_Status == ON]
2024-09-28 17:46:53 +02:00
Switch item=OpenGarage_Status icon="garage"
Contact item=OpenGarage_Status_Contact icon="garage"
Rollershutter item=OpenGarage_Status_Rollershutter icon="garage"
2020-09-21 01:58:32 +02:00
Text item=OpenGarage_Distance label="OG distance"
Text item=OpenGarage_Vehicle label="Vehicle Presence"
2023-12-14 22:09:23 +01:00
```
## Adding to HomeKit
If you have the HomeKit extension installed, you can control your OpenGarage instance via your iPhone.
To wire it up to HomeKit, you might specify the following:
opengarage.items
2020-09-21 01:58:32 +02:00
```
2023-12-14 22:09:23 +01:00
Group gOpenGarage "OpenGarage Door" {homekit="GarageDoorOpener"}
Switch OpenGarage_TargetState "Target state" (gOpenGarage) {homekit="GarageDoorOpener.TargetDoorState", channel="opengarage:opengarage:deadbeef:status-switch"}
String OpenGarage_CurrentState "Current state" (gOpenGarage) {homekit="GarageDoorOpener.CurrentDoorState", channel="opengarage:opengarage:deadbeef:status-text"}
Switch OpenGarage_xxObstruction "Obstruction (do not use)" (gOpenGarage) {homekit="GarageDoorOpener.ObstructionStatus"}
```
The obstruction channel is not bound to any channel.
It's needed because HomeKit requires it, and OpenGarage does not provide it.
HomeKit requires a status for the garage door of `OPEN` , `CLOSED` , `CLOSING` , `OPENING` .
In order to report that, we must provide state transition information.
State transition information is inferred when the garage door state is changed.
For `doorTransitionTimeSeconds` since the last open/close command was issued, the binding reports the state as either "closing" or "opening".