3.0 KiB
author | authorURL | authorImageURL | authorTwitter | title |
---|---|---|---|---|
Paulus Schoutsen | https://twitter.com/balloob | /img/profile/paulus.jpg | balloob | Introducing Integrations |
We have finished the great migration. The result will be released as part of Home Assistant 0.92. The release has been a bit delayed because we had a lot of things to fix! With the migration done, we now consider components and platforms that share the same name to be part of the same integration. Each integration is either a single Python file, or a folder with an __init__.py
. file. We have updated the documentation and introduced a new section for integrations.
Home Assistant 0.92 introduces a new manifest.json
for integrations. This file, which is optional for custom components, is used by integrations to specify metadata: name, link to the documentation, dependencies, requirements and code owners. We are exploring leveraging manifest.json
for additional future features, like tracking breaking changes or allowing custom components to provide config flows and being discovered.
With all these changes, we had to drop a few deprecated things and change some behavior:
- Platforms can no longer be in the directory of the entity component, like
light/my_platform.py
. Instead, create a newmy_platform
folder in your custom_components, create an empty__init__.py
file and movelight/my_platform.py
tomy_platform/light.py
. - Platforms can no longer have dependencies or requirements. Instead, create a
manifest.json
in themy_platform
folder to specify them, or addREQUIREMENTS
orDEPENDENCIES
constants to the__init__.py
file. - A platform will now always require the component, if available, to be set up first.
- It is no longer possible to provide translations for components that are contained in a single Python file. Convert them to an integration in a directory.
- If you want to override a built-in integration, you need to specify a
manifest.json
for your custom integration. Note that we strongly discourage overriding built-in integrations. Instead, if you want to run an integration with custom changes change the integration name. For example if you want to run a custom version of the MQTT integration, namedmqtt
in Home Assistant:- Copy the content of the
mqtt
folder from the Home Assistant repository to a new folder<config>/custom_components/mqtt_custom/
- Open
mqtt_custom/manifest.json
and change the value fordomain
frommqtt
tomqtt_custom
- Open
mqtt_custom/__init__.py
and change the value ofDOMAIN
frommqtt
tomqtt_custom
- Anywhere in your config where you referenced
mqtt
, referencemqtt_custom
. So usemqtt_custom:
to specify the host and useplatform: mqtt_custom
when specifying platforms.
- Copy the content of the