home-assistant.io/source/developers/hassio/addon_publishing.markdown
Fabian Affolter 76d5242b62
Update hass.io docs (#3849)
* Update hass.io docs

* Remove dash
2017-10-31 13:28:55 +01:00

3.4 KiB

layout, title, description, date, sidebar, comments, sharing, footer, redirect_from
layout title description date sidebar comments sharing footer redirect_from
page Publishing your add-on Steps on how-to create an add-on for Hass.io. 2017-04-30 13:28 true false true true /hassio/addon_publishing/

There are two different ways of publishing add-ons. One is to publish pre-build containers to Docker Hub and the other option is to have users build the containers locally on their Hass.io instance.

{% linkable_title Pre-build containers %}

With pre-build containers, the developer is responsible for building the images for each architecture on their machine and push the results out to Docker Hub. This has a lot of advantages for the user. As a user it will only have to download the final container and be up and running once the download finishes. This makes the installation process fast and almost no chance of failure. This is the preferred method.

We have automated the process of building and publishing add-ons. See below for the instructions.

{% linkable_title Locally build containers %}

Starting Hass.io 0.26, it is possible to distribute add-ons that will be built on the users machine. The advantage is that as a developer it is easy to test an idea and see if people are interested in your add-ons. This method includes installing and potentially compiling code. This means that installing such an add-on is slow and adds more wear and tear to users SD card/hard drive than the above mentioned pre-build solution. It also has a higher chance of failure if one of the dependencies of the container has changed or is no longer available.

Use this option when you are playing with add-ons and seeing if someone is interested in your work. Once you're an established repository, please migrate to pushing builds to Docker Hub as it greatly improves the user experience. In the future we will mark locally built add-ons in the add-on store to warn users.

{% linkable_title Build scripts to publish add-ons to Docker Hub %}

All add-ons are simple docker containers. Inside your add-on config.json you specify the Docker image that will be installed for your add-on:

{
  ...

  "image": "myhub/image-{arch}-addon-name",

  ...
}

You can use {arch} inside the image name to support multiple architectures with 1 configuration file. It will be replaced with the architecture of the user when we load the image. If you use Buildargs you can use the build.json to overwrite our default args.

Hass.io assumes that the master branch of your add-on repository matches the latest tag on Docker Hub. When you're building a new version, it's suggested that you use another branch, ie build or do it with a PR on GitHub. After you push the add-on to Docker Hub, you can merge this branch to master.

{% linkable_title Custom Add-ons %}

You need a Docker Hub account to make your own add-ons. You can build your docker images with docker build command or use our script that make it simple. Pull our builder docker engine and run one of the following commands.

For a git repository:

$ docker run --rm --privileged -v ~/.docker:/root/.docker homeassistant/amd64-builder --all -t addon-folder -r https://github.com/xy/addons -b branchname

For a local repository:

$ docker run --rm --privileged -v ~/.docker:/root/.docker -v /my_addon:/data homeassistant/amd64-builder --all -t /data