From: Eugene Crosser Date: Fri, 15 Jul 2022 15:50:29 +0000 (+0200) Subject: beesure: implment MESSAGE command X-Git-Tag: 1.90~16 X-Git-Url: http://average.org/gitweb/?a=commitdiff_plain;h=c6343a2c2886a35c3a1361a0bf96fe9428ad5aa2;p=loctrkd.git beesure: implment MESSAGE command --- diff --git a/loctrkd/beesure.py b/loctrkd/beesure.py index 51a1ec9..3a71f5d 100755 --- a/loctrkd/beesure.py +++ b/loctrkd/beesure.py @@ -340,30 +340,6 @@ class UNKNOWN(BeeSurePkt): pass -class LK(BeeSurePkt): - RESPOND = Respond.INL - - def in_decode(self, *args: str) -> None: - numargs = len(args) - if numargs > 0: - self.step = args[0] - if numargs > 1: - self.tumbling_number = args[1] - if numargs > 2: - self.battery_percentage = args[2] - - def in_encode(self) -> str: - return "LK" - - -class CONFIG(BeeSurePkt): - pass - - -class ICCID(BeeSurePkt): - pass - - class _LOC_DATA(BeeSurePkt): def in_decode(self, *args: str) -> None: p = SimpleNamespace() @@ -425,36 +401,51 @@ class _LOC_DATA(BeeSurePkt): self.longitude = p.lon * p.eorw -class UD(_LOC_DATA): +class AL(_LOC_DATA): + RESPOND = Respond.INL + + +class CONFIG(BeeSurePkt): pass -class UD2(_LOC_DATA): +class CR(BeeSurePkt): pass -class TKQ(BeeSurePkt): - RESPOND = Respond.INL +class FLOWER(BeeSurePkt): + OUT_KWARGS = (("number", int, 1),) + + def out_encode(self) -> str: + self.number: int + return str(self.number) -class TKQ2(BeeSurePkt): - RESPOND = Respond.INL +class ICCID(BeeSurePkt): + pass -class AL(_LOC_DATA): +class LK(BeeSurePkt): RESPOND = Respond.INL + def in_decode(self, *args: str) -> None: + numargs = len(args) + if numargs > 0: + self.step = args[0] + if numargs > 1: + self.tumbling_number = args[1] + if numargs > 2: + self.battery_percentage = args[2] -class CR(BeeSurePkt): - pass + def in_encode(self) -> str: + return "LK" -class FLOWER(BeeSurePkt): - OUT_KWARGS = (("number", int, 1),) +class MESSAGE(BeeSurePkt): + OUT_KWARGS = (("message", str, ""),) def out_encode(self) -> str: - self.number: int - return str(self.number) + return str(self.message.encode("utf_16_be").hex()) class _PHB(BeeSurePkt): @@ -534,6 +525,22 @@ class TK(BeeSurePkt): return "1" # 0 - receive failure, 1 - receive success +class TKQ(BeeSurePkt): + RESPOND = Respond.INL + + +class TKQ2(BeeSurePkt): + RESPOND = Respond.INL + + +class UD(_LOC_DATA): + pass + + +class UD2(_LOC_DATA): + pass + + # Build dicts protocol number -> class and class name -> protocol number CLASSES = {} if True: # just to indent the code, sorry!