1
0
mirror of https://github.com/USA-RedDragon/badnest.git synced 2025-01-19 02:10:42 +00:00
badnest/info.md

66 lines
2.8 KiB
Markdown
Raw Normal View History

2019-09-25 22:20:36 -05:00
# badnest
2019-09-25 19:14:43 -05:00
A bad Nest thermostat and camera 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)
2019-09-25 22:20:36 -05:00
## Why is it bad?
This isn't an advertised or public API, it's still better than web scraping, but will never be as good as the original API
2019-09-25 19:14:43 -05:00
## Drawbacks
- No proper error handling
2019-10-19 18:55:37 -05:00
- Won't work with 2FA enabled accounts (Works with 2fa Google Accounts)
- Tested with a single thermostat, I have no other devices to test with
- Camera integration is untested by me
2019-09-25 19:14:43 -05:00
- Nest could change their webapp api at any time, making this defunct
2019-10-19 18:55:37 -05:00
- Thermostat presets don't work (Eco, Away)
2019-09-25 19:14:43 -05:00
2019-10-17 09:17:14 +02:00
## Example configuration.yaml - When you're not using the Google Auth Login
2019-09-25 19:14:43 -05:00
```yaml
2019-09-25 22:20:36 -05:00
badnest:
2019-09-25 19:14:43 -05:00
email: email@domain.com
password: !secret nest_password
2019-10-17 09:17:14 +02:00
climate:
- platform: badnest
scan_interval: 10
camera:
- platform: badnest
2019-10-17 09:17:14 +02:00
```
## Example configuration.yaml - When you are using the Google Auth Login
```yaml
badnest:
issue_token: "https://accounts.google.com/o/oauth2/iframerpc....."
cookie: "OCAK=......"
api_key : "#YOURAPIKEYHERE#"
2019-09-25 19:14:43 -05:00
climate:
2019-09-25 22:20:36 -05:00
- platform: badnest
2019-09-25 19:14:43 -05:00
scan_interval: 10
2019-10-17 09:17:14 +02:00
camera:
- platform: badnest
2019-09-25 19:14:43 -05:00
```
2019-10-17 09:17:14 +02:00
Google Login support added with many thanks to: chrisjshull from <https://github.com/chrisjshull/homebridge-nest/>
The values of `"issue_token"`, `"cookie"` and `"api_key"` 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).
1. Open a Chrome browser tab in Incognito Mode (or clear your cache).
2. Open Developer Tools (View/Developer/Developer Tools).
3. Click on 'Network' tab. Make sure 'Preserve Log' is checked.
4. In the 'Filter' box, enter `issueToken`
5. Go to `home.nest.com`, and click 'Sign in with Google'. Log into your account.
6. One network call (beginning with `iframerpc`) will appear in the Dev Tools window. Click on it.
7. In the Headers tab, under General, copy the entire `Request URL` (beginning with `https://accounts.google.com`, ending with `nest.com`). This is your `"issue_token"` in `configuration.yaml`.
8. In the 'Filter' box, enter `oauth2/iframe`
9. Several network calls will appear in the Dev Tools window. Click on the last `iframe` call.
10. In the Headers tab, under Request Headers, copy the entire `cookie` (beginning `OCAK=...` - **include the whole string which is several lines long and has many field/value pairs** - do not include the `cookie:` name). This is your `"cookie"` in `configuration.yaml`.
11. In the 'Filter' box, enter `issue_jwt`
12. Click on the last `issue_jwt` call.
13. In the Headers tab, under Request Headers, copy the entire `x-goog-api-key` (do not include the `x-goog-api-key:` name). This is your `"api_key"` in `configuration.yaml`.