Skip to content
This repository has been archived by the owner on May 17, 2021. It is now read-only.

Garadget Binding

John Cocula edited this page Dec 30, 2016 · 6 revisions

Note: This Binding is available in 1.9 and later releases.

Table of Contents

Introduction

The Garadget is cloud-based device that "futurizes" your existing garage door opener, letting you open and close your garage door from anywhere, including via openHAB with this binding. Remote access is made possible with the particle.io REST API.

garadget

For installation of the binding, please see the Wiki page Bindings.

Binding Configuration

In order to use the Particle API to access your Garadget, you must specify the username and password that will be used. These values must be set in the openhab.cfg file (in the folder '${openhab_home}/configurations'). The refresh interval can also be specified, and defaults to 180000ms (three minutes).

################################ Garadget Binding #######################################
#
# the username for accessing your account (required, replace with your own)
#garadget:[email protected]

# the password for accessing your account (required, replace with your own)
# it is your responsbility to ensure that no one can access your username or password
#garadget:password=SuperSecret

# Rate at which to check if poll is to run, in ms (optional, defaults to 5000)
#garadget:granularity=5000

# Data refresh interval in ms (optional, defaults to 180000)
#garadget:refresh=180000

# Time in ms to wait after successful update to garadget state (optional, defaults to 11000)
#garadget:quickpoll=11000

# Time in ms to allow an API request to complete (optional, defaults to 5000)
#garadget:timeout=5000

Item configuration

In order to bind an item to a Garadget's properties, you need to provide configuration settings. To do this, you will add some binding information in your item file (in the folder configurations/items). The syntax for the Garadget binding configuration string is explained below.

Garadget bindings start with a < or >, to indicate if the item receives values from the API (in binding) or sends values to the API (out binding), respectively. A single garadget= binding string can contain multiple in and out bindings separated by commas, so that a single openHAB item can be used to send commands to your Garadget device(s) as well as receive state updates. The Garadget binding suppresses auto-updates of items that are sent commands, so that the actual state reported back from Garadget is used. See the doorState example item below.

The first character (< or >) is then followed by a section between square brackets ([ and ] characters):

[<device>#<property>]

Where <device> is a device identifier and <property> is either a device field or variable (in binding) or function (out binding).

Where can I find my device identifier? A device identifier is a long decimal number. One way to find the number is to login to garag.io and read the URL you were taken to in the browser's address bar:

http://garag.io/my/settings.php?id=270041234567343432313031

> The final component of the URL is your device identifier.

## Example Binding Strings

Here are some examples of valid binding configuration strings, as you would define in your .items file.  Change the device identifiers below to match your Garadget(s).

Group Garadget Group UI

String name "Garage Door [%s]" (Garadget,UI) { garadget="<[270041234567343432313031#name]" }

// A Contact item supports open and closed, but a Garadget doorStatus_status can be: // closed, open, closing, opening, stopped // (as documented here: https://github.com/Garadget/firmware#door-states-status) String doorStatus_status "Status [%s]" (Garadget,UI) { garadget="<[270041234567343432313031#doorStatus_status]" } String doorStatus_time "Last Change [%s ago]" (Garadget,UI) { garadget="<[270041234567343432313031#doorStatus_time]" }

// Send the doorState item commands like ZERO, HUNDRED, UP, DOWN, ON, OFF, STOP, or "open", "closed" or "stop". Rollershutter doorState "Control" (Garadget,UI) { garadget=">[270041234567343432313031#setState],<[270041234567343432313031#doorStatus_status]" } Number doorStatus_sensor "Reflection [%d %%]" (Garadget,UI) { garadget="<[270041234567343432313031#doorStatus_sensor]" } Number doorConfig_srt "Threshold [%d %%]" (Garadget,UI) { garadget="<[270041234567343432313031#doorConfig_srt]" } Number doorStatus_signal "Signal [%d dB]" (Garadget,UI) { garadget="<[270041234567343432313031#doorStatus_signal]" } String last_app "Last App [%s]" (Garadget) { garadget="<[270041234567343432313031#last_app]" } String last_ip_address "Last IP Address [%s]" (Garadget) { garadget="<[270041234567343432313031#last_ip_address]" } DateTime last_heard "Last Heard [%1$tm/%1$td %1$tH:%1$tM]" (Garadget) { garadget="<[270041234567343432313031#last_heard]" } Number product_id "Product ID [%d]" (Garadget) { garadget="<[270041234567343432313031#product_id]" } Switch connected "Connected [%s]" (Garadget) { garadget="<[270041234567343432313031#connected]" }

String doorStatus "Door Status [%s]" (Garadget) { garadget="<[270041234567343432313031#doorStatus]" }

String doorConfig "Door Config [%s]" (Garadget) { garadget="<[270041234567343432313031#doorConfig]" } Number doorConfig_ver "Version [%.1f]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_ver]" } Number doorConfig_rdt "Sensor Scan Interval [%d ms]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_rdt]" } Number doorConfig_mtt "Door Moving Time [%d ms]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_mtt]" } Number doorConfig_rlt "Button Press Time [%d ms]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_rlt]" } Number doorConfig_rlp "Delay betw Presses [%d ms]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_rlp]" } Number doorConfig_srr "Sensor reads [%d]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_srr]" } Number doorConfig_aot "Open Timeout Alert [%d min]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_aot]" } Number doorConfig_ans "Night time alert start [%d min from midnight]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_ans]" } Number doorConfig_ane "Night time alert end [%d min from midnight]" (Garadget) { garadget="<[270041234567343432313031#doorConfig_ane]" }

