Talk to the Hubspace API asynchronously
Project description
Connects to Afero cloud API and provides an easy way to interact with devices.
This project was designed to asynchronously connect to the Afero IOT API. It has the ability to retrieve the devices and set new states.
Overview
All data is stored within a “bridge” that knows of all of the devices aligned with the Afero IOT account. This bridge contains multiple controllers for each device type. These controllers know how to interact with the Afero IOT devices. Each controller manages the device’s states. To retrieve a device, you must query bridge.<controller>.get_device(<device_id>) which will return a model containing all the states. Any changes to the model will not update Afero IOT as the correct call needs to be made.
Controllers
The following controllers are implemented:
- bridge.devices: Top-level devices (such as a ceiling-fan, or light that
is not associated with another device). These entities also contain their respective sensors and binary sensors. This is purely an informational controller and cannot set any states.
bridge.fans: Any device that matches a fan. Can perform the following actions:
turn_on
turn_off
set_speed
set_direction
set_preset
bridge.lights: Any device that matches a fan. Can perform the following actions:
turn_on
turn_off
set_color_temperature
set_brightness
set_rgb
set_effect
bridge.locks: Any device that matches a lock. Can perform the following actions:
lock
unlock
bridge.portable_acs: Any device that matches a portable-ac. Can perform the following actions:
Everything is done through set_state
bridge.switches: Any device that matches a switch. Can perform the following actions:
turn_on
turn_off
bridge.thermostats: Any device that matches a thermostat. Can perform the following actions:
set_fan_mode
set_hvac_mode
set_target_temperature
set_temperature_range
bridge.valves: Any device that matches a valves. Can perform the following actions:
turn_on
turn_off
Example Usage
All examples assume you entered the shell with python -m asyncio
from aioafero import v1
import logging
logging.getLogger("aioafero").setLevel(logging.DEBUG)
USERNAME="" # Afero IOT username
PASSWORD="" # Afero IOT password
POLLING_INTERVAL=30 # Number of seconds between polling cycles
# Create the bridge
bridge = v1.AferoBridgeV1(USERNAME, PASSWORD, polling_interval=POLLING_INTERVAL, hide_secrets=False)
# Query the API and populate the controllers
await bridge.initialize()
# Turn on the light that matches id="84338ebe-7ddf-4bfa-9753-3ee8cdcc8da6"
await conn.lights.turn_off("84338ebe-7ddf-4bfa-9753-3ee8cdcc8da6")
Troubleshooting
Device shows incorrect model
Afero IoT does not always report all the pertinent information through the API. To resolve this, open a PR to src/aioafero/device.py and update the dataclass AferoDevice.__post_init__ function to correctly identify the device.
Afero IoT is slow to update
The API rate-limits request. If other things are hitting the API (such as the phone app or Home Assistant), you may need to stop using one to ensure a better connection.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aioafero-3.3.0.tar.gz.
File metadata
- Download URL: aioafero-3.3.0.tar.gz
- Upload date:
- Size: 155.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd3693dab4bd160866eaa372508b9fe4e06cf5b0dab683e42f663169d43ce6ea
|
|
| MD5 |
c4dd841dfd6ef8741db0e956fd31ad3b
|
|
| BLAKE2b-256 |
763577526a2a638d79f9dee6b4ac864083269a108ee30378ab963321e9c761da
|
Provenance
The following attestation bundles were made for aioafero-3.3.0.tar.gz:
Publisher:
release.yaml on Expl0dingBanana/aioafero
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
aioafero-3.3.0.tar.gz -
Subject digest:
bd3693dab4bd160866eaa372508b9fe4e06cf5b0dab683e42f663169d43ce6ea - Sigstore transparency entry: 224631390
- Sigstore integration time:
-
Permalink:
Expl0dingBanana/aioafero@6171824061a55b8a5441c2ae77ebe3a2b4c857a1 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/Expl0dingBanana
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@6171824061a55b8a5441c2ae77ebe3a2b4c857a1 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file aioafero-3.3.0-py3-none-any.whl.
File metadata
- Download URL: aioafero-3.3.0-py3-none-any.whl
- Upload date:
- Size: 54.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c33088d52f28511f90ba32ee3070c2c92dfd09c4c2ee0100da4e9e63f6d5aaf2
|
|
| MD5 |
5f36f6b0fbf9b5e84bf713ebad1b7ca2
|
|
| BLAKE2b-256 |
5c77692a8d02fdfed15ff43ae120dbeca79d9516aa373324ff4f9bbc561e24f8
|
Provenance
The following attestation bundles were made for aioafero-3.3.0-py3-none-any.whl:
Publisher:
release.yaml on Expl0dingBanana/aioafero
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
aioafero-3.3.0-py3-none-any.whl -
Subject digest:
c33088d52f28511f90ba32ee3070c2c92dfd09c4c2ee0100da4e9e63f6d5aaf2 - Sigstore transparency entry: 224631406
- Sigstore integration time:
-
Permalink:
Expl0dingBanana/aioafero@6171824061a55b8a5441c2ae77ebe3a2b4c857a1 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/Expl0dingBanana
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@6171824061a55b8a5441c2ae77ebe3a2b4c857a1 -
Trigger Event:
workflow_dispatch
-
Statement type: