mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-13 00:22:20 +01:00
261 lines
27 KiB
Markdown
261 lines
27 KiB
Markdown
|
# Nest Binding
|
||
|
|
||
|
The Nest binding integrates devices by [Nest](https://nest.com) using the [Nest API](https://developers.nest.com/documentation/cloud/get-started) (REST).
|
||
|
|
||
|
Because the Nest API runs on Nest's servers a connection with the Internet is required for sending and receiving information.
|
||
|
The binding uses HTTPS to connect to the Nest API using ports 443 and 9553. Make sure outbound connections to these ports are not blocked by a firewall.
|
||
|
|
||
|
> Note: This binding can only be used with Nest devices if you have an existing Nest developer account signed up for the Works with Nest (WWN) program.
|
||
|
New integrations using the WWN program are no longer accepted because WWN is being retired.
|
||
|
To keep using this binding do **NOT** migrate your Nest Account to a Google Account.
|
||
|
For more information see [What's happening at Nest?](https://nest.com/whats-happening/).
|
||
|
|
||
|
## Supported Things
|
||
|
|
||
|
The table below lists the Nest binding thing types:
|
||
|
|
||
|
| Things | Description | Thing Type |
|
||
|
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|
||
|
| Nest Account | An account for using the Nest REST API | account |
|
||
|
| Nest Cam (Indoor, IQ, Outdoor), Dropcam | A Nest Cam registered with your account | camera |
|
||
|
| Nest Protect | The smoke detector/Nest Protect for the account | smoke_detector |
|
||
|
| Structure | The Nest structure defines the house the account has setup on Nest. You will only have more than one structure if you have more than one house | structure |
|
||
|
| Nest Thermostat (E) | A Thermostat to control the various aspects of the house's HVAC system | thermostat |
|
||
|
|
||
|
## Authorization
|
||
|
|
||
|
The Nest API uses OAuth for authorization.
|
||
|
Therefore the binding needs some authorization parameters before it can access your Nest account via the Nest API.
|
||
|
|
||
|
To get these authorization parameters you first need to sign up as a [Nest Developer](https://developer.nest.com) and [register a new Product](https://developer.nest.com/products/new) (free and instant).
|
||
|
|
||
|
While registering a new Product (on the Product Details page) make sure to:
|
||
|
|
||
|
* Leave both "OAuth Redirect URI" fields empty to enable PIN-based authorization.
|
||
|
* Grant all the permissions you intend to use. When in doubt, enable the permission because the binding needs to be reauthorized when permissions change at a later time.
|
||
|
|
||
|
After creating the Product, your browser shows the Product Overview page.
|
||
|
This page contains the **Product ID** and **Product Secret** authorization parameters that are used by the binding.
|
||
|
Take note of both parameters or keep this page open in a browser tab.
|
||
|
Now copy and paste the "Authorization URL" in a new browser tab.
|
||
|
Accept the permissions and you will be presented the **Pincode** authorization parameter that is also used by the binding.
|
||
|
|
||
|
You can return to the Product Overview page at a later time by opening the [Products](https://console.developers.nest.com/products) page and selecting your Product.
|
||
|
|
||
|
## Discovery
|
||
|
|
||
|
The binding will discover all Nest Things from your account when you add and configure a "Nest Account" Thing.
|
||
|
See the Authorization paragraph above for details on how to obtain the Product ID, Product Secret and Pincode configuration parameters.
|
||
|
|
||
|
Once the binding has successfully authorized with the Nest API, it obtains an Access Token using the Pincode.
|
||
|
The configured Pincode is cleared because it can only be used once.
|
||
|
The obtained Access Token is saved as an advanced configuration parameter of the "Nest Account".
|
||
|
|
||
|
You can reuse an Access Token for authorization but not the Pincode.
|
||
|
A new Pincode can again be generated via the "Authorization URL" (see Authorization paragraph).
|
||
|
|
||
|
## Channels
|
||
|
|
||
|
### Account Channels
|
||
|
|
||
|
The account Thing Type does not have any channels.
|
||
|
|
||
|
### Camera Channels
|
||
|
|
||
|
**Camera group channels**
|
||
|
|
||
|
Information about the camera.
|
||
|
|
||
|
| Channel Type ID | Item Type | Description | Read Write |
|
||
|
|-----------------------|-----------|---------------------------------------------------|:----------:|
|
||
|
| app_url | String | The app URL to see the camera | R |
|
||
|
| audio_input_enabled | Switch | If the audio input is currently enabled | R |
|
||
|
| last_online_change | DateTime | Timestamp of the last online status change | R |
|
||
|
| public_share_enabled | Switch | If public sharing is currently enabled | R |
|
||
|
| public_share_url | String | The URL to see the public share of the camera | R |
|
||
|
| snapshot_url | String | The URL to use for a snapshot of the video stream | R |
|
||
|
| streaming | Switch | If the camera is currently streaming | R/W |
|
||
|
| video_history_enabled | Switch | If the video history is currently enabled | R |
|
||
|
| web_url | String | The web URL to see the camera | R |
|
||
|
|
||
|
**Last event group channels**
|
||
|
|
||
|
Information about the last camera event (requires Nest Aware subscription).
|
||
|
|
||
|
| Channel Type ID | Item Type | Description | Read Write |
|
||
|
|--------------------|-----------|------------------------------------------------------------------------------------|:----------:|
|
||
|
| activity_zones | String | Identifiers for activity zones that detected the event (comma separated) | R |
|
||
|
| animated_image_url | String | The URL showing an animated image for the camera event | R |
|
||
|
| app_url | String | The app URL for the camera event, allows you to see the camera event in an app | R |
|
||
|
| end_time | DateTime | Timestamp when the camera event ended | R |
|
||
|
| has_motion | Switch | If motion was detected in the camera event | R |
|
||
|
| has_person | Switch | If a person was detected in the camera event | R |
|
||
|
| has_sound | Switch | If sound was detected in the camera event | R |
|
||
|
| image_url | String | The URL showing an image for the camera event | R |
|
||
|
| start_time | DateTime | Timestamp when the camera event started | R |
|
||
|
| urls_expire_time | DateTime | Timestamp when the camera event URLs expire | R |
|
||
|
| web_url | String | The web URL for the camera event, allows you to see the camera event in a web page | R |
|
||
|
|
||
|
### Smoke Detector Channels
|
||
|
|
||
|
| Channel Type ID | Item Type | Description | Read Write |
|
||
|
|-----------------------|-----------|-----------------------------------------------------------------------------------|:----------:|
|
||
|
| co_alarm_state | String | The carbon monoxide alarm state of the Nest Protect (OK, EMERGENCY, WARNING) | R |
|
||
|
| last_connection | DateTime | Timestamp of the last successful interaction with Nest | R |
|
||
|
| last_manual_test_time | DateTime | Timestamp of the last successful manual test | R |
|
||
|
| low_battery | Switch | Reports whether the battery of the Nest protect is low (if it is battery powered) | R |
|
||
|
| manual_test_active | Switch | Manual test active at the moment | R |
|
||
|
| smoke_alarm_state | String | The smoke alarm state of the Nest Protect (OK, EMERGENCY, WARNING) | R |
|
||
|
| ui_color_state | String | The current color of the ring on the smoke detector (GRAY, GREEN, YELLOW, RED) | R |
|
||
|
|
||
|
### Structure Channels
|
||
|
|
||
|
| Channel Type ID | Item Type | Description | Read Write |
|
||
|
|------------------------------|-----------|--------------------------------------------------------------------------------------------------------|:----------:|
|
||
|
| away | String | Away state of the structure (HOME, AWAY) | R/W |
|
||
|
| country_code | String | Country code of the structure ([ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)) | R |
|
||
|
| co_alarm_state | String | Carbon Monoxide alarm state (OK, EMERGENCY, WARNING) | R |
|
||
|
| eta_begin | DateTime | Estimated time of arrival at home, will setup the heat to turn on and be warm | R |
|
||
|
| peak_period_end_time | DateTime | Peak period end for the Rush Hour Rewards program | R |
|
||
|
| peak_period_start_time | DateTime | Peak period start for the Rush Hour Rewards program | R |
|
||
|
| postal_code | String | Postal code of the structure | R |
|
||
|
| rush_hour_rewards_enrollment | Switch | If rush hour rewards system is enabled or not | R |
|
||
|
| security_state | String | Security state of the structure (OK, DETER) | R |
|
||
|
| smoke_alarm_state | String | Smoke alarm state (OK, EMERGENCY, WARNING) | R |
|
||
|
| time_zone | String | The time zone for the structure ([IANA time zone format](https://www.iana.org/time-zones)) | R |
|
||
|
|
||
|
### Thermostat Channels
|
||
|
|
||
|
| Channel Type ID | Item Type | Description | Read Write |
|
||
|
|-----------------------------|----------------------|----------------------------------------------------------------------------------------|:----------:|
|
||
|
| can_cool | Switch | If the thermostat can actually turn on cooling | R |
|
||
|
| can_heat | Switch | If the thermostat can actually turn on heating | R |
|
||
|
| eco_max_set_point | Number:Temperature | The eco range max set point temperature | R |
|
||
|
| eco_min_set_point | Number:Temperature | The eco range min set point temperature | R |
|
||
|
| fan_timer_active | Switch | If the fan timer is engaged | R/W |
|
||
|
| fan_timer_duration | Number:Time | Length of time that the fan is set to run (15, 30, 45, 60, 120, 240, 480, 960 minutes) | R/W |
|
||
|
| fan_timer_timeout | DateTime | Timestamp when the fan stops running | R |
|
||
|
| has_fan | Switch | If the thermostat can control the fan | R |
|
||
|
| has_leaf | Switch | If the thermostat is currently in a leaf mode | R |
|
||
|
| humidity | Number:Dimensionless | Indicates the current relative humidity | R |
|
||
|
| last_connection | DateTime | Timestamp of the last successful interaction with Nest | R |
|
||
|
| locked | Switch | If the thermostat has the temperature locked to only be within a set range | R |
|
||
|
| locked_max_set_point | Number:Temperature | The locked range max set point temperature | R |
|
||
|
| locked_min_set_point | Number:Temperature | The locked range min set point temperature | R |
|
||
|
| max_set_point | Number:Temperature | The max set point temperature | R/W |
|
||
|
| min_set_point | Number:Temperature | The min set point temperature | R/W |
|
||
|
| mode | String | Current mode of the Nest thermostat (HEAT, COOL, HEAT_COOL, ECO, OFF) | R/W |
|
||
|
| previous_mode | String | The previous mode of the Nest thermostat (HEAT, COOL, HEAT_COOL, ECO, OFF) | R |
|
||
|
| state | String | The active state of the Nest thermostat (HEATING, COOLING, OFF) | R |
|
||
|
| temperature | Number:Temperature | Current temperature | R |
|
||
|
| time_to_target | Number:Time | Time left to the target temperature approximately | R |
|
||
|
| set_point | Number:Temperature | The set point temperature | R/W |
|
||
|
| sunlight_correction_active | Switch | If sunlight correction is active | R |
|
||
|
| sunlight_correction_enabled | Switch | If sunlight correction is enabled | R |
|
||
|
| using_emergency_heat | Switch | If the system is currently using emergency heat | R |
|
||
|
|
||
|
Note that the Nest API rounds Thermostat values so they will differ from what shows up in the Nest App.
|
||
|
The Nest API applies the following rounding:
|
||
|
|
||
|
* degrees Celsius to 0.5 degrees
|
||
|
* degrees Fahrenheit to whole degrees
|
||
|
* humidity to 5%
|
||
|
|
||
|
## Example
|
||
|
|
||
|
You can use the discovery functionality of the binding to obtain the deviceId and structureId values for defining Nest things in files.
|
||
|
|
||
|
Another way to get the deviceId and structureId values is by querying the Nest API yourself. First [obtain an Access Token](https://developers.nest.com/documentation/cloud/sample-code-auth) (or use the Access Token obtained by the binding).
|
||
|
Then use it with one of the [API Read Examples](https://developers.nest.com/documentation/cloud/how-to-read-data).
|
||
|
|
||
|
### demo.things:
|
||
|
|
||
|
```
|
||
|
Bridge nest:account:demo_account [ productId="8fdf9885-ca07-4252-1aa3-f3d5ca9589e0", productSecret="QITLR3iyUlWaj9dbvCxsCKp4f", accessToken="c.6rse1xtRk2UANErcY0XazaqPHgbvSSB6owOrbZrZ6IXrmqhsr9QTmcfaiLX1l0ULvlI5xLp01xmKeiojHqozLQbNM8yfITj1LSdK28zsUft1aKKH2mDlOeoqZKBdVIsxyZk4orH0AvKEZ5aY" ] {
|
||
|
camera fish_cam [ deviceId="qw0NNE8ruxA9AGJkTaFH3KeUiJaONWKiH9Gh3RwwhHClonIexTtufQ" ]
|
||
|
smoke_detector hallway_smoke [ deviceId="Tzvibaa3lLKnHpvpi9OQeCI_z5rfkBAV" ]
|
||
|
structure home [ structureId="20wKjydArmMV3kOluTA7JRcZg8HKBzTR-G_2nRXuIN1Bd6laGLOJQw" ]
|
||
|
thermostat living_thermostat [ deviceId="ZqAKzSv6TO6PjBnOCXf9LSI_z5rfkBAV" ]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### demo.items:
|
||
|
|
||
|
|
||
|
```
|
||
|
/* Camera */
|
||
|
String Cam_App_URL "App URL [%s]" { channel="nest:camera:demo_account:fish_cam:camera#app_url" }
|
||
|
Switch Cam_Audio_Input_Enabled "Audio Input Enabled" { channel="nest:camera:demo_account:fish_cam:camera#audio_input_enabled" }
|
||
|
DateTime Cam_Last_Online_Change "Last Online Change [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:camera:demo_account:fish_cam:camera#last_online_change" }
|
||
|
String Cam_Snapshot_URL "Snapshot URL [%s]" { channel="nest:camera:demo_account:fish_cam:camera#snapshot_url" }
|
||
|
Switch Cam_Streaming "Streaming" { channel="nest:camera:demo_account:fish_cam:camera#streaming" }
|
||
|
Switch Cam_Public_Share_Enabled "Public Share Enabled" { channel="nest:camera:demo_account:fish_cam:camera#public_share_enabled" }
|
||
|
String Cam_Public_Share_URL "Public Share URL [%s]" { channel="nest:camera:demo_account:fish_cam:camera#public_share_url" }
|
||
|
Switch Cam_Video_History_Enabled "Video History Enabled" { channel="nest:camera:demo_account:fish_cam:camera#video_history_enabled" }
|
||
|
String Cam_Web_URL "Web URL [%s]" { channel="nest:camera:demo_account:fish_cam:camera#web_url" }
|
||
|
String Cam_LE_Activity_Zones "Last Event Activity Zones [%s]" { channel="nest:camera:demo_account:fish_cam:last_event#activity_zones" }
|
||
|
String Cam_LE_Animated_Image_URL "Last Event Animated Image URL [%s]" { channel="nest:camera:demo_account:fish_cam:last_event#animated_image_url" }
|
||
|
String Cam_LE_App_URL "Last Event App URL [%s]" { channel="nest:camera:demo_account:fish_cam:last_event#app_url" }
|
||
|
DateTime Cam_LE_End_Time "Last Event End Time [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:camera:demo_account:fish_cam:last_event#end_time" }
|
||
|
Switch Cam_LE_Has_Motion "Last Event Has Motion" { channel="nest:camera:demo_account:fish_cam:last_event#has_motion" }
|
||
|
Switch Cam_LE_Has_Person "Last Event Has Person" { channel="nest:camera:demo_account:fish_cam:last_event#has_person" }
|
||
|
Switch Cam_LE_Has_Sound "Last Event Has Sound" { channel="nest:camera:demo_account:fish_cam:last_event#has_sound" }
|
||
|
String Cam_LE_Image_URL "Last Event Image URL [%s]" { channel="nest:camera:demo_account:fish_cam:last_event#image_url" }
|
||
|
DateTime Cam_LE_Start_Time "Last Event Start Time [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:camera:demo_account:fish_cam:last_event#start_time" }
|
||
|
DateTime Cam_LE_URLs_Expire_Time "Last Event URLs Expire Time [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:camera:demo_account:fish_cam:last_event#urls_expire_time" }
|
||
|
String Cam_LE_Web_URL "Last Event Web URL [%s]" { channel="nest:camera:demo_account:fish_cam:last_event#web_url" }
|
||
|
|
||
|
/* Smoke Detector */
|
||
|
String Smoke_CO_Alarm "CO Alarm [%s]" { channel="nest:smoke_detector:demo_account:hallway_smoke:co_alarm_state" }
|
||
|
Switch Smoke_Battery_Low "Battery Low" { channel="nest:smoke_detector:demo_account:hallway_smoke:low_battery" }
|
||
|
Switch Smoke_Manual_Test "Manual Test" { channel="nest:smoke_detector:demo_account:hallway_smoke:manual_test_active" }
|
||
|
DateTime Smoke_Last_Connection "Last Connection [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:smoke_detector:demo_account:hallway_smoke:last_connection" }
|
||
|
DateTime Smoke_Last_Manual_Test "Last Manual Test [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:smoke_detector:demo_account:hallway_smoke:last_manual_test_time" }
|
||
|
String Smoke_Smoke_Alarm "Smoke Alarm [%s]" { channel="nest:smoke_detector:demo_account:hallway_smoke:smoke_alarm_state" }
|
||
|
String Smoke_UI_Color "UI Color [%s]" { channel="nest:smoke_detector:demo_account:hallway_smoke:ui_color_state" }
|
||
|
|
||
|
/* Thermostat */
|
||
|
Switch Thermostat_Can_Cool "Can Cool" { channel="nest:thermostat:demo_account:living_thermostat:can_cool" }
|
||
|
Switch Thermostat_Can_Heat "Can Heat" { channel="nest:thermostat:demo_account:living_thermostat:can_heat" }
|
||
|
Number:Temperature Therm_EMaxSP "Eco Max Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:eco_max_set_point" }
|
||
|
Number:Temperature Therm_EMinSP "Eco Min Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:eco_min_set_point" }
|
||
|
Switch Thermostat_FT_Active "Fan Timer Active" { channel="nest:thermostat:demo_account:living_thermostat:fan_timer_active" }
|
||
|
Number:Time Thermostat_FT_Duration "Fan Timer Duration [%d %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:fan_timer_duration" }
|
||
|
DateTime Thermostat_FT_Timeout "Fan Timer Timeout [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:thermostat:demo_account:living_thermostat:fan_timer_timeout" }
|
||
|
Switch Thermostat_Has_Fan "Has Fan" { channel="nest:thermostat:demo_account:living_thermostat:has_fan" }
|
||
|
Switch Thermostat_Has_Leaf "Has Leaf" { channel="nest:thermostat:demo_account:living_thermostat:has_leaf" }
|
||
|
Number:Dimensionless Therm_Hum "Humidity [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:humidity" }
|
||
|
DateTime Thermostat_Last_Conn "Last Connection [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:thermostat:demo_account:living_thermostat:last_connection" }
|
||
|
Switch Thermostat_Locked "Locked" { channel="nest:thermostat:demo_account:living_thermostat:locked" }
|
||
|
Number:Temperature Therm_LMaxSP "Locked Max Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:locked_max_set_point" }
|
||
|
Number:Temperature Therm_LMinSP "Locked Min Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:locked_min_set_point" }
|
||
|
Number:Temperature Therm_Max_SP "Max Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:max_set_point" }
|
||
|
Number:Temperature Therm_Min_SP "Min Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:min_set_point" }
|
||
|
String Thermostat_Mode "Mode [%s]" { channel="nest:thermostat:demo_account:living_thermostat:mode" }
|
||
|
String Thermostat_Previous_Mode "Previous Mode [%s]" { channel="nest:thermostat:demo_account:living_thermostat:previous_mode" }
|
||
|
String Thermostat_State "State [%s]" { channel="nest:thermostat:demo_account:living_thermostat:state" }
|
||
|
Number:Temperature Thermostat_SP "Set Point [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:set_point" }
|
||
|
Switch Thermostat_Sunlight_CA "Sunlight Correction Active" { channel="nest:thermostat:demo_account:living_thermostat:sunlight_correction_active" }
|
||
|
Switch Thermostat_Sunlight_CE "Sunlight Correction Enabled" { channel="nest:thermostat:demo_account:living_thermostat:sunlight_correction_enabled" }
|
||
|
Number:Temperature Therm_Temp "Temperature [%.1f %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:temperature" }
|
||
|
Number:Time Therm_Time_To_Target "Time To Target [%d %unit%]" { channel="nest:thermostat:demo_account:living_thermostat:time_to_target" }
|
||
|
Switch Thermostat_Using_Em_Heat "Using Emergency Heat" { channel="nest:thermostat:demo_account:living_thermostat:using_emergency_heat" }
|
||
|
|
||
|
/* Structure */
|
||
|
String Home_Away "Away [%s]" { channel="nest:structure:demo_account:home:away" }
|
||
|
String Home_Country_Code "Country Code [%s]" { channel="nest:structure:demo_account:home:country_code" }
|
||
|
String Home_CO_Alarm_State "CO Alarm State [%s]" { channel="nest:structure:demo_account:home:co_alarm_state" }
|
||
|
DateTime Home_ETA "ETA [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:structure:demo_account:home:eta_begin" }
|
||
|
DateTime Home_PP_End_Time "PP End Time [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:structure:demo_account:home:peak_period_end_time" }
|
||
|
DateTime Home_PP_Start_Time "PP Start Time [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" { channel="nest:structure:demo_account:home:peak_period_start_time" }
|
||
|
String Home_Postal_Code "Postal Code [%s]" { channel="nest:structure:demo_account:home:postal_code" }
|
||
|
Switch Home_Rush_Hour_Rewards "Rush Hour Rewards" { channel="nest:structure:demo_account:home:rush_hour_rewards_enrollment" }
|
||
|
String Home_Security_State "Security State [%s]" { channel="nest:structure:demo_account:home:security_state" }
|
||
|
String Home_Smoke_Alarm_State "Smoke Alarm State [%s]" { channel="nest:structure:demo_account:home:smoke_alarm_state" }
|
||
|
String Home_Time_Zone "Time Zone [%s]" { channel="nest:structure:demo_account:home:time_zone" }
|
||
|
```
|
||
|
|
||
|
## Attribution
|
||
|
|
||
|
This documentation contains parts written by John Cocula which were copied from the 1.0 Nest binding.
|