-
Notifications
You must be signed in to change notification settings - Fork 33
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow device cluster entities overwrite from v2 quirks #328
base: dev
Are you sure you want to change the base?
Conversation
@@ -314,7 +314,7 @@ def discover_quirks_v2_entities(self, device: Device) -> None: | |||
endpoint.async_new_entity( | |||
platform=platform, | |||
entity_class=entity_class, | |||
unique_id=endpoint.unique_id, | |||
unique_id=f"{endpoint.unique_id}-{cluster.cluster_id}", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this will break all existing v2 entities and it will require a migration of the HA entity registry.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is that migration a post-install operation?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In ZHA async_setup_entry
I can get access to all HA ZHA entities. But it doesn't look like the HA associated entity data contains the info I need to migrate the ids - I would not know the cluster id of each entity in order to migrate to <unique id>-<cluster id>
.
Here is how the registry entry looks like for a local temperature calibration entity:
'RegistryEntry(entity_id='number.thermostat_trv_local_temperature_offset', unique_id='28:fa:26:01:02:0b:67:2a-1-513-local_temperature_calibration', platform='zha', previous_unique_id=None, aliases=set(), area_id=None, categories={}, capabilities={'min': -5.0, 'max': 5.0, 'step': 0.1, 'mode': 'auto'}, config_entry_id='75fe69aebaacaaed3a012a97167d2d10', created_at=datetime.datetime(1970, 1, 1, 0, 0, tzinfo=datetime.timezone.utc), device_class=None, device_id='9e9268b18b27e97adb5d7543c1df8f62', disabled_by=None, entity_category=<EntityCategory.CONFIG: 'config'>, hidden_by=None, icon=None, id='617948e1ccca4e53075e64956998a17e', has_entity_name=True, labels=set(), modified_at=datetime.datetime(2024, 12, 16, 19, 51, 43, 399371, tzinfo=datetime.timezone.utc), name=None, options={'conversation': {'should_expose': False}}, original_device_class=None, original_icon=None, original_name='Local temperature offset', supported_features=0, translation_key='local_temperature_calibration', unit_of_measurement='°C', _cache={})'.
Is there any other place where the migration could be done?
(self.PLATFORM, self.unique_id), | ||
self._device.platform_entities[(self.PLATFORM, self.unique_id)], | ||
self, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is this doing?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Intention was to offer a debugging message for those cases where it is not intended or expected to encounter duplicated entities. Can be removed or demoted to debug.
) | ||
self._device.platform_entities[(self.PLATFORM, self.unique_id)] = self |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same question as above
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is allowing a newer entity instance to overwrite an existing one. In my specific case, an automatic zha created local temp calibration entity would be replaced by one provided by a quirk v2. At least, in my setup, the quirk v2 entity gets created last.
Entities created by a v2 quirk should be allowed to overwrite any default generated ones.
Current patch allows all overwrites and I'm not fully aware of the possible consequences outside the above mentioned use case.
Fixes home-assistant/core#128253.