Skip to main content

Python API for Yale Access (formerly August) Smart Lock and Doorbell

Project description

yalexs PyPI version Build Status codecov Python Versions

Python API for Yale Access (formerly August) Smart Lock and Doorbell. This is used in Home Assistant but should be generic enough that can be used elsewhere.

Yale Access formerly August

This library is a fork of Joe Lu's excellent august library from https://github.com/snjoetw/py-august

API status

This is an unofficial library. As of v9, only the async API (yalexs.api_async.ApiAsync, yalexs.authenticator_async.AuthenticatorAsync) is supported — the synchronous Api / Authenticator classes were removed in v8 (see #141).

The public API key historically embedded in this library is no longer accepted by either backend. Both Brand.AUGUST (Fortune Brands / Yale Access) and Brand.YALE_HOME (Assa Abloy) now require an official partner key issued by the vendor. See #167 for context. The usage example below is illustrative — you will need to supply a working key via the brand/API plumbing for it to authenticate against the live service.

Install

pip install yalexs

Classes

AuthenticatorAsync

AuthenticatorAsync handles authentication: signing in, sending a verification code to email or phone, and validating the returned code.

Constructor

Argument Description
api An ApiAsync instance.
login_method Login method, either "phone" or "email".
username If login_method is phone, your full phone number including + and country code; otherwise your email address.
password Account password.
install_id* ID generated when the Yale Access app is installed. If not specified, the authenticator generates one. Providing a previously provisioned install ID skips the verification step.
access_token_cache_file* Path to a token cache file. If set, authentication state is persisted to disk so subsequent runs can skip the login step until the token expires.

* optional

Methods

async_setup_authentication()

Loads cached credentials from access_token_cache_file if present. Call once before async_authenticate().

async_authenticate() -> Authentication

Authenticates with the API. The returned Authentication.state is one of:

  • AuthenticationState.AUTHENTICATED — logged in, access_token is valid.
  • AuthenticationState.REQUIRES_VALIDATION — call async_send_verification_code() then async_validate_verification_code(code).
  • AuthenticationState.BAD_PASSWORD — credentials rejected.
  • AuthenticationState.REQUIRES_AUTHENTICATION — no cached token; call async_authenticate() to obtain one.

If a valid token is already cached, this returns it without contacting the API.

async_send_verification_code() -> bool

Sends a 6-digit verification code to the phone or email tied to the account.

async_validate_verification_code(code: str) -> ValidationResult

Validates the code. Returns ValidationResult.VALIDATED on success or ValidationResult.INVALID_VERIFICATION_CODE otherwise.

async_refresh_access_token(force: bool = False) -> Authentication | None

Refreshes the access token if it is within the renewal threshold (default 7 days before expiry). Pass force=True to refresh unconditionally.

Usage

import asyncio

from aiohttp import ClientSession

from yalexs.alarm import ArmState
from yalexs.api_async import ApiAsync
from yalexs.authenticator_async import AuthenticationState, AuthenticatorAsync
from yalexs.const import Brand


async def main() -> None:
    async with ClientSession() as session:
        api = ApiAsync(session, timeout=20, brand=Brand.AUGUST)
        authenticator = AuthenticatorAsync(
            api,
            "email",
            "EMAIL_ADDRESS",
            "PASSWORD",
            access_token_cache_file="auth.txt",
        )
        await authenticator.async_setup_authentication()
        authentication = await authenticator.async_authenticate()

        if authentication.state is AuthenticationState.REQUIRES_VALIDATION:
            await authenticator.async_send_verification_code()
            code = input("Verification code: ")
            await authenticator.async_validate_verification_code(code)
            authentication = await authenticator.async_authenticate()

        access_token = authentication.access_token

        locks = await api.async_get_locks(access_token)
        for lock in locks:
            print(lock)

        # Alarms (Yale Home brand only)
        if api.brand_supports_alarms:
            alarms = await api.async_get_alarms(access_token)
            if alarms:
                await api.async_arm_alarm(access_token, alarms[0], ArmState.Away)


asyncio.run(main())

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

yalexs-9.2.7.tar.gz (45.8 kB view details)

Uploaded Source

Built Distribution

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

yalexs-9.2.7-py3-none-any.whl (54.0 kB view details)

Uploaded Python 3

File details

Details for the file yalexs-9.2.7.tar.gz.

File metadata

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

File hashes

Hashes for yalexs-9.2.7.tar.gz
Algorithm Hash digest
SHA256 f3062344aa99012218235e6128523996a1b9febc1880cfabd3da3708fc36b97b
MD5 0ff6f37ede4e1eca0bc6fd381547665e
BLAKE2b-256 98294f84c2eafd71bc72ef085fdc5def56d58a151e231491ee1b00c122980e97

See more details on using hashes here.

Provenance

The following attestation bundles were made for yalexs-9.2.7.tar.gz:

Publisher: ci.yml on Yale-Libs/yalexs

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

File details

Details for the file yalexs-9.2.7-py3-none-any.whl.

File metadata

  • Download URL: yalexs-9.2.7-py3-none-any.whl
  • Upload date:
  • Size: 54.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for yalexs-9.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 0f2bc387ae5f6aa57c8fc1dd87e850c57ad93f710cd5fb44c536376d703c99ce
MD5 aaf45af040db2e759dda7632499715d0
BLAKE2b-256 631ab07a2b0fc7d0ab3e05c5e1580ed2565e238147cbcc43576afd1c778271f2

See more details on using hashes here.

Provenance

The following attestation bundles were made for yalexs-9.2.7-py3-none-any.whl:

Publisher: ci.yml on Yale-Libs/yalexs

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