rewrite dahboard config, update APRS receive
This commit is contained in:
parent
e61f90fcfd
commit
295dfbda1f
@ -162,11 +162,11 @@ def aprs_send(packet):
|
|||||||
|
|
||||||
def dashboard_loc_write(call, lat, lon, time, comment):
|
def dashboard_loc_write(call, lat, lon, time, comment):
|
||||||
#try:
|
#try:
|
||||||
dash_entries = ast.literal_eval(os.popen('cat /tmp/gps_data_user_loc.txt').read())
|
dash_entries = ast.literal_eval(os.popen('cat ' + loc_file).read())
|
||||||
# except:
|
# except:
|
||||||
# dash_entries = []
|
# dash_entries = []
|
||||||
dash_entries.insert(0, {'call': call, 'lat': lat, 'lon': lon, 'time':time, 'comment': comment})
|
dash_entries.insert(0, {'call': call, 'lat': lat, 'lon': lon, 'time':time, 'comment': comment})
|
||||||
with open("/tmp/gps_data_user_loc.txt", 'w') as user_loc_file:
|
with open(loc_file, 'w') as user_loc_file:
|
||||||
user_loc_file.write(str(dash_entries[:200]))
|
user_loc_file.write(str(dash_entries[:200]))
|
||||||
user_loc_file.close()
|
user_loc_file.close()
|
||||||
logger.info('User location saved for dashboard')
|
logger.info('User location saved for dashboard')
|
||||||
@ -174,11 +174,11 @@ def dashboard_loc_write(call, lat, lon, time, comment):
|
|||||||
|
|
||||||
def dashboard_bb_write(call, dmr_id, time, bulletin):
|
def dashboard_bb_write(call, dmr_id, time, bulletin):
|
||||||
#try:
|
#try:
|
||||||
dash_bb = ast.literal_eval(os.popen('cat /tmp/gps_data_user_bb.txt').read())
|
dash_bb = ast.literal_eval(os.popen('cat ' + bb_file).read())
|
||||||
# except:
|
# except:
|
||||||
# dash_entries = []
|
# dash_entries = []
|
||||||
dash_bb.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'bulletin':bulletin})
|
dash_bb.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'bulletin':bulletin})
|
||||||
with open("/tmp/gps_data_user_bb.txt", 'w') as user_bb_file:
|
with open(bb_file, 'w') as user_bb_file:
|
||||||
user_bb_file.write(str(dash_bb[:20]))
|
user_bb_file.write(str(dash_bb[:20]))
|
||||||
user_bb_file.close()
|
user_bb_file.close()
|
||||||
logger.info('User bulletin entry saved.')
|
logger.info('User bulletin entry saved.')
|
||||||
@ -186,29 +186,28 @@ def dashboard_bb_write(call, dmr_id, time, bulletin):
|
|||||||
|
|
||||||
def mailbox_write(call, dmr_id, time, message, recipient):
|
def mailbox_write(call, dmr_id, time, message, recipient):
|
||||||
#try:
|
#try:
|
||||||
mail_file = ast.literal_eval(os.popen('cat ./gps_data_user_mailbox.txt').read())
|
mail_file = ast.literal_eval(os.popen('cat ' + the_mailbox_file).read())
|
||||||
mail_file.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'message':message, 'recipient': recipient})
|
mail_file.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'message':message, 'recipient': recipient})
|
||||||
with open("./gps_data_user_mailbox.txt", 'w') as mailbox_file:
|
with open(the_mailbox_file, 'w') as mailbox_file:
|
||||||
mailbox_file.write(str(mail_file[:100]))
|
mailbox_file.write(str(mail_file[:100]))
|
||||||
mailbox_file.close()
|
mailbox_file.close()
|
||||||
logger.info('User mail saved.')
|
logger.info('User mail saved.')
|
||||||
|
|
||||||
def mailbox_delete(dmr_id):
|
def mailbox_delete(dmr_id):
|
||||||
mail_file = ast.literal_eval(os.popen('cat ./gps_data_user_mailbox.txt').read())
|
mail_file = ast.literal_eval(os.popen('cat ' + the_mailbox_file).read())
|
||||||
call = str(get_alias((dmr_id), subscriber_ids))
|
call = str(get_alias((dmr_id), subscriber_ids))
|
||||||
new_data = []
|
new_data = []
|
||||||
for message in mail_file:
|
for message in mail_file:
|
||||||
if message['recipient'] != call:
|
if message['recipient'] != call:
|
||||||
new_data.append(message)
|
new_data.append(message)
|
||||||
with open("./gps_data_user_mailbox.txt", 'w') as mailbox_file:
|
with open(the_mailbox_file, 'w') as mailbox_file:
|
||||||
mailbox_file.write(str(new_data[:100]))
|
mailbox_file.write(str(new_data[:100]))
|
||||||
mailbox_file.close()
|
mailbox_file.close()
|
||||||
logger.info('Mailbox updated. Delete occurred.')
|
logger.info('Mailbox updated. Delete occurred.')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def sos_write(dmr_id, time, message):
|
def sos_write(dmr_id, time, message):
|
||||||
user_settings = ast.literal_eval(os.popen('cat ./user_settings.txt').read())
|
user_settings = ast.literal_eval(os.popen('cat ./user_settings.txt').read())
|
||||||
try:
|
try:
|
||||||
if user_settings[dmr_id][1]['ssid'] == '':
|
if user_settings[dmr_id][1]['ssid'] == '':
|
||||||
sos_call = user_settings[dmr_id][0]['call'] + '-' + user_ssid
|
sos_call = user_settings[dmr_id][0]['call'] + '-' + user_ssid
|
||||||
@ -216,9 +215,8 @@ def sos_write(dmr_id, time, message):
|
|||||||
sos_call = user_settings[dmr_id][0]['call'] + '-' + user_settings[dmr_id][1]['ssid']
|
sos_call = user_settings[dmr_id][0]['call'] + '-' + user_settings[dmr_id][1]['ssid']
|
||||||
except:
|
except:
|
||||||
sos_call = str(get_alias((dmr_id), subscriber_ids))
|
sos_call = str(get_alias((dmr_id), subscriber_ids))
|
||||||
|
|
||||||
sos_info = {'call': sos_call, 'dmr_id': dmr_id, 'time': time, 'message':message}
|
sos_info = {'call': sos_call, 'dmr_id': dmr_id, 'time': time, 'message':message}
|
||||||
with open("/tmp/gps_data_user_sos.txt", 'w') as sos_file:
|
with open(emergency_sos_file, 'w') as sos_file:
|
||||||
sos_file.write(str(sos_info))
|
sos_file.write(str(sos_info))
|
||||||
sos_file.close()
|
sos_file.close()
|
||||||
logger.info('Saved SOS.')
|
logger.info('Saved SOS.')
|
||||||
@ -261,6 +259,8 @@ def user_setting_write(dmr_id, setting, value):
|
|||||||
user_dict[dmr_id][1]['ssid'] = value
|
user_dict[dmr_id][1]['ssid'] = value
|
||||||
if setting.upper() == 'COM':
|
if setting.upper() == 'COM':
|
||||||
user_comment = user_dict[dmr_id][3]['comment'] = value[0:35]
|
user_comment = user_dict[dmr_id][3]['comment'] = value[0:35]
|
||||||
|
if setting.upper() == 'APRS':
|
||||||
|
user_dict[dmr_id] = [{'call': str(get_alias((dmr_id), subscriber_ids))}, {'ssid': ''}, {'icon': ''}, {'comment': ''}]
|
||||||
f.close()
|
f.close()
|
||||||
logger.info('Loaded user settings. Preparing to write...')
|
logger.info('Loaded user settings. Preparing to write...')
|
||||||
# Write modified dict to file
|
# Write modified dict to file
|
||||||
@ -288,6 +288,9 @@ def process_sms(_rf_src, sms):
|
|||||||
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@SSID| ','',sms))
|
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@SSID| ','',sms))
|
||||||
elif '@COM' in sms:
|
elif '@COM' in sms:
|
||||||
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@COM |@COM','',sms))
|
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@COM |@COM','',sms))
|
||||||
|
# Write blank entry to cause APRS receive to look for packets for this station.
|
||||||
|
elif '@APRS' in sms:
|
||||||
|
user_setting_write(int_id(_rf_src), 'APRS', '')
|
||||||
elif '@BB' in sms:
|
elif '@BB' in sms:
|
||||||
dashboard_bb_write(get_alias(int_id(_rf_src), subscriber_ids), int_id(_rf_src), time(), re.sub('@BB|@BB ','',sms))
|
dashboard_bb_write(get_alias(int_id(_rf_src), subscriber_ids), int_id(_rf_src), time(), re.sub('@BB|@BB ','',sms))
|
||||||
elif '@' and ' E-' in sms:
|
elif '@' and ' E-' in sms:
|
||||||
@ -306,7 +309,7 @@ def process_sms(_rf_src, sms):
|
|||||||
elif '@SOS' in sms or '@NOTICE' in sms:
|
elif '@SOS' in sms or '@NOTICE' in sms:
|
||||||
sos_write(int_id(_rf_src), time(), sms)
|
sos_write(int_id(_rf_src), time(), sms)
|
||||||
elif '@REM SOS' == sms:
|
elif '@REM SOS' == sms:
|
||||||
os.remove('/tmp/gps_data_user_sos.txt')
|
os.remove(emergency_sos_file)
|
||||||
logger.info('Removing SOS')
|
logger.info('Removing SOS')
|
||||||
elif '@' and 'M-' in sms:
|
elif '@' and 'M-' in sms:
|
||||||
message = re.sub('^@|.* M-|','',sms)
|
message = re.sub('^@|.* M-|','',sms)
|
||||||
@ -358,7 +361,7 @@ def process_sms(_rf_src, sms):
|
|||||||
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
||||||
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
||||||
comment = user_settings[int_id(_rf_src)][3]['comment']
|
comment = user_settings[int_id(_rf_src)][3]['comment']
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
||||||
logger.info(aprs_loc_packet)
|
logger.info(aprs_loc_packet)
|
||||||
logger.info('User comment: ' + comment)
|
logger.info('User comment: ' + comment)
|
||||||
logger.info('User SSID: ' + ssid)
|
logger.info('User SSID: ' + ssid)
|
||||||
@ -1539,7 +1542,7 @@ class routerHBP(HBSYSTEM):
|
|||||||
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
||||||
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
||||||
comment = user_settings[int_id(_rf_src)][3]['comment']
|
comment = user_settings[int_id(_rf_src)][3]['comment']
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
||||||
logger.info(aprs_loc_packet)
|
logger.info(aprs_loc_packet)
|
||||||
logger.info('User comment: ' + comment)
|
logger.info('User comment: ' + comment)
|
||||||
logger.info('User SSID: ' + ssid)
|
logger.info('User SSID: ' + ssid)
|
||||||
@ -1635,14 +1638,14 @@ class routerHBP(HBSYSTEM):
|
|||||||
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
||||||
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
||||||
comment = user_settings[int_id(_rf_src)][3]['comment']
|
comment = user_settings[int_id(_rf_src)][3]['comment']
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + icon_table + str(loc.lon[0:8]) + str(loc.lon_dir) + icon_icon + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + str(comment)
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + icon_table + str(loc.lon[0:8]) + str(loc.lon_dir) + icon_icon + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + str(comment)
|
||||||
logger.info(aprs_loc_packet)
|
logger.info(aprs_loc_packet)
|
||||||
logger.info('User comment: ' + comment)
|
logger.info('User comment: ' + comment)
|
||||||
logger.info('User SSID: ' + ssid)
|
logger.info('User SSID: ' + ssid)
|
||||||
logger.info('User icon: ' + icon_table + icon_icon)
|
logger.info('User icon: ' + icon_table + icon_icon)
|
||||||
except Exception as error_exception:
|
except Exception as error_exception:
|
||||||
logger.info('Error or user settings file not found, proceeding with default settings.')
|
logger.info('Error or user settings file not found, proceeding with default settings.')
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + str(user_ssid) + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + '/' + str(loc.lon[0:8]) + str(loc.lon_dir) + '[' + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + aprs_comment + ' DMR ID: ' + str(int_id(_rf_src))
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + str(user_ssid) + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + '/' + str(loc.lon[0:8]) + str(loc.lon_dir) + '[' + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + aprs_comment + ' DMR ID: ' + str(int_id(_rf_src))
|
||||||
logger.info(error_exception)
|
logger.info(error_exception)
|
||||||
logger.info(str(traceback.extract_tb(error_exception.__traceback__)))
|
logger.info(str(traceback.extract_tb(error_exception.__traceback__)))
|
||||||
try:
|
try:
|
||||||
@ -1769,38 +1772,6 @@ if __name__ == '__main__':
|
|||||||
# Change the current directory to the location of the application
|
# Change the current directory to the location of the application
|
||||||
os.chdir(os.path.dirname(os.path.realpath(sys.argv[0])))
|
os.chdir(os.path.dirname(os.path.realpath(sys.argv[0])))
|
||||||
|
|
||||||
# Check if user_settings (for APRS settings of users) exists. Creat it if not.
|
|
||||||
if Path('./user_settings.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('./user_settings.txt').touch()
|
|
||||||
with open("./user_settings.txt", 'w') as user_dict_file:
|
|
||||||
user_dict_file.write("{1: [{'call': 'N0CALL'}, {'ssid': ''}, {'icon': ''}, {'comment': ''}]}")
|
|
||||||
user_dict_file.close()
|
|
||||||
# Check to see if dashboard files exist
|
|
||||||
if Path('/tmp/gps_data_user_loc.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('/tmp/gps_data_user_loc.txt').touch()
|
|
||||||
with open("/tmp/gps_data_user_loc.txt", 'w') as user_loc_file:
|
|
||||||
user_loc_file.write("[]")
|
|
||||||
user_loc_file.close()
|
|
||||||
if Path('/tmp/gps_data_user_bb.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('/tmp/gps_data_user_bb.txt').touch()
|
|
||||||
with open("/tmp/gps_data_user_bb.txt", 'w') as user_bb_file:
|
|
||||||
user_bb_file.write("[]")
|
|
||||||
user_bb_file.close()
|
|
||||||
if Path('./gps_data_user_mailbox.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('./gps_data_user_mailbox.txt').touch()
|
|
||||||
with open("./gps_data_user_mailbox.txt", 'w') as user_loc_file:
|
|
||||||
user_loc_file.write("[]")
|
|
||||||
user_loc_file.close()
|
|
||||||
|
|
||||||
|
|
||||||
# CLI argument parser - handles picking up the config file from the command line, and sending a "help" message
|
# CLI argument parser - handles picking up the config file from the command line, and sending a "help" message
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
parser.add_argument('-c', '--config', action='store', dest='CONFIG_FILE', help='/full/path/to/config.file (usually hblink.cfg)')
|
parser.add_argument('-c', '--config', action='store', dest='CONFIG_FILE', help='/full/path/to/config.file (usually hblink.cfg)')
|
||||||
@ -1833,6 +1804,43 @@ if __name__ == '__main__':
|
|||||||
smtp_server = CONFIG['GPS_DATA']['SMTP_SERVER']
|
smtp_server = CONFIG['GPS_DATA']['SMTP_SERVER']
|
||||||
smtp_port = CONFIG['GPS_DATA']['SMTP_PORT']
|
smtp_port = CONFIG['GPS_DATA']['SMTP_PORT']
|
||||||
|
|
||||||
|
# Dashboard files
|
||||||
|
bb_file = CONFIG['GPS_DATA']['BULLETIN_BOARD_FILE']
|
||||||
|
loc_file = CONFIG['GPS_DATA']['LOCATION_FILE']
|
||||||
|
the_mailbox_file = CONFIG['GPS_DATA']['MAILBOX_FILE']
|
||||||
|
emergency_sos_file = CONFIG['GPS_DATA']['EMERGENCY_SOS_FILE']
|
||||||
|
|
||||||
|
# Check if user_settings (for APRS settings of users) exists. Creat it if not.
|
||||||
|
if Path('./user_settings.txt').is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path('./user_settings.txt').touch()
|
||||||
|
with open("./user_settings.txt", 'w') as user_dict_file:
|
||||||
|
user_dict_file.write("{1: [{'call': 'N0CALL'}, {'ssid': ''}, {'icon': ''}, {'comment': ''}]}")
|
||||||
|
user_dict_file.close()
|
||||||
|
# Check to see if dashboard files exist
|
||||||
|
if Path(loc_file).is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path(loc_file).touch()
|
||||||
|
with open(loc_file, 'w') as user_loc_file:
|
||||||
|
user_loc_file.write("[]")
|
||||||
|
user_loc_file.close()
|
||||||
|
if Path(bb_file).is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path(bb_file).touch()
|
||||||
|
with open(bb_file, 'w') as user_bb_file:
|
||||||
|
user_bb_file.write("[]")
|
||||||
|
user_bb_file.close()
|
||||||
|
if Path(the_mailbox_file).is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path(the_mailbox_file).touch()
|
||||||
|
with open(the_mailbox_file, 'w') as user_loc_file:
|
||||||
|
user_loc_file.write("[]")
|
||||||
|
user_loc_file.close()
|
||||||
|
|
||||||
# Ensure we have a path for the rules file, if one wasn't specified, then use the default (top of file)
|
# Ensure we have a path for the rules file, if one wasn't specified, then use the default (top of file)
|
||||||
if not cli_args.RULES_FILE:
|
if not cli_args.RULES_FILE:
|
||||||
cli_args.RULES_FILE = os.path.dirname(os.path.abspath(__file__))+'/rules.py'
|
cli_args.RULES_FILE = os.path.dirname(os.path.abspath(__file__))+'/rules.py'
|
||||||
|
@ -161,6 +161,10 @@ def build_config(_config_file):
|
|||||||
'EMAIL_PASSWORD': config.get(section, 'EMAIL_PASSWORD'),
|
'EMAIL_PASSWORD': config.get(section, 'EMAIL_PASSWORD'),
|
||||||
'SMTP_SERVER': config.get(section, 'SMTP_SERVER'),
|
'SMTP_SERVER': config.get(section, 'SMTP_SERVER'),
|
||||||
'SMTP_PORT': config.get(section, 'SMTP_PORT'),
|
'SMTP_PORT': config.get(section, 'SMTP_PORT'),
|
||||||
|
'LOCATION_FILE': config.get(section, 'LOCATION_FILE'),
|
||||||
|
'BULLETIN_BOARD_FILE': config.get(section, 'BULLETIN_BOARD_FILE'),
|
||||||
|
'MAILBOX_FILE': config.get(section, 'MAILBOX_FILE'),
|
||||||
|
'EMERGENCY_SOS_FILE': config.get(section, 'EMERGENCY_SOS_FILE'),
|
||||||
|
|
||||||
})
|
})
|
||||||
if not CONFIG['LOGGER']['LOG_FILE']:
|
if not CONFIG['LOGGER']['LOG_FILE']:
|
||||||
|
@ -105,6 +105,7 @@ PEER_URL: https://www.radioid.net/static/rptrs.json
|
|||||||
SUBSCRIBER_URL: https://www.radioid.net/static/users.json
|
SUBSCRIBER_URL: https://www.radioid.net/static/users.json
|
||||||
STALE_DAYS: 1
|
STALE_DAYS: 1
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
# GPS/Data Application - by KF7EEL
|
# GPS/Data Application - by KF7EEL
|
||||||
# Configure the settings for the DMR GPS to APRS position application here.
|
# Configure the settings for the DMR GPS to APRS position application here.
|
||||||
#
|
#
|
||||||
@ -126,6 +127,11 @@ APRS_LOGIN_PASSCODE: 12345
|
|||||||
APRS_SERVER: rotate.aprs2.net
|
APRS_SERVER: rotate.aprs2.net
|
||||||
APRS_PORT: 14580
|
APRS_PORT: 14580
|
||||||
|
|
||||||
|
# The APRS filter below is used for the message received script. See http://www.aprs-is.net/javAPRSFilter.aspx for details
|
||||||
|
# about APRS filters.
|
||||||
|
APRS_RECEIVE_LOGIN_CALL: N0CALL-1
|
||||||
|
APRS_FILTER: r/47/-120/500 t/m
|
||||||
|
|
||||||
# The following settings are only applicable if you are using the gps_data_beacon_igate script.
|
# The following settings are only applicable if you are using the gps_data_beacon_igate script.
|
||||||
# They do not affect the operation gps_data itself.
|
# They do not affect the operation gps_data itself.
|
||||||
# Time in minutes.
|
# Time in minutes.
|
||||||
@ -135,13 +141,66 @@ IGATE_BEACON_ICON = /I
|
|||||||
IGATE_LATITUDE = 0000.00N
|
IGATE_LATITUDE = 0000.00N
|
||||||
IGATE_LONGITUDE = 00000.00W
|
IGATE_LONGITUDE = 00000.00W
|
||||||
|
|
||||||
|
# The options below are required for operation of the dashboard. Leave them as default
|
||||||
|
# unless you know what you are doing.
|
||||||
|
LOCATION_FILE: /tmp/gps_data_user_loc.txt
|
||||||
|
BULLETIN_BOARD_FILE: /tmp/gps_data_user_bb.txt
|
||||||
|
MAILBOX_FILE: /tmp/gps_data_user_mailbox.txt
|
||||||
|
EMERGENCY_SOS_FILE: /tmp/gps_data_user_sos.txt
|
||||||
|
|
||||||
# The email gateway settingns below are OPTIONAL. They are NOT REQUIRED if you don't want
|
# The email gateway settingns below are OPTIONAL. They are NOT REQUIRED if you don't want
|
||||||
# to enable the email gateway. Leave as is to disable.
|
http://www.aprs-is.net/javAPRSFilter.aspx# to enable the email gateway. Leave as is to disable.
|
||||||
EMAIL_SENDER: test@example.org
|
EMAIL_SENDER: test@example.org
|
||||||
EMAIL_PASSWORD: letmein
|
EMAIL_PASSWORD: letmein
|
||||||
SMTP_SERVER: smtp.gmail.com
|
SMTP_SERVER: smtp.gmail.com
|
||||||
SMTP_PORT: 465
|
SMTP_PORT: 465
|
||||||
|
|
||||||
|
# The options below are required for operation of the dashboard and will cause errors in gps_data.py
|
||||||
|
# if configured wrong. Leave them as default unless you know what you are doing.
|
||||||
|
# If you do change, you must use absolute paths.
|
||||||
|
LOCATION_FILE: /tmp/gps_data_user_loc.txt
|
||||||
|
BULLETIN_BOARD_FILE: /tmp/gps_data_user_bb.txt
|
||||||
|
MAILBOX_FILE: /tmp/gps_data_user_mailbox.txt
|
||||||
|
EMERGENCY_SOS_FILE: /tmp/gps_data_user_sos.txt
|
||||||
|
|
||||||
|
# The following options are used for the dashboard. The dashboard is optional.
|
||||||
|
# Title of the Dashboard
|
||||||
|
DASHBOARD_TITLE: HBLink3 D-APRS Dashboard
|
||||||
|
|
||||||
|
# Logo used on dashboard page
|
||||||
|
LOGO: https://raw.githubusercontent.com/kf7eel/hblink3/gps/HBlink.png
|
||||||
|
|
||||||
|
# Port to run server
|
||||||
|
DASH_PORT: 8092
|
||||||
|
|
||||||
|
# IP to run server on
|
||||||
|
DASH_HOST: 127.0.0.1
|
||||||
|
|
||||||
|
#Description of dashboard to show on main page
|
||||||
|
DESCRIPTION: Welcome to the dashboard.
|
||||||
|
|
||||||
|
# Gateway contact info displayed on about page.
|
||||||
|
CONTACT_NAME: your name
|
||||||
|
CONTACT_CALL: N0CALL
|
||||||
|
CONTACT_EMAIL: email@example.org
|
||||||
|
CONTACT_WEBSITE: https://hbl.ink
|
||||||
|
|
||||||
|
# Time format for display
|
||||||
|
TIME_FORMAT: %%H:%%M:%%S - %%m/%%d/%%y
|
||||||
|
|
||||||
|
# Center dashboard map over these coordinates
|
||||||
|
MAP_CENTER_LAT: 47.00
|
||||||
|
MAP_CENTER_LON: -120.00
|
||||||
|
ZOOM_LEVEL: 7
|
||||||
|
|
||||||
|
# List and preview of some map themes at http://leaflet-extras.github.io/leaflet-providers/preview/
|
||||||
|
# The following are options for map themes and just work, you should use one of these: “OpenStreetMap”, “Stamen” (Terrain, Toner, and Watercolor),
|
||||||
|
MAP_THEME: Stamen Toner
|
||||||
|
|
||||||
|
# RSS feed link, shows in the link section of each RSS item.
|
||||||
|
RSS_LINK: http://localhost:8092
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
# OPENBRIDGE INSTANCES - DUPLICATE SECTION FOR MULTIPLE CONNECTIONS
|
# OPENBRIDGE INSTANCES - DUPLICATE SECTION FOR MULTIPLE CONNECTIONS
|
||||||
# OpenBridge is a protocol originall created by DMR+ for connection between an
|
# OpenBridge is a protocol originall created by DMR+ for connection between an
|
||||||
# IPSC2 server and Brandmeister. It has been implemented here at the suggestion
|
# IPSC2 server and Brandmeister. It has been implemented here at the suggestion
|
||||||
|
101
gps_data.py
101
gps_data.py
@ -155,11 +155,11 @@ def aprs_send(packet):
|
|||||||
|
|
||||||
def dashboard_loc_write(call, lat, lon, time, comment):
|
def dashboard_loc_write(call, lat, lon, time, comment):
|
||||||
#try:
|
#try:
|
||||||
dash_entries = ast.literal_eval(os.popen('cat /tmp/gps_data_user_loc.txt').read())
|
dash_entries = ast.literal_eval(os.popen('cat ' + loc_file).read())
|
||||||
# except:
|
# except:
|
||||||
# dash_entries = []
|
# dash_entries = []
|
||||||
dash_entries.insert(0, {'call': call, 'lat': lat, 'lon': lon, 'time':time, 'comment': comment})
|
dash_entries.insert(0, {'call': call, 'lat': lat, 'lon': lon, 'time':time, 'comment': comment})
|
||||||
with open("/tmp/gps_data_user_loc.txt", 'w') as user_loc_file:
|
with open(loc_file, 'w') as user_loc_file:
|
||||||
user_loc_file.write(str(dash_entries[:200]))
|
user_loc_file.write(str(dash_entries[:200]))
|
||||||
user_loc_file.close()
|
user_loc_file.close()
|
||||||
logger.info('User location saved for dashboard')
|
logger.info('User location saved for dashboard')
|
||||||
@ -167,11 +167,11 @@ def dashboard_loc_write(call, lat, lon, time, comment):
|
|||||||
|
|
||||||
def dashboard_bb_write(call, dmr_id, time, bulletin):
|
def dashboard_bb_write(call, dmr_id, time, bulletin):
|
||||||
#try:
|
#try:
|
||||||
dash_bb = ast.literal_eval(os.popen('cat /tmp/gps_data_user_bb.txt').read())
|
dash_bb = ast.literal_eval(os.popen('cat ' + bb_file).read())
|
||||||
# except:
|
# except:
|
||||||
# dash_entries = []
|
# dash_entries = []
|
||||||
dash_bb.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'bulletin':bulletin})
|
dash_bb.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'bulletin':bulletin})
|
||||||
with open("/tmp/gps_data_user_bb.txt", 'w') as user_bb_file:
|
with open(bb_file, 'w') as user_bb_file:
|
||||||
user_bb_file.write(str(dash_bb[:20]))
|
user_bb_file.write(str(dash_bb[:20]))
|
||||||
user_bb_file.close()
|
user_bb_file.close()
|
||||||
logger.info('User bulletin entry saved.')
|
logger.info('User bulletin entry saved.')
|
||||||
@ -179,21 +179,21 @@ def dashboard_bb_write(call, dmr_id, time, bulletin):
|
|||||||
|
|
||||||
def mailbox_write(call, dmr_id, time, message, recipient):
|
def mailbox_write(call, dmr_id, time, message, recipient):
|
||||||
#try:
|
#try:
|
||||||
mail_file = ast.literal_eval(os.popen('cat ./gps_data_user_mailbox.txt').read())
|
mail_file = ast.literal_eval(os.popen('cat ' + the_mailbox_file).read())
|
||||||
mail_file.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'message':message, 'recipient': recipient})
|
mail_file.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'message':message, 'recipient': recipient})
|
||||||
with open("./gps_data_user_mailbox.txt", 'w') as mailbox_file:
|
with open(the_mailbox_file, 'w') as mailbox_file:
|
||||||
mailbox_file.write(str(mail_file[:100]))
|
mailbox_file.write(str(mail_file[:100]))
|
||||||
mailbox_file.close()
|
mailbox_file.close()
|
||||||
logger.info('User mail saved.')
|
logger.info('User mail saved.')
|
||||||
|
|
||||||
def mailbox_delete(dmr_id):
|
def mailbox_delete(dmr_id):
|
||||||
mail_file = ast.literal_eval(os.popen('cat ./gps_data_user_mailbox.txt').read())
|
mail_file = ast.literal_eval(os.popen('cat ' + the_mailbox_file).read())
|
||||||
call = str(get_alias((dmr_id), subscriber_ids))
|
call = str(get_alias((dmr_id), subscriber_ids))
|
||||||
new_data = []
|
new_data = []
|
||||||
for message in mail_file:
|
for message in mail_file:
|
||||||
if message['recipient'] != call:
|
if message['recipient'] != call:
|
||||||
new_data.append(message)
|
new_data.append(message)
|
||||||
with open("./gps_data_user_mailbox.txt", 'w') as mailbox_file:
|
with open(the_mailbox_file, 'w') as mailbox_file:
|
||||||
mailbox_file.write(str(new_data[:100]))
|
mailbox_file.write(str(new_data[:100]))
|
||||||
mailbox_file.close()
|
mailbox_file.close()
|
||||||
logger.info('Mailbox updated. Delete occurred.')
|
logger.info('Mailbox updated. Delete occurred.')
|
||||||
@ -209,7 +209,7 @@ def sos_write(dmr_id, time, message):
|
|||||||
except:
|
except:
|
||||||
sos_call = str(get_alias((dmr_id), subscriber_ids))
|
sos_call = str(get_alias((dmr_id), subscriber_ids))
|
||||||
sos_info = {'call': sos_call, 'dmr_id': dmr_id, 'time': time, 'message':message}
|
sos_info = {'call': sos_call, 'dmr_id': dmr_id, 'time': time, 'message':message}
|
||||||
with open("/tmp/gps_data_user_sos.txt", 'w') as sos_file:
|
with open(emergency_sos_file, 'w') as sos_file:
|
||||||
sos_file.write(str(sos_info))
|
sos_file.write(str(sos_info))
|
||||||
sos_file.close()
|
sos_file.close()
|
||||||
logger.info('Saved SOS.')
|
logger.info('Saved SOS.')
|
||||||
@ -252,6 +252,8 @@ def user_setting_write(dmr_id, setting, value):
|
|||||||
user_dict[dmr_id][1]['ssid'] = value
|
user_dict[dmr_id][1]['ssid'] = value
|
||||||
if setting.upper() == 'COM':
|
if setting.upper() == 'COM':
|
||||||
user_comment = user_dict[dmr_id][3]['comment'] = value[0:35]
|
user_comment = user_dict[dmr_id][3]['comment'] = value[0:35]
|
||||||
|
if setting.upper() == 'APRS':
|
||||||
|
user_dict[dmr_id] = [{'call': str(get_alias((dmr_id), subscriber_ids))}, {'ssid': ''}, {'icon': ''}, {'comment': ''}]
|
||||||
f.close()
|
f.close()
|
||||||
logger.info('Loaded user settings. Preparing to write...')
|
logger.info('Loaded user settings. Preparing to write...')
|
||||||
# Write modified dict to file
|
# Write modified dict to file
|
||||||
@ -279,6 +281,9 @@ def process_sms(_rf_src, sms):
|
|||||||
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@SSID| ','',sms))
|
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@SSID| ','',sms))
|
||||||
elif '@COM' in sms:
|
elif '@COM' in sms:
|
||||||
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@COM |@COM','',sms))
|
user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@COM |@COM','',sms))
|
||||||
|
# Write blank entry to cause APRS receive to look for packets for this station.
|
||||||
|
elif '@APRS' in sms:
|
||||||
|
user_setting_write(int_id(_rf_src), 'APRS', '')
|
||||||
elif '@BB' in sms:
|
elif '@BB' in sms:
|
||||||
dashboard_bb_write(get_alias(int_id(_rf_src), subscriber_ids), int_id(_rf_src), time.time(), re.sub('@BB|@BB ','',sms))
|
dashboard_bb_write(get_alias(int_id(_rf_src), subscriber_ids), int_id(_rf_src), time.time(), re.sub('@BB|@BB ','',sms))
|
||||||
elif '@' and ' E-' in sms:
|
elif '@' and ' E-' in sms:
|
||||||
@ -297,7 +302,7 @@ def process_sms(_rf_src, sms):
|
|||||||
elif '@SOS' in sms or '@NOTICE' in sms:
|
elif '@SOS' in sms or '@NOTICE' in sms:
|
||||||
sos_write(int_id(_rf_src), time.time(), sms)
|
sos_write(int_id(_rf_src), time.time(), sms)
|
||||||
elif '@REM SOS' == sms:
|
elif '@REM SOS' == sms:
|
||||||
os.remove('/tmp/gps_data_user_sos.txt')
|
os.remove(emergency_sos_file)
|
||||||
logger.info('Removing SOS or Notice')
|
logger.info('Removing SOS or Notice')
|
||||||
elif '@' and 'M-' in sms:
|
elif '@' and 'M-' in sms:
|
||||||
message = re.sub('^@|.* M-|','',sms)
|
message = re.sub('^@|.* M-|','',sms)
|
||||||
@ -349,7 +354,7 @@ def process_sms(_rf_src, sms):
|
|||||||
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
||||||
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
||||||
comment = user_settings[int_id(_rf_src)][3]['comment']
|
comment = user_settings[int_id(_rf_src)][3]['comment']
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
||||||
logger.info(aprs_loc_packet)
|
logger.info(aprs_loc_packet)
|
||||||
logger.info('User comment: ' + comment)
|
logger.info('User comment: ' + comment)
|
||||||
logger.info('User SSID: ' + ssid)
|
logger.info('User SSID: ' + ssid)
|
||||||
@ -485,7 +490,7 @@ class DATA_SYSTEM(HBSYSTEM):
|
|||||||
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
||||||
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
||||||
comment = user_settings[int_id(_rf_src)][3]['comment']
|
comment = user_settings[int_id(_rf_src)][3]['comment']
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(aprs_lat) + icon_table + str(aprs_lon) + icon_icon + '/' + str(comment)
|
||||||
logger.info(aprs_loc_packet)
|
logger.info(aprs_loc_packet)
|
||||||
logger.info('User comment: ' + comment)
|
logger.info('User comment: ' + comment)
|
||||||
logger.info('User SSID: ' + ssid)
|
logger.info('User SSID: ' + ssid)
|
||||||
@ -581,14 +586,14 @@ class DATA_SYSTEM(HBSYSTEM):
|
|||||||
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
ssid = user_settings[int_id(_rf_src)][1]['ssid']
|
||||||
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
if user_settings[int_id(_rf_src)][3]['comment'] != '':
|
||||||
comment = user_settings[int_id(_rf_src)][3]['comment']
|
comment = user_settings[int_id(_rf_src)][3]['comment']
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + icon_table + str(loc.lon[0:8]) + str(loc.lon_dir) + icon_icon + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + str(comment)
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + ssid + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + icon_table + str(loc.lon[0:8]) + str(loc.lon_dir) + icon_icon + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + str(comment)
|
||||||
logger.info(aprs_loc_packet)
|
logger.info(aprs_loc_packet)
|
||||||
logger.info('User comment: ' + comment)
|
logger.info('User comment: ' + comment)
|
||||||
logger.info('User SSID: ' + ssid)
|
logger.info('User SSID: ' + ssid)
|
||||||
logger.info('User icon: ' + icon_table + icon_icon)
|
logger.info('User icon: ' + icon_table + icon_icon)
|
||||||
except Exception as error_exception:
|
except Exception as error_exception:
|
||||||
logger.info('Error or user settings file not found, proceeding with default settings.')
|
logger.info('Error or user settings file not found, proceeding with default settings.')
|
||||||
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + str(user_ssid) + '>APHBL3,TCPIP*:/' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + '/' + str(loc.lon[0:8]) + str(loc.lon_dir) + '[' + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + aprs_comment + ' DMR ID: ' + str(int_id(_rf_src))
|
aprs_loc_packet = str(get_alias(int_id(_rf_src), subscriber_ids)) + '-' + str(user_ssid) + '>APHBL3,TCPIP*:@' + str(datetime.datetime.utcnow().strftime("%H%M%Sh")) + str(loc.lat[0:7]) + str(loc.lat_dir) + '/' + str(loc.lon[0:8]) + str(loc.lon_dir) + '[' + str(round(loc.true_course)).zfill(3) + '/' + str(round(loc.spd_over_grnd)).zfill(3) + '/' + aprs_comment + ' DMR ID: ' + str(int_id(_rf_src))
|
||||||
logger.info(error_exception)
|
logger.info(error_exception)
|
||||||
logger.info(str(traceback.extract_tb(error_exception.__traceback__)))
|
logger.info(str(traceback.extract_tb(error_exception.__traceback__)))
|
||||||
try:
|
try:
|
||||||
@ -671,36 +676,7 @@ if __name__ == '__main__':
|
|||||||
# Change the current directory to the location of the application
|
# Change the current directory to the location of the application
|
||||||
os.chdir(os.path.dirname(os.path.realpath(sys.argv[0])))
|
os.chdir(os.path.dirname(os.path.realpath(sys.argv[0])))
|
||||||
|
|
||||||
# Check if user_settings (for APRS settings of users) exists. Creat it if not.
|
|
||||||
if Path('./user_settings.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('./user_settings.txt').touch()
|
|
||||||
with open("./user_settings.txt", 'w') as user_dict_file:
|
|
||||||
user_dict_file.write("{1: [{'call': 'N0CALL'}, {'ssid': ''}, {'icon': ''}, {'comment': ''}]}")
|
|
||||||
user_dict_file.close()
|
|
||||||
# Check to see if dashboard files exist
|
|
||||||
if Path('/tmp/gps_data_user_loc.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('/tmp/gps_data_user_loc.txt').touch()
|
|
||||||
with open("/tmp/gps_data_user_loc.txt", 'w') as user_loc_file:
|
|
||||||
user_loc_file.write("[]")
|
|
||||||
user_loc_file.close()
|
|
||||||
if Path('/tmp/gps_data_user_bb.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('/tmp/gps_data_user_bb.txt').touch()
|
|
||||||
with open("/tmp/gps_data_user_bb.txt", 'w') as user_bb_file:
|
|
||||||
user_bb_file.write("[]")
|
|
||||||
user_bb_file.close()
|
|
||||||
if Path('./gps_data_user_mailbox.txt').is_file():
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
Path('./gps_data_user_mailbox.txt').touch()
|
|
||||||
with open("./gps_data_user_mailbox.txt", 'w') as user_loc_file:
|
|
||||||
user_loc_file.write("[]")
|
|
||||||
user_loc_file.close()
|
|
||||||
# CLI argument parser - handles picking up the config file from the command line, and sending a "help" message
|
# CLI argument parser - handles picking up the config file from the command line, and sending a "help" message
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
parser.add_argument('-c', '--config', action='store', dest='CONFIG_FILE', help='/full/path/to/config.file (usually gps_data.cfg)')
|
parser.add_argument('-c', '--config', action='store', dest='CONFIG_FILE', help='/full/path/to/config.file (usually gps_data.cfg)')
|
||||||
@ -730,6 +706,43 @@ if __name__ == '__main__':
|
|||||||
email_password = CONFIG['GPS_DATA']['EMAIL_PASSWORD']
|
email_password = CONFIG['GPS_DATA']['EMAIL_PASSWORD']
|
||||||
smtp_server = CONFIG['GPS_DATA']['SMTP_SERVER']
|
smtp_server = CONFIG['GPS_DATA']['SMTP_SERVER']
|
||||||
smtp_port = CONFIG['GPS_DATA']['SMTP_PORT']
|
smtp_port = CONFIG['GPS_DATA']['SMTP_PORT']
|
||||||
|
|
||||||
|
# Dashboard files
|
||||||
|
bb_file = CONFIG['GPS_DATA']['BULLETIN_BOARD_FILE']
|
||||||
|
loc_file = CONFIG['GPS_DATA']['LOCATION_FILE']
|
||||||
|
the_mailbox_file = CONFIG['GPS_DATA']['MAILBOX_FILE']
|
||||||
|
emergency_sos_file = CONFIG['GPS_DATA']['EMERGENCY_SOS_FILE']
|
||||||
|
|
||||||
|
# Check if user_settings (for APRS settings of users) exists. Creat it if not.
|
||||||
|
if Path('./user_settings.txt').is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path('./user_settings.txt').touch()
|
||||||
|
with open("./user_settings.txt", 'w') as user_dict_file:
|
||||||
|
user_dict_file.write("{1: [{'call': 'N0CALL'}, {'ssid': ''}, {'icon': ''}, {'comment': ''}]}")
|
||||||
|
user_dict_file.close()
|
||||||
|
# Check to see if dashboard files exist
|
||||||
|
if Path(loc_file).is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path(loc_file).touch()
|
||||||
|
with open(loc_file, 'w') as user_loc_file:
|
||||||
|
user_loc_file.write("[]")
|
||||||
|
user_loc_file.close()
|
||||||
|
if Path(bb_file).is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path(bb_file).touch()
|
||||||
|
with open(bb_file, 'w') as user_bb_file:
|
||||||
|
user_bb_file.write("[]")
|
||||||
|
user_bb_file.close()
|
||||||
|
if Path(the_mailbox_file).is_file():
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
Path(the_mailbox_file).touch()
|
||||||
|
with open(the_mailbox_file, 'w') as user_loc_file:
|
||||||
|
user_loc_file.write("[]")
|
||||||
|
user_loc_file.close()
|
||||||
|
|
||||||
# Start the system logger
|
# Start the system logger
|
||||||
if cli_args.LOG_LEVEL:
|
if cli_args.LOG_LEVEL:
|
||||||
|
@ -1,28 +1,83 @@
|
|||||||
|
###############################################################################
|
||||||
|
# GPS/Data - Copyright (C) 2020 Eric Craw, KF7EEL <kf7eel@qsl.net>
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
import aprslib
|
import aprslib
|
||||||
import ast, os
|
import ast, os
|
||||||
|
import re
|
||||||
|
from configparser import ConfigParser
|
||||||
|
import time
|
||||||
|
import argparse
|
||||||
|
|
||||||
def mailbox_write(call, dmr_id, time, message, recipient):
|
def mailbox_write(call, dmr_id, time, message, recipient):
|
||||||
mail_file = ast.literal_eval(os.popen('cat ../../gps_data_user_mailbox.txt').read())
|
mail_file = ast.literal_eval(os.popen('cat ' + mailbox_file).read())
|
||||||
mail_file.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'message':message, 'recipient': recipient})
|
mail_file.insert(0, {'call': call, 'dmr_id': dmr_id, 'time': time, 'message':message, 'recipient': recipient})
|
||||||
with open("../../gps_data_user_mailbox.txt", 'w') as mailbox_file:
|
with open("../../gps_data_user_mailbox.txt", 'w') as mailbox_file:
|
||||||
mailbox_file.write(str(mail_file[:100]))
|
mailbox_file.write(str(mail_file[:100]))
|
||||||
mailbox_file.close()
|
mailbox_file.close()
|
||||||
logger.info('User mail saved.')
|
print('User mail saved.')
|
||||||
|
|
||||||
def aprs_filter(packet):
|
def aprs_filter(packet):
|
||||||
#if aprslib.parse(packet) in aprslib.parse(packet):
|
#if aprslib.parse(packet) in aprslib.parse(packet):
|
||||||
# print(aprslib.parse(packet))
|
# print(aprslib.parse(packet))
|
||||||
#else:
|
#else:
|
||||||
# pass
|
# pass
|
||||||
if aprslib.parse(packet)['to'] in user_settings:
|
user_settings = ast.literal_eval(os.popen('cat ../../user_settings.txt').read())
|
||||||
print(aprslib.parse(packet))
|
if 'addresse' in aprslib.parse(packet):
|
||||||
mailbox_write(aprslib.parse(packet)['from'], aprslib.parse(packet)['to'], time.time(), aprslib.parse(packet)['message_text'], recipient)
|
#print(aprslib.parse(packet))
|
||||||
|
recipient = re.sub('-.*','', aprslib.parse(packet)['addresse'])
|
||||||
user_settings = ast.literal_eval(os.popen('cat ../../user_settings.txt').read())
|
recipient_ssid = re.sub('.*-','', aprslib.parse(packet)['addresse'])
|
||||||
recipient = re.sub('-.*','', aprslib.parse(packet)['to'])
|
|
||||||
AIS = aprslib.IS("N0CALL", host='rotate.aprs.net')
|
for i in user_settings.items():
|
||||||
AIS.connect()
|
## print('checking user_settings ' + recipient)
|
||||||
# by default `raw` is False, then each line is ran through aprslib.parse()
|
if recipient in i[1][0]['call'] and recipient_ssid in i[1][1]['ssid']:
|
||||||
AIS.consumer(aprs_filter, raw=True)
|
## print(i[1][0])
|
||||||
|
## print(i[1][1])
|
||||||
|
## print(aprslib.parse(packet))
|
||||||
|
mailbox_write(re.sub('-.*','', aprslib.parse(packet)['addresse']), aprslib.parse(packet)['from'], time.time(), aprslib.parse(packet)['message_text'], recipient)
|
||||||
|
if 'msgNo' in aprslib.parse(packet):
|
||||||
|
time.sleep(1)
|
||||||
|
AIS.sendall(aprslib.parse(packet)['addresse'] + '>APHBL3,TCPIP*:' + ':' + aprslib.parse(packet)['from'].ljust(9) +':ack'+aprslib.parse(packet)['msgNo'])
|
||||||
|
print('Send ACK')
|
||||||
|
print(aprslib.parse(packet)['addresse'] + '>APHBL3,TCPIP*:' + ':' + aprslib.parse(packet)['from'].ljust(9) +':ack'+aprslib.parse(packet)['msgNo'])
|
||||||
|
## else:
|
||||||
|
## print(aprslib.parse(packet)['from'])
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
arg_parser = argparse.ArgumentParser()
|
||||||
|
arg_parser.add_argument('-c', '--config', action='store', dest='CONFIG_FILE', help='/full/path/to/config.file (usually gps_data.cfg)')
|
||||||
|
cli_args = arg_parser.parse_args()
|
||||||
|
parser = ConfigParser()
|
||||||
|
if not cli_args.CONFIG_FILE:
|
||||||
|
print('\n\nMust specify a config file with -c argument.\n\n')
|
||||||
|
parser.read(cli_args.CONFIG_FILE)
|
||||||
|
|
||||||
|
aprs_server = parser.get('GPS_DATA', 'APRS_SERVER')
|
||||||
|
aprs_port = parser.get('GPS_DATA', 'APRS_PORT')
|
||||||
|
aprs_login = parser.get('GPS_DATA', 'APRS_RECEIVE_LOGIN_CALL')
|
||||||
|
aprs_passcode = parser.get('GPS_DATA', 'APRS_LOGIN_PASSCODE')
|
||||||
|
mailbox_file = parser.get('GPS_DATA', 'MAILBOX_FILE')
|
||||||
|
|
||||||
|
AIS = aprslib.IS(aprs_login, passwd=int(aprs_passcode), host=aprs_server, port=int(aprs_port))
|
||||||
|
user_settings = ast.literal_eval(os.popen('cat ../../user_settings.txt').read())
|
||||||
|
print('APRS message receive script for GPS/Data Application.\nAuthor: Eric, KF7EEL - kf7eel@qsl.net')
|
||||||
|
AIS.set_filter(parser.get('GPS_DATA', 'APRS_FILTER'))
|
||||||
|
AIS.connect()
|
||||||
|
print('Connecting to APRS-IS')
|
||||||
|
AIS.consumer(aprs_filter, raw=True)
|
||||||
|
|
||||||
|
|
||||||
|
@ -23,11 +23,15 @@ This is a web dashboard for the GPS/Data application.
|
|||||||
|
|
||||||
from flask import Flask, render_template, request, Response, Markup
|
from flask import Flask, render_template, request, Response, Markup
|
||||||
import ast, os
|
import ast, os
|
||||||
from dashboard_settings import *
|
#from dashboard_settings import *
|
||||||
import folium
|
import folium
|
||||||
from folium.plugins import MarkerCluster
|
from folium.plugins import MarkerCluster
|
||||||
import re
|
import re
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
import argparse
|
||||||
|
from configparser import ConfigParser
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
app = Flask(__name__)
|
app = Flask(__name__)
|
||||||
|
|
||||||
@ -42,7 +46,7 @@ tbl_ftr = '''
|
|||||||
|
|
||||||
def get_loc_data():
|
def get_loc_data():
|
||||||
try:
|
try:
|
||||||
dash_loc = ast.literal_eval(os.popen('cat /tmp/gps_data_user_loc.txt').read())
|
dash_loc = ast.literal_eval(os.popen('cat ' + loc_file).read())
|
||||||
tmp_loc = ''
|
tmp_loc = ''
|
||||||
loc_hdr = '''
|
loc_hdr = '''
|
||||||
<tr>
|
<tr>
|
||||||
@ -88,7 +92,7 @@ def get_loc_data():
|
|||||||
|
|
||||||
def get_bb_data():
|
def get_bb_data():
|
||||||
try:
|
try:
|
||||||
dash_bb = ast.literal_eval(os.popen('cat /tmp/gps_data_user_bb.txt').read())
|
dash_bb = ast.literal_eval(os.popen('cat ' + bb_file).read())
|
||||||
tmp_bb = ''
|
tmp_bb = ''
|
||||||
|
|
||||||
bb_hdr = '''
|
bb_hdr = '''
|
||||||
@ -132,7 +136,7 @@ def get_bb_data():
|
|||||||
def check_emergency():
|
def check_emergency():
|
||||||
# open emergency txt
|
# open emergency txt
|
||||||
try:
|
try:
|
||||||
sos_file = ast.literal_eval(os.popen('cat /tmp/gps_data_user_sos.txt').read())
|
sos_file = ast.literal_eval(os.popen('cat ' + emergency_sos_file).read())
|
||||||
if type(sos_file['time']) == str:
|
if type(sos_file['time']) == str:
|
||||||
loc_time = str(sos_file['time'])
|
loc_time = str(sos_file['time'])
|
||||||
if type(sos_file['time']) == int or type(sos_file['time']) == float:
|
if type(sos_file['time']) == int or type(sos_file['time']) == float:
|
||||||
@ -200,7 +204,7 @@ def view_map():
|
|||||||
reload_time = request.args.get('reload')
|
reload_time = request.args.get('reload')
|
||||||
track_call = request.args.get('track')
|
track_call = request.args.get('track')
|
||||||
map_size = request.args.get('map_size')
|
map_size = request.args.get('map_size')
|
||||||
user_loc = ast.literal_eval(os.popen('cat /tmp/gps_data_user_loc.txt').read())
|
user_loc = ast.literal_eval(os.popen('cat ' + loc_file).read())
|
||||||
last_known_list = []
|
last_known_list = []
|
||||||
try:
|
try:
|
||||||
if track_call:
|
if track_call:
|
||||||
@ -302,7 +306,7 @@ def view_map():
|
|||||||
return render_template('generic.html', title = dashboard_title, logo = logo, content = Markup(content))
|
return render_template('generic.html', title = dashboard_title, logo = logo, content = Markup(content))
|
||||||
|
|
||||||
if not track_call:
|
if not track_call:
|
||||||
folium_map = folium.Map(location=map_center, tiles=map_theme, zoom_start=int(zoom_level))
|
folium_map = folium.Map(location=(map_center_lat, map_center_lon), tiles=map_theme, zoom_start=int(zoom_level))
|
||||||
marker_cluster = MarkerCluster().add_to(folium_map)
|
marker_cluster = MarkerCluster().add_to(folium_map)
|
||||||
for user_coord in user_loc:
|
for user_coord in user_loc:
|
||||||
user_lat = aprs_to_latlon(float(re.sub('[A-Za-z]','', user_coord['lat'])))
|
user_lat = aprs_to_latlon(float(re.sub('[A-Za-z]','', user_coord['lat'])))
|
||||||
@ -406,7 +410,7 @@ def user_settings():
|
|||||||
if icon == '':
|
if icon == '':
|
||||||
icon = '\['
|
icon = '\['
|
||||||
if comment == '':
|
if comment == '':
|
||||||
comment = 'Default comment.'
|
comment = default_comment + ' ' + user_id
|
||||||
#for result in user_settings:
|
#for result in user_settings:
|
||||||
#return user_settings[int(user_id)][0]
|
#return user_settings[int(user_id)][0]
|
||||||
#return user_id
|
#return user_id
|
||||||
@ -471,7 +475,7 @@ def mailbox():
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
else:
|
else:
|
||||||
mailbox_file = ast.literal_eval(os.popen('cat ../../gps_data_user_mailbox.txt').read())
|
mailbox_file = ast.literal_eval(os.popen('cat ' + the_mailbox_file).read())
|
||||||
mail_content = '<h2 style="text-align: center;">Messages for: ' + recipient.upper() + '''
|
mail_content = '<h2 style="text-align: center;">Messages for: ' + recipient.upper() + '''
|
||||||
</h2>\n<p style="text-align: center;"><button onclick="history.back()">Back</button></p>\n
|
</h2>\n<p style="text-align: center;"><button onclick="history.back()">Back</button></p>\n
|
||||||
<h4 style="text-align: center;"><a href="mailbox_rss?recipient=''' + recipient.upper() + '''"><em>Mailbox RSS Feed for ''' + recipient.upper() + '''</em></a><img src="" /></h4>
|
<h4 style="text-align: center;"><a href="mailbox_rss?recipient=''' + recipient.upper() + '''"><em>Mailbox RSS Feed for ''' + recipient.upper() + '''</em></a><img src="" /></h4>
|
||||||
@ -518,10 +522,11 @@ def mailbox():
|
|||||||
"""
|
"""
|
||||||
return render_template('generic.html', title = dashboard_title, logo = logo, content = Markup(mail_content))
|
return render_template('generic.html', title = dashboard_title, logo = logo, content = Markup(mail_content))
|
||||||
|
|
||||||
|
|
||||||
@app.route('/bulletin_rss.xml')
|
@app.route('/bulletin_rss.xml')
|
||||||
def bb_rss():
|
def bb_rss():
|
||||||
try:
|
try:
|
||||||
dash_bb = ast.literal_eval(os.popen('cat /tmp/gps_data_user_bb.txt').read())
|
dash_bb = ast.literal_eval(os.popen('cat ' + bb_file).read())
|
||||||
post_data = ''
|
post_data = ''
|
||||||
rss_header = """<?xml version="1.0" encoding="UTF-8" ?>
|
rss_header = """<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<rss version="2.0">
|
<rss version="2.0">
|
||||||
@ -542,12 +547,13 @@ def bb_rss():
|
|||||||
</item>
|
</item>
|
||||||
"""
|
"""
|
||||||
return Response(rss_header + post_data + "\n</channel>\n</rss>", mimetype='text/xml')
|
return Response(rss_header + post_data + "\n</channel>\n</rss>", mimetype='text/xml')
|
||||||
except:
|
except Exception as e:
|
||||||
return str('<h1 style="text-align: center;">No data</h1>')
|
#return str('<h1 style="text-align: center;">No data</h1>')
|
||||||
|
return str(e)
|
||||||
|
|
||||||
@app.route('/mailbox_rss')
|
@app.route('/mailbox_rss')
|
||||||
def mail_rss():
|
def mail_rss():
|
||||||
mailbox_file = ast.literal_eval(os.popen('cat ../../gps_data_user_mailbox.txt').read())
|
mailbox_file = ast.literal_eval(os.popen('cat ' + the_mailbox_file).read())
|
||||||
post_data = ''
|
post_data = ''
|
||||||
recipient = request.args.get('recipient').upper()
|
recipient = request.args.get('recipient').upper()
|
||||||
rss_header = """<?xml version="1.0" encoding="UTF-8" ?>
|
rss_header = """<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
@ -572,4 +578,64 @@ def mail_rss():
|
|||||||
return Response(rss_header + post_data + "\n</channel>\n</rss>", mimetype='text/xml')
|
return Response(rss_header + post_data + "\n</channel>\n</rss>", mimetype='text/xml')
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
arg_parser = argparse.ArgumentParser()
|
||||||
|
arg_parser.add_argument('-c', '--config', action='store', dest='CONFIG_FILE', help='/full/path/to/config.file (usually gps_data.cfg)')
|
||||||
|
cli_args = arg_parser.parse_args()
|
||||||
|
parser = ConfigParser()
|
||||||
|
if not cli_args.CONFIG_FILE:
|
||||||
|
print('\n\nMust specify a config file with -c argument.\n\n')
|
||||||
|
parser.read(cli_args.CONFIG_FILE)
|
||||||
|
###### Definitions #####
|
||||||
|
# Title of the Dashboard
|
||||||
|
dashboard_title = parser.get('GPS_DATA', 'DASHBOARD_TITLE')
|
||||||
|
# Logo used on dashboard page
|
||||||
|
logo = parser.get('GPS_DATA', 'LOGO')
|
||||||
|
dash_port = int(parser.get('GPS_DATA', 'DASH_PORT'))
|
||||||
|
# IP to run server on
|
||||||
|
dash_host = parser.get('GPS_DATA', 'DASH_HOST')
|
||||||
|
#Description of dashboard to show on main page
|
||||||
|
description = parser.get('GPS_DATA', 'DESCRIPTION')
|
||||||
|
# The following will generate a help page for your users.
|
||||||
|
|
||||||
|
# Data call type
|
||||||
|
if parser.get('GPS_DATA', 'CALL_TYPE') == 'unit':
|
||||||
|
data_call_type = 'Private Call'
|
||||||
|
if parser.get('GPS_DATA', 'CALL_TYPE') == 'group':
|
||||||
|
data_call_type = 'Group Call'
|
||||||
|
if parser.get('GPS_DATA', 'CALL_TYPE') == 'both':
|
||||||
|
data_call_type = 'Private or Group Call'
|
||||||
|
# DMR ID of GPS/Data application
|
||||||
|
data_call_id = parser.get('GPS_DATA', 'DATA_DMR_ID')
|
||||||
|
# Default APRS ssid
|
||||||
|
aprs_ssid = parser.get('GPS_DATA', 'USER_APRS_SSID')
|
||||||
|
|
||||||
|
# Gateway contact info displayed on about page.
|
||||||
|
contact_name = parser.get('GPS_DATA', 'CONTACT_NAME')
|
||||||
|
contact_call = parser.get('GPS_DATA', 'CONTACT_CALL')
|
||||||
|
contact_email = parser.get('GPS_DATA', 'CONTACT_EMAIL')
|
||||||
|
contact_website = parser.get('GPS_DATA', 'CONTACT_WEBSITE')
|
||||||
|
|
||||||
|
# Center dashboard map over these coordinates
|
||||||
|
map_center_lat = float(parser.get('GPS_DATA', 'MAP_CENTER_LAT'))
|
||||||
|
map_center_lon = float(parser.get('GPS_DATA', 'MAP_CENTER_LON'))
|
||||||
|
zoom_level = int(parser.get('GPS_DATA', 'ZOOM_LEVEL'))
|
||||||
|
map_theme = parser.get('GPS_DATA', 'MAP_THEME')
|
||||||
|
|
||||||
|
# Time format for display
|
||||||
|
time_format = parser.get('GPS_DATA', 'TIME_FORMAT')
|
||||||
|
|
||||||
|
# RSS feed link, shows in the link section of each RSS item.
|
||||||
|
rss_link = parser.get('GPS_DATA', 'RSS_LINK')
|
||||||
|
|
||||||
|
# Default APRS comment for users.
|
||||||
|
default_comment = parser.get('GPS_DATA', 'USER_APRS_COMMENT')
|
||||||
|
|
||||||
|
|
||||||
|
# DO NOT MODIFY BELOW HERE.
|
||||||
|
bb_file = parser.get('GPS_DATA', 'BULLETIN_BOARD_FILE')
|
||||||
|
loc_file = parser.get('GPS_DATA', 'LOCATION_FILE')
|
||||||
|
emergency_sos_file = parser.get('GPS_DATA', 'EMERGENCY_SOS_FILE')
|
||||||
|
the_mailbox_file = parser.get('GPS_DATA', 'MAILBOX_FILE')
|
||||||
|
########################
|
||||||
|
|
||||||
app.run(debug = True, port=dash_port, host=dash_host)
|
app.run(debug = True, port=dash_port, host=dash_host)
|
||||||
|
Loading…
Reference in New Issue
Block a user