From ac0ca5aab2dbc4ce035cfc0e0f7175110ea180a5 Mon Sep 17 00:00:00 2001 From: Eugene Crosser Date: Wed, 27 Apr 2022 22:40:23 +0200 Subject: [PATCH] cleanup of gps303proto --- gps303/gps303proto.py | 40 ++++++++++++++++------------------------ gps303/opencellid.py | 6 +++--- 2 files changed, 19 insertions(+), 27 deletions(-) diff --git a/gps303/gps303proto.py b/gps303/gps303proto.py index 31073d8..04f5350 100755 --- a/gps303/gps303proto.py +++ b/gps303/gps303proto.py @@ -17,13 +17,11 @@ Forewarnings: from datetime import datetime, timezone from enum import Enum from inspect import isclass -from logging import getLogger from struct import pack, unpack __all__ = ( "class_by_prefix", "inline_response", - "make_object", "parse_message", "proto_by_name", "Respond", @@ -64,10 +62,9 @@ __all__ = ( "VIBRATION_RECEIVED", "POSITION_UPLOAD_INTERVAL", "SOS_ALARM", + "UNKNOWN_B3", ) -log = getLogger("gps303") - def intx(x): if isinstance(x, str): @@ -595,6 +592,17 @@ class SOS_ALARM(GPS303Pkt): PROTO = 0x99 +class UNKNOWN_B3(GPS303Pkt): + PROTO = 0xb3 + IN_KWARGS = (("asciidata", str, ""),) + + @classmethod + def from_packet(cls, length, payload): + self = super().from_packet(length, payload) + self.asciidata = payload.decode() + return self + + # Build dicts protocol number -> class and class name -> protocol number CLASSES = {} PROTOS = {} @@ -640,29 +648,13 @@ def inline_response(packet): return None -def make_object(length, proto, payload): +def parse_message(packet): + """ From a packet (without framing bytes) derive the XXX.In object """ + length, proto = unpack("BB", packet[:2]) + payload = packet[2:] if proto in CLASSES: return CLASSES[proto].from_packet(length, payload) else: retobj = UNKNOWN.from_packet(length, payload) retobj.PROTO = proto # Override class attr with object attr return retobj - - -def parse_message(packet): - length, proto = unpack("BB", packet[:2]) - payload = packet[2:] - adjust = 2 if proto == STATUS.PROTO else 4 # Weird special case - if ( - proto not in (WIFI_POSITIONING.PROTO, WIFI_OFFLINE_POSITIONING.PROTO) - and length > 1 - and len(payload) + adjust != length - ): - log.warning( - "With proto %d length is %d but payload length is %d+%d", - proto, - length, - len(payload), - adjust, - ) - return make_object(length, proto, payload) diff --git a/gps303/opencellid.py b/gps303/opencellid.py index 843e595..436d559 100644 --- a/gps303/opencellid.py +++ b/gps303/opencellid.py @@ -63,12 +63,12 @@ if __name__.endswith("__main__"): db = connect(sys.argv[1]) c = db.cursor() c.execute( - """select timestamp, imei, clntaddr, length, proto, payload from events + """select select tstamp, packet from events where proto in (?, ?)""", (WIFI_POSITIONING.PROTO, WIFI_OFFLINE_POSITIONING.PROTO), ) - for timestamp, imei, clntaddr, length, proto, payload in c: - obj = make_object(length, proto, payload) + for timestamp, imei, clntaddr, proto, payload in c: + obj = parse_message(packet) avlat, avlon = qry_cell(sys.argv[2], obj.mcc, obj.gsm_cells) print( "{} {:+#010.8g},{:+#010.8g}".format( -- 2.43.0