String netConfig "Net Config [%s]" (Garadget) { garadget="<[270041234567343432313031#netConfig]" } String netConfig_ip "IP Address [%s]" (Garadget) { garadget="<[270041234567343432313031#netConfig_ip]" } String netConfig_snet "Subnet [%s]" (Garadget) { garadget="<[270041234567343432313031#netConfig_snet]" } String netConfig_gway "Gateway [%s]" (Garadget) { garadget="<[270041234567343432313031#netConfig_gway]" } String netConfig_mac "MAC address [%s]" (Garadget) { garadget="<[270041234567343432313031#netConfig_mac]" } String netConfig_ssid "SSID [%s]" (Garadget) { garadget="<[270041234567343432313031#netConfig_ssid]" }

// send the setConfig item commands like "ans=1200|ane=420" to set night time alert to 8pm-7am, for example. String setConfig "Workshop Garage Door Config [%s]" (Garadget) { garadget=">[270041234567343432313031#setConfig],<[270040001747343432313031#doorConfig]" }


## Logging

To configure DEBUG or TRACE logging for the Garadget binding to be sent to a separate file, add the following to your `logback.xml` file:
```xml
<appender name="GARADGETFILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
   <file>logs/garadget.log</file>
   <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <!-- weekly rollover and archiving -->
      <fileNamePattern>logs/garadget-%d{yyyy-ww}.log.zip</fileNamePattern>
      <!-- keep 30 days' worth of history -->
      <maxHistory>30</maxHistory>
   </rollingPolicy>
   <encoder>
     <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger{30}[:%line]- %msg%n%ex{5}</pattern>
   </encoder>
</appender>
    
<!-- Change DEBUG->TRACE for even more detailed logging -->
<logger name="org.openhab.binding.garadget" level="DEBUG" additivity="false">
   <appender-ref ref="GARADGETFILE" />
</logger>

Change Log

1.9.0

  • Initial release. Until then, consider using this JAR file.
  • Removed misleading text on exception logs (#4663)

Installation


User Interfaces


Community

(link to openHAB forum)

Development



Misc


Samples

A good source of inspiration and tips from users gathered over the years. Be aware that things may have changed since they were written and some examples might not work correctly.

Please update the wiki if you do come across any out of date information.

Use case examples

Collections of Rules on a single page

Single Rules

Scripts


Release Notes

Clone this wiki locally