Skip to content

Latest commit

 

History

History
77 lines (48 loc) · 5.5 KB

README.md

File metadata and controls

77 lines (48 loc) · 5.5 KB

Detail page of a Nest Protect device

hacs_badge GitHub release HA integration usage

Nest Protect integration for Home Assistant

Custom component for Home Assistant to interact with Nest Protect devices via an undocumented and unofficial Nest API. Unfortunately, Google SDM doesn't support Nest Protect devices and thus the core Nest integration won't work for Nest Protect.

This integration will add the most important sensors of your Nest Protect device (CO, heat and smoke) and the occupancy if your device is wired (to main power). In addition, it will expose several diagnostic and configuration entities. All sensor values will be updated real-time.

Known limitations

  • Only Google Accounts are supported, there is no plan to support legacy Nest accounts
  • When Nest Protect (wired) occupancy is triggered, it will stay 'on' for 10 minutes. (API limitation)
  • Only cookie authentication is supported as Google removed the API key authentication method. This means that you need to login to the Nest website at least once to generate a cookie. This cookie will be used to authenticate with the Nest API. The cookie will be stored in the Home Assistant configuration folder and will be used for future requests. If you logout from your browser or change your password, you need to reautenticate and and replace the current issue_token and cookies.

Installation

You can install this integration via HACS or manually.

HACS

Search for the Nest Protect integration and choose install, then reboot Home Assistant. Configure the Nest Protect integration either via the integrations page or press the blue button below.

Open your Home Assistant instance and start setting up a new integration.

Manual

Copy the custom_components/nest_protect to your custom_components folder and reboot Home Assistant. Configure the Nest Protect integration either via the integrations page or press the blue button below.

Open your Home Assistant instance and start setting up a new integration.

Retrieving issue_token and cookies

(adapted from homebridge-nest documentation)

The values of "issue_token" and "cookies" 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/Edge browser tab in Incognito Mode (or clear your cookies).

  2. Allow third-party cookies in your browser settings to prevent the Nest website from entering a redirect loop. Follow these steps:

    • In Chrome: Go to Settings, select Privacy and Security -> Third-party cookies. Enable "Allow third-party cookies."
    • In Edge: Go to Settings, select Cookies and site permissions -> Manage and delete cookies and site data. Disable "Block third-party cookies."
  3. Open Developer Tools (View/Developer/Developer Tools).

  4. Click on Network tab. Make sure 'Preserve Log' is checked.

  5. In the Filter box, enter issueToken

  6. Go to home.nest.com, and click Sign in with Google. Log into your account.

  7. One network call (beginning with iframerpc) will appear in the Dev Tools window. Click on it.

  8. In the Headers tab, under General, copy the entire Request URL (beginning with https://accounts.google.com). This is your 'issue_token' in the configuration form.

  9. In the Filter box, enter oauth2/iframe

  10. Several network calls will appear in the Dev Tools window. Click on the last iframe call.

  11. 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 the cookie: name). This is your 'cookies' in the configuration form.

  12. Do not log out of home.nest.com, as this will invalidate your credentials. Just close the browser tab.

Advanced

Feel free to create an issue on GitHub if you find an issue or if you have a suggestion. It is always helpful to download the diagnostics information and to include debug logging.

Enable debug logging

The logger integration lets you define the level of logging activities in Home Assistant. Turning on debug mode will show more information about unsupported devices in your logbook.

logger:
  default: critical
  logs:
    custom_components.nest_protect: debug

Credits

Based on the research and implementation of homebridge-nest.