diff --git a/ogn/parser/aprs_comment/fanet_parser.py b/ogn/parser/aprs_comment/fanet_parser.py index 6eb7a02..c47da26 100644 --- a/ogn/parser/aprs_comment/fanet_parser.py +++ b/ogn/parser/aprs_comment/fanet_parser.py @@ -13,5 +13,8 @@ class FanetParser(BaseParser): @staticmethod def parse_position(aprs_comment): ac_match = re.search(PATTERN_FANET_POSITION_COMMENT, aprs_comment) - return {'id': ac_match.group('id') if ac_match.group('id') else None, + return {'address_type': int(ac_match.group('details'), 16) & 0b00000011 if ac_match.group('details') else None, + 'aircraft_type': (int(ac_match.group('details'), 16) & 0b01111100) >> 2 if ac_match.group('details') else None, + 'stealth': (int(ac_match.group('details'), 16) & 0b10000000) >> 7 == 1 if ac_match.group('details') else None, + 'address': ac_match.group('address') if ac_match.group('address') else None, 'climb_rate': int(ac_match.group('climb_rate')) * fpm2ms if ac_match.group('climb_rate') else None} diff --git a/ogn/parser/aprs_comment/flarm_parser.py b/ogn/parser/aprs_comment/flarm_parser.py index 54931f9..a7896e7 100644 --- a/ogn/parser/aprs_comment/flarm_parser.py +++ b/ogn/parser/aprs_comment/flarm_parser.py @@ -16,7 +16,7 @@ class FlarmParser(BaseParser): return {'address_type': int(ac_match.group('details'), 16) & 0b00000011, 'aircraft_type': (int(ac_match.group('details'), 16) & 0b01111100) >> 2, 'stealth': (int(ac_match.group('details'), 16) & 0b10000000) >> 7 == 1, - 'address': ac_match.group('id'), + 'address': ac_match.group('address'), 'climb_rate': int(ac_match.group('climb_rate')) * fpm2ms, 'turn_rate': float(ac_match.group('turn_rate')), 'signal_quality': float(ac_match.group('signal_quality')), diff --git a/ogn/parser/aprs_comment/naviter_parser.py b/ogn/parser/aprs_comment/naviter_parser.py index 95edf58..d17b96b 100644 --- a/ogn/parser/aprs_comment/naviter_parser.py +++ b/ogn/parser/aprs_comment/naviter_parser.py @@ -18,6 +18,6 @@ class NaviterParser(BaseParser): 'aircraft_type': (int(match.group('details'), 16) & 0b0011110000000000) >> 10, 'address_type': (int(match.group('details'), 16) & 0b0000001111110000) >> 4, 'reserved': (int(match.group('details'), 16) & 0b0000000000001111), - 'address': match.group('id'), + 'address': match.group('address'), 'climb_rate': int(match.group('climb_rate')) * fpm2ms if match.group('climb_rate') else None, 'turn_rate': float(match.group('turn_rate')) if match.group('turn_rate') else None} diff --git a/ogn/parser/aprs_comment/ogn_parser.py b/ogn/parser/aprs_comment/ogn_parser.py index 86d6d69..3aa2532 100644 --- a/ogn/parser/aprs_comment/ogn_parser.py +++ b/ogn/parser/aprs_comment/ogn_parser.py @@ -34,7 +34,7 @@ class OgnParser(BaseParser): return {'address_type': int(ac_match.group('details'), 16) & 0b00000011, 'aircraft_type': (int(ac_match.group('details'), 16) & 0b01111100) >> 2, 'stealth': (int(ac_match.group('details'), 16) & 0b10000000) >> 7 == 1, - 'address': ac_match.group('id'), + 'address': ac_match.group('address'), 'climb_rate': int(ac_match.group('climb_rate')) * fpm2ms if ac_match.group('climb_rate') else None, 'turn_rate': float(ac_match.group('turn_rate')) if ac_match.group('turn_rate') else None, 'flightlevel': float(ac_match.group('flight_level')) if ac_match.group('flight_level') else None, diff --git a/ogn/parser/aprs_comment/tracker_parser.py b/ogn/parser/aprs_comment/tracker_parser.py index 3dcc13c..7a7a067 100644 --- a/ogn/parser/aprs_comment/tracker_parser.py +++ b/ogn/parser/aprs_comment/tracker_parser.py @@ -16,7 +16,7 @@ class TrackerParser(BaseParser): return {'address_type': int(match.group('details'), 16) & 0b00000011, 'aircraft_type': (int(match.group('details'), 16) & 0b01111100) >> 2, 'stealth': (int(match.group('details'), 16) & 0b10000000) >> 7 == 1, - 'address': match.group('id'), + 'address': match.group('address'), 'climb_rate': int(match.group('climb_rate')) * fpm2ms if match.group('climb_rate') else None, 'turn_rate': float(match.group('turn_rate')) if match.group('turn_rate') else None, 'flightlevel': float(match.group('flight_level')) if match.group('flight_level') else None, diff --git a/ogn/parser/pattern.py b/ogn/parser/pattern.py index b7ec1a7..a107364 100644 --- a/ogn/parser/pattern.py +++ b/ogn/parser/pattern.py @@ -7,12 +7,12 @@ PATTERN_APRS_STATUS = re.compile(r"^(?P