-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathFlightDetails.py
81 lines (61 loc) · 2.64 KB
/
FlightDetails.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
"""
FlightDetails.py
Manage the database of known ICAO24 decodes, fetch from external APIs as needed
Thanks to 'joshuadouch' for the API - https://radarspotting.com/forum/index.php?topic=6117.0
Matt Dyson
08/06/18
Part of FlightPi - http://github.com/mattdy/flightpi
Updates:
24/10/22 @snerd9334 : API URLs updated based on info on https://hexdb.io/
"""
import logging
import sys
import sqlite3
import time
import urllib2
log = logging.getLogger('root')
TIMEOUT=60 # Number of minutes to keep a cache of our API hits
class FlightDetails:
def __init__(self,filename="details.sql"):
log.debug("Starting FlightDetails database at %s" % (filename))
self.apiCache = { }
self.conn = sqlite3.connect(filename, check_same_thread=False)
self.c = self.conn.cursor()
self.c.execute("CREATE TABLE IF NOT EXISTS `airframe` (icao text, type text, registration text)")
log.debug("Loaded FlightDetails")
def getRow(self, icao):
self.c.execute('SELECT * FROM `airframe` WHERE `icao`=?', [icao])
row = self.c.fetchone()
if row is None:
if icao in self.apiCache:
if self.apiCache[icao] > time.time() - (TIMEOUT * 60 * 60):
return None
try:
log.debug("Attempting to fetch details from external API")
req = urllib2.Request("https://hexdb.io/hex-type.php?hex=%s" % (icao), headers={ 'User-Agent': 'Mozilla/5.0' })
type = urllib2.urlopen(req).read()
req = urllib2.Request("https://hexdb.io/hex-reg.php?hex=%s" % (icao), headers={ 'User-Agent': 'Mozilla/5.0' })
reg = urllib2.urlopen(req).read()
if type=="n/a" or type=="0": type=None
if reg=="n/a" or reg=="0": reg=None
self.apiCache[icao] = time.time()
if type is not None and reg is not None:
log.info("Successful fetch for %s, now inserting into database" % (icao))
self.c.execute("INSERT INTO `airframe` (icao, type, registration) VALUES (?, ? ,?)", [icao, type, reg])
self.conn.commit()
row = (icao, type, reg)
except Exception as e:
log.error("Error fetching from external API {0}".format(e))
return row
def getType(self, icao):
row = self.getRow(icao)
if row is not None:
return self.getRow(icao)[1]
else:
return None
def getRegistration(self, icao):
row = self.getRow(icao)
if row is not None:
return self.getRow(icao)[2]
else:
return None