Entity registry
The entity registry is a registry where Home Assistant keeps track of entities. Any entity that is added to Home Assistant which specifies the unique_id
attribute will be registered in the registry.
Being registered has the advantage that the same entity will always get the same entity ID. It will also prevent other entities from using that entity ID.
A user is also able to override the name of an entity in the entity registry. When set, the name in the entity registry is used in favor of the name the device might give itself.
Unique ID
It is important that it is not possible for the user to change the unique ID, because the system would lose all its settings related to the unique ID.
An entity is looked up in the registry based on a combination of the platform type (e.g., light
), and the integration name (domain) (e.g. hue) and the unique ID of the entity. Entities should not include the domain
(e.g., your_integration
) and platform type (e.g., light
) in their Unique ID as the system already accounts for these identifiers.
If a device has a single unique id but provides multiple entities, combine the unique id with unique identifiers for the entities. For example, if a device measures both temperature and humidity, you can uniquely identify the entities using {unique_id}-{sensor_type}
.
Unique ID requirements
Example acceptable sources for a unique ID
- Serial number of a device
- MAC address: formatted using
homeassistant.helpers.device_registry.format_mac
; Only obtain the MAC address from the device API or a discovery handler. Tools that rely on reading the arp cache or local network access such asgetmac
will not function in all supported network environments and are not acceptable. - Latitude and Longitude or other unique Geo Location
- Unique identifier that is physically printed on the device or burned into an EEPROM
Unique ID of last resort
For entities that are setup by a config entry, the Config Entry ID
can be used as a last resort if no other Unique ID is available.
Unacceptable sources for a unique ID
- IP Address
- Device Name
- Hostname
- URL
- Email addresses
- Usernames