Skip to main content

Building a Python library for an API

One of the foundational rules of Home Assistant is that we do not include any protocol specific code. Instead, this code should be put into a standalone Python library and published to PyPI. This guide will describe how to get started with this!

For this guide we're going to assume that we're building a library for a Rest API that is accessible over HTTP and returning data structured as JSON objects. This is the most common type of API that we see. These APIs can either be accessible on the device itself, or in the cloud.

This guide is not a perfect fit for every API. You might have to tweak the examples.


If you are a manufacturer designing a new API for your product, please read about the best type of API to add to your products here.

HTTP API requests consist of four different parts:

  • The URL. This is the path that we fetch data from. With a Rest API the URL will uniquely identify the resource. Examples of urls are and
  • The HTTP method. This defines what we want from the API. The most common ones are:
    • GET for when we want to get information like the state of a light
    • POST for if we want something to be done (ie turn on a light)
  • The body. This is the data that we sent to the server to identify what needs to be done. This is how we send the command in the case of a POST request.
  • The headers. This contains metadata to describe your request. This will used to attach the authorization to the request.

Structuring the library

Our library will consist of two different parts:

  • Authentication: Responsible for making authenticated HTTP requests to the API endpoint and returning the results. This is the only piece of code that will actually interact with the API.
  • Data models: Represent the data and offer commands to interact with the data.

Trying your library inside Home Assistant

You will need to run an editable version of your library if you want to try your library in Home Assistant before it is published to PyPI.

Do so by going to your Home Assistant development environment, activating the virtual environment and typing:

pip3 install -e ../my_lib_folder

Now run Home Assistant without installing dependencies from PyPI to avoid overriding your package.

hass --skip-pip-packages my_lib_module_name