154 lines
6.0 KiB
Python
154 lines
6.0 KiB
Python
###############################################################################
|
|
# HBLink - Copyright (C) 2020 Cortney T. Buffington, N0MJS <n0mjs@me.com>
|
|
# 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
|
|
###############################################################################
|
|
|
|
'''
|
|
This is a web dashboard for the GPS/Data application.
|
|
'''
|
|
|
|
from flask import Flask, render_template
|
|
import ast, os
|
|
from dashboard_settings import *
|
|
import folium
|
|
import re
|
|
|
|
app = Flask(__name__)
|
|
|
|
|
|
tbl_hdr = '''
|
|
<table style="border-color: black; margin-left: auto; margin-right: auto;" border="2" cellspacing="6" cellpadding="2"><tbody>
|
|
'''
|
|
tbl_ftr = '''
|
|
</tbody>
|
|
</table>
|
|
'''
|
|
|
|
def get_loc_data():
|
|
try:
|
|
dash_loc = ast.literal_eval(os.popen('cat /tmp/gps_data_user_loc.txt').read())
|
|
tmp_loc = ''
|
|
loc_hdr = '''
|
|
<tr>
|
|
<td style="text-align: center;">
|
|
<h2><strong> Callsign </strong></h2>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<h2> <strong>Latitude</strong> </h2>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<h2> <strong>Longitude</strong> </h2>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<h2> <strong>Local Time</strong> </h2>
|
|
</td>
|
|
</tr>
|
|
'''
|
|
for e in dash_loc:
|
|
tmp_loc = tmp_loc + '''<tr>
|
|
<td style="text-align: center;"><a href="https://aprs.fi/''' + e['call'] + '''"><strong>''' + e['call'] + '''</strong></a></td>
|
|
<td style="text-align: center;"><strong> ''' + str(e['lat']) + ''' </strong></td>
|
|
<td style="text-align: center;"><strong> ''' + str(e['lon']) + ''' </strong></td>
|
|
<td style="text-align: center;"> ''' + e['time'] + ''' </td>
|
|
</tr>'''
|
|
return str(str('<h1 style="text-align: center;">Positions Received</h1>') + tbl_hdr + loc_hdr + tmp_loc + tbl_ftr)
|
|
except:
|
|
return str('<h1 style="text-align: center;">No data</h1>')
|
|
|
|
|
|
def get_bb_data():
|
|
try:
|
|
dash_bb = ast.literal_eval(os.popen('cat /tmp/gps_data_user_bb.txt').read())
|
|
tmp_bb = ''
|
|
|
|
bb_hdr = '''
|
|
<tr>
|
|
<td style="text-align: center;">
|
|
<h2><strong> Callsign </strong></h2>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<h2> <strong>DMR ID</strong> </h2>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<h2> <strong>Bulletin</strong> </h2>
|
|
</td>
|
|
<td style="text-align: center;">
|
|
<h2> <strong>Local Time</strong> </h2>
|
|
</td>
|
|
</tr>
|
|
'''
|
|
|
|
for e in dash_bb:
|
|
tmp_bb = tmp_bb + '''<tr>
|
|
<td style="text-align: center;"><strong> ''' + e['call'] + ''' </strong></td>
|
|
<td style="text-align: center;">''' + str(e['dmr_id']) + '''</td>
|
|
<td style="text-align: center;"><strong> ''' + e['bulliten'] + ''' </strong></td>
|
|
<td style="text-align: center;"> ''' + e['time'] + ''' </td>
|
|
</tr>'''
|
|
|
|
return str('<h1 style="text-align: center;">Bulletin Board</h1>' + tbl_hdr + bb_hdr + tmp_bb + tbl_ftr)
|
|
except:
|
|
return str('<h1 style="text-align: center;">No data</h1>')
|
|
def aprs_to_latlon(x):
|
|
degrees = int(x) // 100
|
|
minutes = x - 100*degrees
|
|
return degrees + minutes/60
|
|
|
|
@app.route('/')
|
|
def index():
|
|
#return get_data()
|
|
return render_template('index.html', title = dashboard_title, logo = logo)
|
|
@app.route('/bulletin_board')
|
|
def dash_bb():
|
|
return get_bb_data()
|
|
#return render_template('index.html', data = str(get_data()))
|
|
@app.route('/positions')
|
|
def dash_loc():
|
|
return get_loc_data()
|
|
#return render_template('index.html', data = str(get_data()))
|
|
##@app.route('/<string:page_name>/')
|
|
##def render_static(page_name):
|
|
## return render_template('%s.html' % page_name, title = dashboard_title, logo = logo, description = description)
|
|
@app.route('/help/')
|
|
def help():
|
|
#return get_data()
|
|
return render_template('help.html', title = dashboard_title, logo = logo, description = description, data_call_type = data_call_type, data_call_id = data_call_id, aprs_ssid = aprs_ssid)
|
|
@app.route('/about/')
|
|
def about():
|
|
#return get_data()
|
|
return render_template('about.html', title = dashboard_title, logo = logo, contact_name = contact_name, contact_call = contact_call, contact_email = contact_email, contact_website = contact_website)
|
|
@app.route('/view_map/')
|
|
def view_map():
|
|
user_loc = ast.literal_eval(os.popen('cat /tmp/gps_data_user_loc.txt').read())
|
|
#map_center = (47.9540700, -120.7360300)
|
|
folium_map = folium.Map(location=map_center, zoom_start=int(zoom_level))
|
|
for user_coord in user_loc:
|
|
user_lat = aprs_to_latlon(float(re.sub('[A-Za-z]','', user_coord['lat'])))
|
|
user_lon = aprs_to_latlon(float(re.sub('[A-Za-z]','', user_coord['lon'])))
|
|
if 'S' in user_coord['lat']:
|
|
user_lat = -user_lat
|
|
if 'W' in user_coord['lon']:
|
|
user_lon = -user_lon
|
|
folium.Marker([user_lat, user_lon], popup="<i>" + '<strong>' + str(user_coord['call']) + '</strong>' + '\n' + user_coord['time'] + "</i>", tooltip=str(user_coord['call'])).add_to(folium_map)
|
|
return folium_map._repr_html_()
|
|
@app.route('/map/')
|
|
def map():
|
|
return render_template('map.html', title = dashboard_title, logo = logo)
|
|
|
|
if __name__ == '__main__':
|
|
app.run(debug = True, port=dash_port, host=dash_host)
|