2016-02-18 21:28:03 +00:00
|
|
|
import logging
|
2017-10-03 11:31:24 +00:00
|
|
|
|
2018-01-04 11:52:19 +00:00
|
|
|
from mgrs import MGRS
|
2018-04-27 19:48:14 +00:00
|
|
|
from haversine import haversine
|
2018-01-04 11:52:19 +00:00
|
|
|
|
2016-02-18 21:28:03 +00:00
|
|
|
from ogn.commands.dbutils import session
|
2017-05-26 20:56:38 +00:00
|
|
|
from ogn.model import AircraftBeacon, ReceiverBeacon, Location
|
2017-10-03 11:31:24 +00:00
|
|
|
from ogn.parser import parse, ParseError
|
2017-12-13 19:19:11 +00:00
|
|
|
from datetime import datetime, timedelta
|
2017-10-03 11:31:24 +00:00
|
|
|
|
2016-02-18 21:28:03 +00:00
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
2018-01-04 11:52:19 +00:00
|
|
|
myMGRS = MGRS()
|
2016-02-18 21:28:03 +00:00
|
|
|
|
|
|
|
|
2018-04-27 19:48:14 +00:00
|
|
|
def replace_lonlat_with_wkt(message, reference_receiver=None):
|
2018-01-19 18:14:57 +00:00
|
|
|
latitude = message['latitude']
|
|
|
|
longitude = message['longitude']
|
|
|
|
|
2018-04-27 19:48:14 +00:00
|
|
|
if reference_receiver is not None:
|
|
|
|
message['distance'] = 1000.0 * haversine((reference_receiver['latitude'], reference_receiver['longitude']), (latitude, longitude))
|
2018-02-11 10:55:29 +00:00
|
|
|
|
2018-01-19 18:14:57 +00:00
|
|
|
location = Location(longitude, latitude)
|
2016-04-24 17:34:25 +00:00
|
|
|
message['location_wkt'] = location.to_wkt()
|
2018-01-19 18:14:57 +00:00
|
|
|
message['location_mgrs'] = myMGRS.toMGRS(latitude, longitude).decode('utf-8')
|
2016-04-24 17:34:25 +00:00
|
|
|
del message['latitude']
|
|
|
|
del message['longitude']
|
|
|
|
return message
|
|
|
|
|
2018-04-27 19:48:14 +00:00
|
|
|
previous_message = None
|
|
|
|
receivers = dict()
|
|
|
|
|
2016-04-24 17:34:25 +00:00
|
|
|
|
2018-04-27 19:48:14 +00:00
|
|
|
def message_to_beacon(raw_message, reference_date, wait_for_brother=False):
|
2016-10-31 07:58:19 +00:00
|
|
|
beacon = None
|
2018-04-27 19:48:14 +00:00
|
|
|
global previous_message
|
|
|
|
global receivers
|
2016-10-03 13:14:44 +00:00
|
|
|
|
2016-10-31 07:58:19 +00:00
|
|
|
if raw_message[0] != '#':
|
|
|
|
try:
|
2017-10-03 11:31:24 +00:00
|
|
|
message = parse(raw_message, reference_date)
|
2017-12-02 11:44:57 +00:00
|
|
|
except NotImplementedError as e:
|
|
|
|
logger.error('Received message: {}'.format(raw_message))
|
|
|
|
logger.error(e)
|
2018-04-27 19:48:14 +00:00
|
|
|
return None
|
2016-10-31 07:58:19 +00:00
|
|
|
except ParseError as e:
|
|
|
|
logger.error('Received message: {}'.format(raw_message))
|
|
|
|
logger.error('Drop packet, {}'.format(e.message))
|
2018-04-27 19:48:14 +00:00
|
|
|
return None
|
2016-10-31 07:58:19 +00:00
|
|
|
except TypeError as e:
|
|
|
|
logger.error('TypeError: {}'.format(raw_message))
|
2018-04-27 19:48:14 +00:00
|
|
|
return None
|
2018-01-19 18:14:57 +00:00
|
|
|
except Exception as e:
|
|
|
|
logger.error(raw_message)
|
|
|
|
logger.error(e)
|
2018-04-27 19:48:14 +00:00
|
|
|
return None
|
|
|
|
|
|
|
|
# update reference receivers and distance to the receiver
|
|
|
|
if message['aprs_type'] == 'position':
|
|
|
|
if message['beacon_type'] in ['receiver_beacon', 'aprs_receiver', 'receiver']:
|
|
|
|
receivers.update({message['name']: {'latitude': message['latitude'], 'longitude': message['longitude']}})
|
|
|
|
message = replace_lonlat_with_wkt(message)
|
|
|
|
elif message['beacon_type'] in ['aircraft_beacon', 'aprs_aircraft', 'flarm', 'tracker']:
|
|
|
|
reference_receiver = receivers.get(message['receiver_name'])
|
|
|
|
message = replace_lonlat_with_wkt(message, reference_receiver=reference_receiver)
|
|
|
|
|
|
|
|
# optional: merge different beacon types
|
|
|
|
params = dict()
|
|
|
|
if wait_for_brother is True:
|
|
|
|
if previous_message is None:
|
|
|
|
previous_message = message
|
|
|
|
return None
|
|
|
|
elif message['name'] == previous_message['name'] and message['timestamp'] == previous_message['timestamp']:
|
|
|
|
params = message
|
|
|
|
params.update(previous_message)
|
|
|
|
params['aprs_type'] = 'merged'
|
2018-04-28 09:43:45 +00:00
|
|
|
previous_message = None
|
2018-04-27 19:48:14 +00:00
|
|
|
else:
|
|
|
|
params = previous_message
|
|
|
|
previous_message = message
|
|
|
|
else:
|
|
|
|
params = message
|
|
|
|
|
|
|
|
# create beacons
|
|
|
|
if params['beacon_type'] in ['aircraft_beacon', 'aprs_aircraft', 'flarm', 'tracker']:
|
|
|
|
beacon = AircraftBeacon(**params)
|
2018-04-28 09:43:45 +00:00
|
|
|
elif params['beacon_type'] in ['receiver_beacon', 'aprs_receiver', 'receiver']:
|
2018-04-27 19:48:14 +00:00
|
|
|
beacon = ReceiverBeacon(**params)
|
|
|
|
else:
|
|
|
|
print("Whoops: what is this: {}".format(params))
|
2016-05-22 05:23:22 +00:00
|
|
|
|
2016-10-31 07:58:19 +00:00
|
|
|
return beacon
|
2016-05-22 05:23:22 +00:00
|
|
|
|
2017-12-13 19:19:11 +00:00
|
|
|
beacons = list()
|
|
|
|
last_commit = datetime.utcnow()
|
|
|
|
|
2016-05-22 05:23:22 +00:00
|
|
|
|
2016-10-31 07:58:19 +00:00
|
|
|
def process_beacon(raw_message, reference_date=None):
|
2017-12-13 19:19:11 +00:00
|
|
|
global beacons
|
|
|
|
global last_commit
|
|
|
|
|
2016-10-31 07:58:19 +00:00
|
|
|
beacon = message_to_beacon(raw_message, reference_date)
|
|
|
|
if beacon is not None:
|
2017-12-13 19:19:11 +00:00
|
|
|
beacons.append(beacon)
|
2016-02-18 21:28:03 +00:00
|
|
|
logger.debug('Received message: {}'.format(raw_message))
|
2017-12-13 19:19:11 +00:00
|
|
|
|
|
|
|
current_time = datetime.utcnow()
|
|
|
|
elapsed_time = current_time - last_commit
|
|
|
|
if elapsed_time >= timedelta(seconds=1):
|
|
|
|
session.bulk_save_objects(beacons)
|
|
|
|
session.commit()
|
|
|
|
logger.debug('Commited beacons')
|
|
|
|
beacons = list()
|
|
|
|
last_commit = current_time
|