2020-06-19 21:35:41 +02:00
aioesphomeapi
=============
2023-11-11 21:08:08 +01:00
.. image :: https://github.com/esphome/aioesphomeapi/workflows/CI/badge.svg
:target: https://github.com/esphome/aioesphomeapi?query=workflow%3ACI+branch%3Amain
.. image :: https://img.shields.io/pypi/v/aioesphomeapi.svg
:target: https://pypi.python.org/pypi/aioesphomeapi
.. image :: https://codecov.io/gh/esphome/aioesphomeapi/branch/main/graph/badge.svg
:target: https://app.codecov.io/gh/esphome/aioesphomeapi/tree/main
2020-06-19 21:35:41 +02:00
`` aioesphomeapi `` allows you to interact with devices flashed with `ESPHome <https://esphome.io/> `_ .
Installation
------------
The module is available from the `Python Package Index <https://pypi.python.org/pypi> `_ .
.. code :: bash
$ pip3 install aioesphomeapi
2023-10-12 20:12:39 +02:00
An optional cython extension is available for better performance, and the module will try to build it automatically.
The extension requires a C compiler and Python development headers. The module will fall back to the pure Python implementation if they are unavailable.
Building the extension can be forcefully disabled by setting the environment variable `` SKIP_CYTHON `` to `` 1 `` .
2020-06-19 21:35:41 +02:00
Usage
-----
It's required that you enable the `Native API <https://esphome.io/components/api.html> `_ component for the device.
.. code :: yaml
# Example configuration entry
api:
password: 'MyPassword'
Check the output to get the local address of the device or use the `` name: ` ` under ` ` esphome: `` from the device configuration.
.. code :: bash
[17:56:38][C][api:095]: API Server:
[17:56:38][C][api:096]: Address: api_test.local:6053
The sample code below will connect to the device and retrieve details.
.. code :: python
import aioesphomeapi
import asyncio
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
async def main():
"""Connect to an ESPHome device and get details."""
2021-10-13 10:15:30 +02:00
2023-10-20 02:00:36 +02:00
# Establish connection
2021-10-13 10:15:30 +02:00
api = aioesphomeapi.APIClient("api_test.local", 6053, "MyPassword")
2020-06-19 21:35:41 +02:00
await api.connect(login=True)
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
# Get API version of the device's firmware
print(api.api_version)
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
# Show device details
device_info = await api.device_info()
print(device_info)
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
# List all entities of the device
entities = await api.list_entities_services()
print(entities)
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
Subscribe to state changes of an ESPHome device.
.. code :: python
import aioesphomeapi
import asyncio
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
async def main():
"""Connect to an ESPHome device and wait for state changes."""
2021-12-22 02:09:42 +01:00
cli = aioesphomeapi.APIClient("api_test.local", 6053, "MyPassword")
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
await cli.connect(login=True)
2020-12-22 20:45:32 +01:00
def change_callback(state):
2020-06-19 21:35:41 +02:00
"""Print the state changes of the device.."""
print(state)
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
# Subscribe to the state changes
await cli.subscribe_states(change_callback)
2023-10-20 02:00:36 +02:00
2020-06-19 21:35:41 +02:00
loop = asyncio.get_event_loop()
try:
asyncio.ensure_future(main())
loop.run_forever()
2020-12-22 20:45:32 +01:00
except KeyboardInterrupt:
2020-06-19 21:35:41 +02:00
pass
finally:
loop.close()
Other examples:
- `Camera <https://gist.github.com/micw/202f9dee5c990f0b0f7e7c36b567d92b> `_
- `Async print <https://gist.github.com/fpletz/d071c72e45d17ba274fd61ca7a465033#file-esphome-print-async-py> `_
2020-07-01 03:53:11 +02:00
- `Simple print <https://gist.github.com/fpletz/d071c72e45d17ba274fd61ca7a465033#file-esphome-print-simple-py> `_
2020-06-19 21:35:41 +02:00
- `InfluxDB <https://gist.github.com/fpletz/d071c72e45d17ba274fd61ca7a465033#file-esphome-sensor-influxdb-py> `_
Development
-----------
For development is recommended to use a Python virtual environment (`` venv `` ).
.. code :: bash
2021-07-12 20:09:17 +02:00
# Setup virtualenv (optional)
2020-06-19 21:35:41 +02:00
$ python3 -m venv .
$ source bin/activate
2021-07-12 20:09:17 +02:00
# Install aioesphomeapi and development depenencies
$ pip3 install -e .
$ pip3 install -r requirements_test.txt
# Run linters & test
$ script/lint
# Update protobuf _pb2.py definitions (requires a protobuf compiler installation)
$ script/gen-protoc
2020-06-19 21:35:41 +02:00
2023-11-11 21:08:08 +01:00
A cli tool is also available for watching logs:
.. code :: bash
aioesphomeapi-logs --help
2020-06-19 21:35:41 +02:00
License
-------
`` aioesphomeapi `` is licensed under MIT, for more details check LICENSE.