mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-01-08 22:07:06 +00:00
Better checking of child modules not supported by parent device (#966)
Replaces the logic to skip adding child modules to parent devices based on whether a device is a wall switch and instead relies on the `_check_supported` method. Is more future proof and will fix issue with the P300 with child `auto_off` modules https://github.com/python-kasa/python-kasa/pull/915 not supported on the parent.
This commit is contained in:
parent
9e74e1bd40
commit
927fe648ac
@ -140,3 +140,13 @@ class LightPreset(SmartModule, LightPresetInterface):
|
|||||||
if self._state_in_sysinfo: # Child lights can have states in the child info
|
if self._state_in_sysinfo: # Child lights can have states in the child info
|
||||||
return {}
|
return {}
|
||||||
return {self.QUERY_GETTER_NAME: None}
|
return {self.QUERY_GETTER_NAME: None}
|
||||||
|
|
||||||
|
async def _check_supported(self):
|
||||||
|
"""Additional check to see if the module is supported by the device.
|
||||||
|
|
||||||
|
Parent devices that report components of children such as ks240 will not have
|
||||||
|
the brightness value is sysinfo.
|
||||||
|
"""
|
||||||
|
# Look in _device.sys_info here because self.data is either sys_info or
|
||||||
|
# get_preset_rules depending on whether it's a child device or not.
|
||||||
|
return "brightness" in self._device.sys_info
|
||||||
|
@ -202,10 +202,6 @@ class SmartDevice(Device):
|
|||||||
child_modules_to_skip = {}
|
child_modules_to_skip = {}
|
||||||
if self._parent and self._parent.device_type != DeviceType.Hub:
|
if self._parent and self._parent.device_type != DeviceType.Hub:
|
||||||
skip_parent_only_modules = True
|
skip_parent_only_modules = True
|
||||||
elif self._children and self.device_type == DeviceType.WallSwitch:
|
|
||||||
# _initialize_modules is called on the parent after the children
|
|
||||||
for child in self._children.values():
|
|
||||||
child_modules_to_skip.update(**child.modules)
|
|
||||||
|
|
||||||
for mod in SmartModule.REGISTERED_MODULES.values():
|
for mod in SmartModule.REGISTERED_MODULES.values():
|
||||||
_LOGGER.debug("%s requires %s", mod, mod.REQUIRED_COMPONENT)
|
_LOGGER.debug("%s requires %s", mod, mod.REQUIRED_COMPONENT)
|
||||||
|
Loading…
Reference in New Issue
Block a user