Fixed remaining Zigbee groups and binding methods to work with the new zigbee2mqtt API [see #163]
This commit is contained in:
parent
021dd32190
commit
7325c87068
1 changed files with 94 additions and 21 deletions
|
@ -414,8 +414,9 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
@action
|
@action
|
||||||
def factory_reset(self, **kwargs):
|
def factory_reset(self, **kwargs):
|
||||||
"""
|
"""
|
||||||
Perform a factory reset of the device. Of course, you should only do it if you know what you're doing,
|
Perform a factory reset of a device connected to the network, following the procedure required by the particular
|
||||||
as you will lose all the paired devices and may also lose the Z-Stack firmware.
|
device (for instance, Hue bulbs require the Zigbee adapter to be close to the device while a button on the back
|
||||||
|
of the bulb is pressed).
|
||||||
|
|
||||||
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
(default: query the default configured device).
|
(default: query the default configured device).
|
||||||
|
@ -628,19 +629,49 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
return properties
|
return properties
|
||||||
|
|
||||||
@action
|
@action
|
||||||
def device_groups(self, device: str, **kwargs) -> List[int]:
|
def device_check_ota_updates(self, device: str, **kwargs) -> dict:
|
||||||
"""
|
"""
|
||||||
List the groups a given device belongs to.
|
Check if the specified device has any OTA updates available to install.
|
||||||
|
|
||||||
:param device: Display name of the device.
|
:param device: Address or friendly name of the device.
|
||||||
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
(default: query the default configured device).
|
(default: query the default configured device).
|
||||||
:return: List of group IDs the device is linked to.
|
|
||||||
"""
|
|
||||||
|
|
||||||
return self.publish(topic=self._topic('bridge/device/{}/get_group_membership'.format(device)),
|
:return:
|
||||||
reply_topic=self._topic(device), msg=device, **self._mqtt_args(**kwargs)). \
|
|
||||||
output.get('group_list', [])
|
.. code-block:: json
|
||||||
|
|
||||||
|
{
|
||||||
|
"id": "<device ID>",
|
||||||
|
"update_available": true,
|
||||||
|
"status": "ok"
|
||||||
|
}
|
||||||
|
|
||||||
|
"""
|
||||||
|
ret = self._parse_response(
|
||||||
|
self.publish(topic=self._topic('bridge/request/device/ota_update/check'),
|
||||||
|
reply_topic=self._topic('bridge/response/device/ota_update/check'),
|
||||||
|
msg={'id': device}, **self._mqtt_args(**kwargs)))
|
||||||
|
|
||||||
|
return {
|
||||||
|
'status': ret['status'],
|
||||||
|
'id': ret.get('data', {}).get('id'),
|
||||||
|
'update_available': ret.get('data', {}).get('update_available', False),
|
||||||
|
}
|
||||||
|
|
||||||
|
@action
|
||||||
|
def device_install_ota_updates(self, device: str, **kwargs):
|
||||||
|
"""
|
||||||
|
Install OTA updates for a device if available.
|
||||||
|
|
||||||
|
:param device: Address or friendly name of the device.
|
||||||
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
|
(default: query the default configured device).
|
||||||
|
"""
|
||||||
|
return self._parse_response(
|
||||||
|
self.publish(topic=self._topic('bridge/request/device/ota_update/update'),
|
||||||
|
reply_topic=self._topic('bridge/response/device/ota_update/update'),
|
||||||
|
msg={'id': device}, **self._mqtt_args(**kwargs)))
|
||||||
|
|
||||||
@action
|
@action
|
||||||
def groups(self, **kwargs) -> List[dict]:
|
def groups(self, **kwargs) -> List[dict]:
|
||||||
|
@ -808,6 +839,32 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
**self._mqtt_args(**kwargs))
|
**self._mqtt_args(**kwargs))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@action
|
||||||
|
def group_get(self, group: str, property: Optional[str] = None, **kwargs) -> dict:
|
||||||
|
"""
|
||||||
|
Get one or more properties of a group. The compatible properties vary depending on the devices on the group.
|
||||||
|
For example, a light bulb may have the "``state``" (with values ``"ON"`` and ``"OFF"``) and "``brightness``"
|
||||||
|
properties, while an environment sensor may have the "``temperature``" and "``humidity``" properties, and so on.
|
||||||
|
|
||||||
|
:param group: Display name of the group.
|
||||||
|
:param property: Name of the property to retrieve (default: all available properties)
|
||||||
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
|
(default: query the default configured device).
|
||||||
|
"""
|
||||||
|
msg = {}
|
||||||
|
if property:
|
||||||
|
msg = {property: ''}
|
||||||
|
|
||||||
|
properties = self.publish(topic=self._topic(group + '/get'),
|
||||||
|
reply_topic=self._topic(group),
|
||||||
|
msg=msg, **self._mqtt_args(**kwargs)).output
|
||||||
|
|
||||||
|
if property:
|
||||||
|
assert property in properties, 'No such property: ' + property
|
||||||
|
return {property: properties[property]}
|
||||||
|
|
||||||
|
return properties
|
||||||
|
|
||||||
# noinspection PyShadowingBuiltins,DuplicatedCode
|
# noinspection PyShadowingBuiltins,DuplicatedCode
|
||||||
@action
|
@action
|
||||||
def group_set(self, group: str, property: str, value: Any, **kwargs):
|
def group_set(self, group: str, property: str, value: Any, **kwargs):
|
||||||
|
@ -881,8 +938,13 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
(default: query the default configured device).
|
(default: query the default configured device).
|
||||||
"""
|
"""
|
||||||
self.publish(topic=self._topic('bridge/group/{}/add'.format(group)),
|
return self._parse_response(
|
||||||
msg=device, **self._mqtt_args(**kwargs))
|
self.publish(topic=self._topic('bridge/request/group/members/add'),
|
||||||
|
reply_topic=self._topic('bridge/response/group/members/add'),
|
||||||
|
msg={
|
||||||
|
'group': group,
|
||||||
|
'device': device,
|
||||||
|
}, **self._mqtt_args(**kwargs)))
|
||||||
|
|
||||||
@action
|
@action
|
||||||
def group_remove_device(self, group: str, device: Optional[str] = None, **kwargs):
|
def group_remove_device(self, group: str, device: Optional[str] = None, **kwargs):
|
||||||
|
@ -895,11 +957,16 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
(default: query the default configured device).
|
(default: query the default configured device).
|
||||||
"""
|
"""
|
||||||
self.publish(topic=self._topic('bridge/group/{}/remove{}'.format(group, '_all' if not device else '')),
|
return self._parse_response(
|
||||||
msg=device, **self._mqtt_args(**kwargs))
|
self.publish(topic=self._topic('bridge/request/group/members/remove{}'.format('_all' if device is None else '')),
|
||||||
|
reply_topic=self._topic('bridge/response/group/members/remove{}'.format('_all' if device is None else '')),
|
||||||
|
msg={
|
||||||
|
'group': group,
|
||||||
|
'device': device,
|
||||||
|
}, **self._mqtt_args(**kwargs)))
|
||||||
|
|
||||||
@action
|
@action
|
||||||
def bind_devices(self, source: str, target: str, endpoint: Optional[str] = None, **kwargs):
|
def bind_devices(self, source: str, target: str, **kwargs):
|
||||||
"""
|
"""
|
||||||
Bind two devices. Binding makes it possible that devices can directly control each other without the
|
Bind two devices. Binding makes it possible that devices can directly control each other without the
|
||||||
intervention of zigbee2mqtt or any home automation software. You may want to use this feature to bind
|
intervention of zigbee2mqtt or any home automation software. You may want to use this feature to bind
|
||||||
|
@ -908,14 +975,16 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
|
|
||||||
:param source: Name of the source device. It can also be a group name, although the support is
|
:param source: Name of the source device. It can also be a group name, although the support is
|
||||||
`still experimental <https://www.zigbee2mqtt.io/information/binding.html#binding-a-group>`_.
|
`still experimental <https://www.zigbee2mqtt.io/information/binding.html#binding-a-group>`_.
|
||||||
|
You can also bind a specific device endpoint - for example ``MySensor/temperature``.
|
||||||
:param target: Name of the target device.
|
:param target: Name of the target device.
|
||||||
:param endpoint: The target may support multiple endpoints (e.g. 'left', 'down', 'up' etc.). If so,
|
You can also bind a specific device endpoint - for example ``MyLight/state``.
|
||||||
you can bind the source to a specific endpoint on the target device.
|
|
||||||
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
(default: query the default configured device).
|
(default: query the default configured device).
|
||||||
"""
|
"""
|
||||||
self.publish(topic=self._topic('bridge/bind/' + source + ('/' + endpoint if endpoint else '')),
|
return self._parse_response(
|
||||||
msg=target, **self._mqtt_args(**kwargs))
|
self.publish(topic=self._topic('bridge/request/device/bind'),
|
||||||
|
reply_topic=self._topic('bridge/response/device/bind'),
|
||||||
|
msg={'from': source, 'to': target}, **self._mqtt_args(**kwargs)) )
|
||||||
|
|
||||||
@action
|
@action
|
||||||
def unbind_devices(self, source: str, target: str, **kwargs):
|
def unbind_devices(self, source: str, target: str, **kwargs):
|
||||||
|
@ -923,12 +992,16 @@ class ZigbeeMqttPlugin(MqttPlugin):
|
||||||
Un-bind two devices.
|
Un-bind two devices.
|
||||||
|
|
||||||
:param source: Name of the source device.
|
:param source: Name of the source device.
|
||||||
|
You can also bind a specific device endpoint - for example ``MySensor/temperature``.
|
||||||
:param target: Name of the target device.
|
:param target: Name of the target device.
|
||||||
|
You can also bind a specific device endpoint - for example ``MyLight/state``.
|
||||||
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
:param kwargs: Extra arguments to be passed to :meth:`platypush.plugins.mqtt.MqttPlugin.publish``
|
||||||
(default: query the default configured device).
|
(default: query the default configured device).
|
||||||
"""
|
"""
|
||||||
self.publish(topic=self._topic('bridge/unbind/' + source),
|
return self._parse_response(
|
||||||
msg=target, **self._mqtt_args(**kwargs))
|
self.publish(topic=self._topic('bridge/request/device/unbind'),
|
||||||
|
reply_topic=self._topic('bridge/response/device/unbind'),
|
||||||
|
msg={'from': source, 'to': target}, **self._mqtt_args(**kwargs)) )
|
||||||
|
|
||||||
|
|
||||||
# vim:sw=4:ts=4:et:
|
# vim:sw=4:ts=4:et:
|
Loading…
Reference in a new issue