Skip to content

Commit

Permalink
Merge pull request #135 from puddly/rc
Browse files Browse the repository at this point in the history
0.10.1 Release
  • Loading branch information
puddly authored Oct 8, 2022
2 parents a78951d + cb47bde commit 0fcd626
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 22 deletions.
2 changes: 1 addition & 1 deletion zigpy_zigate/__init__.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
MAJOR_VERSION = 0
MINOR_VERSION = 10
PATCH_VERSION = '0'
PATCH_VERSION = '1'
__short_version__ = '{}.{}'.format(MAJOR_VERSION, MINOR_VERSION)
__version__ = '{}.{}'.format(__short_version__, PATCH_VERSION)
46 changes: 46 additions & 0 deletions zigpy_zigate/types.py
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,52 @@ class Status(uint8_t, enum.Enum):
# No free BTR entries left.
NoFreeBTREntries = 0x8B

# A transmit request failed since the ASDU is too large and fragmentation is not
# supported.
AsduTooLong = 0xA0
# A received fragmented frame could not be defragmented at the current time.
DefragDeferred = 0xA1
# A received fragmented frame could not be defragmented since the device does not
# support fragmentation.
DefragUnsupported = 0xA2
# A parameter value was out of range.
IllegalRequest = 0xA3
# An APSME-UNBIND.request failed due to the requested binding link not existing in
# the binding table.
InvalidBinding = 0xA4
# An APSME-REMOVE-GROUP.request has been issued with a group identifier that does
# not appear in the group table.
InvalidGroup = 0xA5
# A parameter value was invalid or out of range.
InvalidParameter = 0xA6
# An APSDE-DATA.request requesting acknowledged transmission failed due to no
# acknowledgement being received.
NoAck = 0xA7
# An APSDE-DATA.request with a destination addressing mode set to 0x00 failed due to
# there being no devices bound to this device.
NoBoundDevice = 0xA8
# An APSDE-DATA.request with a destination addressing mode set to 0x03 failed due to
# no corresponding short address found in the address map table.
NoShortAddress = 0xA9
# An APSDE-DATA.request with a destination addressing mode set to 0x00 failed due to
# a binding table not being supported on the device.
NotSupported = 0xAA
# An ASDU was received that was secured using a link key.
SecuredLinkKey = 0xAB
# An ASDU was received that was secured using a network key.
SecuredNwkKey = 0xAC
# An APSDE-DATA.request requesting security has resulted in an error during the
# corresponding security processing.
SecurityFail = 0xAD
# An APSME-BIND.request or APSME.ADDGROUP.request issued when the binding or group
# tables, respectively, were full.
TableFull = 0xAE
# An ASDU was received without any security.
Unsecured = 0xAF
# An APSME-GET.request or APSMESET. request has been issued with an unknown
# attribute identifier.
UnsupportedAttribute = 0xB0

@classmethod
def _missing_(cls, value):
if not isinstance(value, int):
Expand Down
36 changes: 15 additions & 21 deletions zigpy_zigate/zigbee/application.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
from __future__ import annotations

import asyncio
import logging
from typing import Any, Dict, Optional
Expand Down Expand Up @@ -32,20 +34,21 @@ def __init__(self, config: Dict[str, Any]):
self._pending = {}
self._pending_join = []

self.version = ''
self.version: str = ""

async def connect(self):
api = await ZiGate.new(self._config[CONF_DEVICE], self)
await api.set_raw_mode()
await api.set_time()
version, lqi = await api.version()

hex_version = f"{version[1]:x}"
self.version = f"{hex_version[0]}.{hex_version[1:]}"
self._api = api

major, minor = version.to_bytes(2, "big")
self.version = f"{major:x}.{minor:x}"

if self.version < '3.21':
LOGGER.warning('Old ZiGate firmware detected, you should upgrade to 3.21 or newer')
LOGGER.error('Old ZiGate firmware detected, you should upgrade to 3.21 or newer')

async def disconnect(self):
# TODO: how do you stop the network? Is it possible?
Expand Down Expand Up @@ -235,20 +238,6 @@ def _handle_frame_failure(self, message_tag, status):
async def send_packet(self, packet):
LOGGER.debug("Sending packet %r", packet)

if packet.dst.addr_mode == zigpy.types.AddrMode.IEEE:
LOGGER.warning("IEEE addressing is not supported, falling back to NWK")

try:
device = self.get_device_with_address(packet.dst)
except (KeyError, ValueError):
raise ValueError(f"Cannot find device with IEEE {packet.dst.address}")

packet = packet.replace(
dst=zigpy.types.AddrModeAddress(
addr_mode=zigpy.types.AddrMode.NWK, address=device.nwk
)
)

ack = (zigpy.types.TransmitOptions.ACK in packet.tx_options)

try:
Expand All @@ -265,11 +254,16 @@ async def send_packet(self, packet):
except NoResponseError:
raise zigpy.exceptions.DeliveryError("ZiGate did not respond to command")

self._pending[tsn] = asyncio.get_running_loop().create_future()

if status != t.Status.Success:
self._pending.pop(tsn)
raise zigpy.exceptions.DeliveryError(f"Failed to deliver packet: {status}", status=status)

self._pending[tsn] = asyncio.get_running_loop().create_future()
# Firmwares 3.1d and below fail to send packets on every request
if status == t.Status.InvalidParameter and self.version <= "3.1d":
pass
else:
raise zigpy.exceptions.DeliveryError(f"Failed to send packet: {status}", status=status)

# disabled because of https://github.com/fairecasoimeme/ZiGate/issues/324
# try:
Expand Down Expand Up @@ -300,7 +294,7 @@ def __init__(self, application, ieee, nwk):
model = 'PiZiGate'
elif c.is_zigate_din(port):
model = 'ZiGate USB-DIN'
self._model = '{} {}'.format(model, application.version)
self._model = f'{model} {application.version}'

@property
def manufacturer(self):
Expand Down

0 comments on commit 0fcd626

Please sign in to comment.