Skip to main content

Library for the Google Nest SDM API

Project description

python-google-nest-sdm

This is a library for Google Nest Device Access using the Smart Device Management API.

Usage

This can be used with the sandbox which requires Registration, accepting terms and a fee.

You'll want to following the Get Started guides for setup including steps in the google cloud console. Overall, this is fairly complicated with many steps that are easy to get wrong. It is likely worth it to make sure you can get the API working using their supplied curl commands with your account before attempting to use this library.

Structure

This API was designed for use in Home Assistant following the advice in Building a Python Library for an API.

If you are integrating this from outside Home Assistant, you'll need to create your own oauth integration and token refresh mechanism and tooling.

Fetching Data

This is an example to use the command line tool to access the API:

PROJECT_ID="some-project-id"
CLIENT_ID="some-client-id"
CLIENT_SECRET="some-client-secret"
# Initial call will ask you to authorize OAuth2 then cache the token
google_nest --project_id="${PROJECT_ID}" --client_id="${CLIENT_ID}" --client_secret="${CLIENT_SECRET}" list_structures
# Subsequent calls only need the project id
google_nest --project_id="${PROJECT_ID}" get_device "some-device-id"
google_nest --project_id="${PROJECT_ID}" set_mode COOL
google_nest --project_id="${PROJECT_ID}" set_cool 25.0

Subscriptions

See Device Access: Getting Started: Subscribe to Events for documentation on how to create a pull subscription.

You can create the subscription to use with the tool with these steps:

This is an example to run the command line tool to subscribe:

PROJECT_ID="some-project-id"
SUBSCRIPTION_ID="projects/some-id/subscriptions/enterprise-some-project-id-python-google-nest"
google_nest --project_id="${PROJECT_ID}" subscribe ${SUBSCRIPTION_ID}

Development

$ python3 -m venv venv
$ source venv/bin/activate
$ pip3 install -e .
$ pip3 install -r requirements.txt

# Running tests
$ pytest

# Running tests w/ Code Coverage
$ pytest --cov=google_nest_sdm tests/ --cov-report=term-missing

# Formatting and linting
$ pre-commit run --all-files

Funding and Support

If you are interested in donating money to this effort, instead send a donation to Black Girls Code which is a great organization growing the next generation of software engineers.

Project details


Release history Release notifications | RSS feed

This version

9.1.2

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

google_nest_sdm-9.1.2.tar.gz (71.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

google_nest_sdm-9.1.2-py3-none-any.whl (53.6 kB view details)

Uploaded Python 3

File details

Details for the file google_nest_sdm-9.1.2.tar.gz.

File metadata

  • Download URL: google_nest_sdm-9.1.2.tar.gz
  • Upload date:
  • Size: 71.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for google_nest_sdm-9.1.2.tar.gz
Algorithm Hash digest
SHA256 b8dde023abfa4838b34ad7fbd9b8716980949c82308748bfaa88a561801dbf67
MD5 077ac8061f3874a4a84822b683cba688
BLAKE2b-256 69bfe54dc1ad4d0f2863e725703fdedacdf59bc8e8cb7f41ed804d012b28b7d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for google_nest_sdm-9.1.2.tar.gz:

Publisher: publish.yaml on allenporter/python-google-nest-sdm

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file google_nest_sdm-9.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for google_nest_sdm-9.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7615c12b7462374b76c7a49788cb174f9941e97fce1cfe3f53eeea2350d1c6f5
MD5 ef67b97532a22f0bdc2e5a6ffb94e668
BLAKE2b-256 f026c778283faa23fea0ffb99596a3dde01c138a7571a73556feb1bae2715071

See more details on using hashes here.

Provenance

The following attestation bundles were made for google_nest_sdm-9.1.2-py3-none-any.whl:

Publisher: publish.yaml on allenporter/python-google-nest-sdm

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page