ogn-python/ogn/model/beacon.py

64 wiersze
2.0 KiB
Python

import re
from sqlalchemy import Column, String, Integer, Float, DateTime
from sqlalchemy.ext.declarative import AbstractConcreteBase
from ogn.aprs_utils import createTimestamp, dmsToDeg, kts2kmh, feet2m
from ogn.exceptions import AprsParseError
from .base import Base
# "original" pattern from OGN: "(.+?)>APRS,.+,(.+?):/(\\d{6})+h(\\d{4}\\.\\d{2})(N|S).(\\d{5}\\.\\d{2})(E|W).((\\d{3})/(\\d{3}))?/A=(\\d{6}).*?"
PATTERN_APRS = r"^(.+?)>APRS,.+,(.+?):/(\d{6})+h(\d{4}\.\d{2})(N|S)(.)(\d{5}\.\d{2})(E|W)(.)((\d{3})/(\d{3}))?/A=(\d{6})\s(.*)$"
re_pattern_aprs = re.compile(PATTERN_APRS)
class Beacon(AbstractConcreteBase, Base):
id = Column(Integer, primary_key=True)
# APRS data
name = Column(String)
receiver_name = Column(String(9))
timestamp = Column(DateTime, index=True)
latitude = Column(Float)
symboltable = None
longitude = Column(Float)
symbolcode = None
track = Column(Integer)
ground_speed = Column(Float)
altitude = Column(Integer)
comment = None
def parse(self, text):
result = re_pattern_aprs.match(text)
if result is None:
raise AprsParseError(text)
self.name = result.group(1)
self.receiver_name = result.group(2)
self.timestamp = createTimestamp(result.group(3))
self.latitude = dmsToDeg(float(result.group(4)) / 100)
if result.group(5) == "S":
self.latitude = -self.latitude
self.symboltable = result.group(6)
self.longitude = dmsToDeg(float(result.group(7)) / 100)
if result.group(8) == "W":
self.longitude = -self.longitude
self.symbolcode = result.group(9)
if result.group(10) is not None:
self.track = int(result.group(11))
self.ground_speed = int(result.group(12)) * kts2kmh
else:
self.track = 0
self.ground_speed = 0
self.altitude = int(result.group(13)) * feet2m
self.comment = result.group(14)