95 lines
3.6 KiB
Python
95 lines
3.6 KiB
Python
import configparser
|
|
import time
|
|
from colorama import Fore, Back, Style
|
|
import platform
|
|
if platform.system() == "Windows":
|
|
from colorama import init
|
|
init(convert=True)
|
|
from planeClass import Plane
|
|
from datetime import datetime
|
|
from defAirport import download_airports
|
|
from AppendAirport import download_font
|
|
import pytz
|
|
download_airports()
|
|
download_font()
|
|
main_config = configparser.ConfigParser()
|
|
main_config.read('./configs/mainconf.ini')
|
|
source = main_config.get('DATA', 'SOURCE')
|
|
import os
|
|
import sys
|
|
#Setup plane objects from plane configs
|
|
planes = {}
|
|
for filename in os.listdir("./configs"):
|
|
if filename.endswith(".ini") and filename != "mainconf.ini":
|
|
plane_config = configparser.ConfigParser()
|
|
plane_config.read(("./configs/" + filename))
|
|
planes[plane_config.get('DATA', 'ICAO').upper()] = Plane(plane_config.get('DATA', 'ICAO'), filename)
|
|
|
|
running_Count = 0
|
|
failed_count = 0
|
|
try:
|
|
tz = pytz.timezone(main_config.get('DATA', 'TZ'))
|
|
except pytz.exceptions.UnknownTimeZoneError:
|
|
tz = pytz.UTC
|
|
|
|
while True:
|
|
datetime_tz = datetime.now(tz)
|
|
if datetime_tz.hour == 0 and datetime_tz.minute == 0:
|
|
running_Count = 0
|
|
running_Count +=1
|
|
start_time = time.time()
|
|
print (Back.GREEN, Fore.BLACK, "--------", running_Count, "--------", datetime_tz.strftime("%I:%M:%S %p"), "-------------------------------------------------------", Style.RESET_ALL)
|
|
if source == "ADSBX":
|
|
from defADSBX import pullADSBX
|
|
data, failed = pullADSBX(planes)
|
|
if failed == False:
|
|
if data['ac'] != None:
|
|
for key, obj in planes.items():
|
|
has_data = False
|
|
for planeData in data['ac']:
|
|
if planeData['icao'] == key:
|
|
obj.run(planeData, source)
|
|
has_data = True
|
|
break
|
|
if has_data is False:
|
|
obj.run(None, source)
|
|
else:
|
|
for obj in planes.values():
|
|
obj.run(None, source)
|
|
elif failed:
|
|
failed_count += 1
|
|
elif source == "OPENS":
|
|
from defOpenSky import pullOpenSky
|
|
planeData, failed = pullOpenSky(planes)
|
|
if failed == False:
|
|
if planeData.states != []:
|
|
# print(planeData.time)
|
|
for key, obj in planes.items():
|
|
has_data = False
|
|
for dataState in planeData.states:
|
|
if (dataState.icao24).upper() == key:
|
|
obj.run(dataState, source)
|
|
has_data = True
|
|
break
|
|
if has_data is False:
|
|
obj.run(None, source)
|
|
else:
|
|
for obj in planes.values():
|
|
obj.run(None, source)
|
|
if failed_count >= 10:
|
|
source = "OPENS"
|
|
elapsed_calc_time = time.time() - start_time
|
|
datetime_tz = datetime.now(tz)
|
|
print (Back.GREEN, Fore.BLACK, "--------", running_Count, "--------", datetime_tz.strftime("%I:%M:%S %p"), "------------------------Elapsed Time-", elapsed_calc_time, " -------------------------------------", Style.RESET_ALL)
|
|
|
|
|
|
sleep_sec = 5
|
|
for i in range(sleep_sec,0,-1):
|
|
if i < 10:
|
|
i = " " + str(i)
|
|
sys.stdout.write("\r")
|
|
sys.stdout.write(Back.RED + "Sleep {00000000}".format(i) + Style.RESET_ALL)
|
|
sys.stdout.flush()
|
|
time.sleep(1)
|
|
sys.stdout.write(Back.RED + ('\x1b[1K\r' +"Slept for " +str(sleep_sec)) + Style.RESET_ALL)
|
|
print() |