Python Client for ESPHome native API. Used by Home Assistant.
Go to file
Jesse Hills 51e364cdb7
Add bluetooth connections free
Add callbacks to remove message subscriptions

Move stop notify to callback of start notify
2022-09-28 10:54:35 +13:00
.github Bump actions/cache from 3.0.7 to 3.0.8 (#248) 2022-09-06 14:04:01 +12:00
aioesphomeapi Add bluetooth connections free 2022-09-28 10:54:35 +13:00
script Add pytest unit testing (#64) 2021-07-12 20:09:17 +02:00
tests Add media player entities (#214) 2022-05-18 13:28:40 +12:00
.dockerignore Build docker image to generate protoc (#72) 2021-07-22 11:35:08 +12:00
.gitignore Initial commit 2018-12-13 21:34:57 +01:00
Dockerfile Fix Dockerfile missing libprotobuf-dev (#127) 2021-10-21 18:59:33 +02:00
LICENSE Initial commit 2018-12-13 21:34:57 +01:00
MAINTAINERS.md Rename master branch to main (#58) 2021-06-30 18:08:56 +02:00
MANIFEST.in Implement PEP561 typing support (#55) 2021-06-30 17:05:44 +02:00
mypy.ini Refactor Lint Configs (#53) 2021-06-30 17:03:55 +02:00
pyproject.toml Refactor Lint Configs (#53) 2021-06-30 17:03:55 +02:00
README.rst Remove loop argument (#155) 2021-12-22 14:09:42 +13:00
requirements_test.txt Bump pylint from 2.14.5 to 2.15.0 (#250) 2022-09-06 14:07:29 +12:00
requirements.txt Add requirement 2022-09-27 13:09:26 +13:00
setup.cfg Add flake8, black, isort and mypy linting (#39) 2021-06-18 17:57:02 +02:00
setup.py Bump version to 10.13.1 2022-09-06 02:03:47 +00:00

aioesphomeapi
=============

``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

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
   
   async def main():
       """Connect to an ESPHome device and get details."""

       # Establish connection 
       api = aioesphomeapi.APIClient("api_test.local", 6053, "MyPassword")
       await api.connect(login=True)
       
       # Get API version of the device's firmware
       print(api.api_version)
       
       # Show device details
       device_info = await api.device_info()
       print(device_info)
       
       # List all entities of the device
       entities = await api.list_entities_services()
       print(entities)
       
    loop = asyncio.get_event_loop()
    loop.run_until_complete(main())

Subscribe to state changes of an ESPHome device.

.. code:: python

   import aioesphomeapi
   import asyncio
   
   async def main():
       """Connect to an ESPHome device and wait for state changes."""
       cli = aioesphomeapi.APIClient("api_test.local", 6053, "MyPassword")
       
       await cli.connect(login=True)

       def change_callback(state):
           """Print the state changes of the device.."""
           print(state)
       
       # Subscribe to the state changes
       await cli.subscribe_states(change_callback)
   
   loop = asyncio.get_event_loop()
   try:
       asyncio.ensure_future(main())
       loop.run_forever()
   except KeyboardInterrupt:
       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>`_
- `Simple print <https://gist.github.com/fpletz/d071c72e45d17ba274fd61ca7a465033#file-esphome-print-simple-py>`_
- `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

    # Setup virtualenv (optional)
    $ python3 -m venv .
    $ source bin/activate
    # 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

License
-------

``aioesphomeapi`` is licensed under MIT, for more details check LICENSE.