A bad Nest integration that uses the web api to work after Works with Nest was shut down (bad Google, go sit in your corner and think about what you did)
This repo is based off of the original from RedDragon with fixes provided by the community since that repo has gone stale.
This isn't an advertised or public API, it's still better than web scraping, but will never be as reliable as the original API
- Doesn't use the now defunct Works with Nest API
- Works with migrated/new accounts via Google auth
- Nest Protect support
- Nest Thermostat support
- Nest Thermostat Sensor support
- Nest Camera support
- Tested with a single thermostat, I have no other devices to test with
- Nest could change their webapp api at any time, making this defunct (this has happened before, see https://github.com/USA-RedDragon/badnest/issues/67)
badnest:
issue_token: "https://accounts.google.com/o/oauth2/iframerpc....."
cookie: "......"
climate:
- platform: badnest
scan_interval: 10
camera:
- platform: badnest
sensor:
- platform: badnest
Google Login support added with many thanks to: chrisjshull from https://github.com/chrisjshull/homebridge-nest/
The values of "issue_token"
and "cookie"
are specific to your Google
Account. To get them, follow these steps (only needs to be done once, as long as
you stay logged into your Google Account).
- Open a Chrome browser tab in Incognito Mode (or clear your cache).
- Open Developer Tools (View/Developer/Developer Tools).
- Click on 'Network' tab. Make sure 'Preserve Log' is checked.
- In the 'Filter' box, enter
issueToken
- Go to
home.nest.com
, and click 'Sign in with Google'. Log into your account. - One network call (beginning with
iframerpc
) will appear in the Dev Tools window. Click on it. - In the Headers tab, under General, copy the entire
Request URL
(beginning withhttps://accounts.google.com
, ending withnest.com
). This is your"issue_token"
inconfiguration.yaml
. - In the 'Filter' box, enter
oauth2/iframe
- Several network calls will appear in the Dev Tools window. Click on the last
iframe
call. - In the Headers tab, under Request Headers, copy the entire
cookie
( include the whole string which is several lines long and has many field/value pairs - do not include thecookie:
name). This is your"cookie"
inconfiguration.yaml
.
badnest:
user_id: 1234567
access_token: "....."
climate:
- platform: badnest
scan_interval: 10
camera:
- platform: badnest
sensor:
- platform: badnest
The values of "user_id"
and "access_token"
are specific to your Nest account.
To get them, follow these steps:
- Open https://home.nest.com in Chrome.
- Open Developer Tools (View/Developer/Developer Tools).
- Click on 'Network' tab. Make sure 'Preserve Log' is checked.
- In the 'Filter' box, enter
session
- Log into your account using your Nest login
- One network call (beginning with
session?_=
) will appear in the Dev Tools window. Click on it. - In the Response tab, find your
access_token
anduserid
from the JSON response. Theuserid
value should be used for the"user_id"
configuration value.
The target temperature reported by the integration sometimes seems to be slightly off by a few tens of a degree. This is caused by the fact that the Nest mobile app actually actually allows users to set the temperature in small increments, but the displayed temperature is rounded to the nearest 0.5 degree. In other words, the temperature displayed by the integration is correct, just more exact than what is shown in the app.