From bb90383c3e78910fed044f1555a31b0d0844cdf6 Mon Sep 17 00:00:00 2001 From: xZetsubou Date: Mon, 29 Apr 2024 06:10:48 +0300 Subject: [PATCH] Handle unexpected data #206 * Reset the buffer if we can't find valid message. * Ensure that the prefix at the start of the message. --- .../localtuya/core/pytuya/__init__.py | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/custom_components/localtuya/core/pytuya/__init__.py b/custom_components/localtuya/core/pytuya/__init__.py index 4d6ce85e3..4eab73597 100644 --- a/custom_components/localtuya/core/pytuya/__init__.py +++ b/custom_components/localtuya/core/pytuya/__init__.py @@ -612,19 +612,27 @@ def add_data(self, data): self.buffer += data header_len = struct.calcsize(MESSAGE_RECV_HEADER_FMT) - while self.buffer: + # Check if enough data for measage header + if len(self.buffer) < header_len: + break + prefix_offset_55AA = self.buffer.find(PREFIX_55AA_BIN) prefix_offset_6699 = self.buffer.find(PREFIX_6699_BIN) - prefix_offset = ( - prefix_offset_6699 if prefix_offset_55AA < 0 else prefix_offset_55AA - ) + prefixes = (prefix_offset_55AA, prefix_offset_6699) - self.buffer = self.buffer[prefix_offset:] - # Check if enough data for measage header - if len(self.buffer) < header_len: + # If somehow we got unexpected message, we will ignore it and reset the buffer. + if prefix_offset_55AA < 0 and prefix_offset_6699 < 0: + self.debug(f"Got unexpected Message prefix: {self.buffer}", force=True) + self.buffer = b"" break + # If the prefix is not at the start of the message. + if prefix_offset_55AA != 0 and prefix_offset_6699 != 0: + self.debug(f"Message prefix offset not at the start {self.buffer}") + prefix_offset = min(prefix for prefix in prefixes if not prefix < 0) + self.buffer = self.buffer[prefix_offset:] + header = parse_header(self.buffer, logger=self) hmac_key = self.local_key if self.version >= 3.4 else None no_retcode = False