kopia lustrzana https://github.com/glidernet/ogn-python
187 wiersze
6.2 KiB
Python
187 wiersze
6.2 KiB
Python
import datetime
|
|
|
|
from flask import request, render_template, send_file
|
|
|
|
from app import db
|
|
from app import cache
|
|
from app.model import Airport, Country, Device, Logbook, Receiver
|
|
|
|
from app.main import bp
|
|
|
|
|
|
@cache.cached(key_prefix="countries_in_receivers")
|
|
def get_countries_in_receivers():
|
|
query = db.session.query(Country.iso2).filter(Country.gid == Receiver.country_id).order_by(Country.iso2).distinct(Country.iso2)
|
|
|
|
return [{"iso2": country[0]} for country in query.all()]
|
|
|
|
|
|
@cache.cached(key_prefix="countries_in_logbook")
|
|
def get_countries_in_logbook():
|
|
query = db.session.query(Country.iso2).filter(Country.iso2 == Airport.country_code).filter(Logbook.takeoff_airport_id == Airport.id).order_by(Country.iso2).distinct(Country.iso2)
|
|
|
|
return [{"iso2": country[0]} for country in query.all()]
|
|
|
|
|
|
@cache.memoize()
|
|
def get_airports_in_country(sel_country):
|
|
query = db.session.query(Airport.id, Airport.name).filter(Airport.country_code == sel_country).filter(Logbook.takeoff_airport_id == Airport.id).order_by(Airport.name).distinct(Airport.name)
|
|
|
|
return [{"id": airport[0], "name": airport[1]} for airport in query.all()]
|
|
|
|
|
|
@cache.memoize()
|
|
def get_dates_for_airport(sel_airport):
|
|
query = (
|
|
db.session.query(db.func.date(Logbook.reftime), db.func.count(Logbook.id).label("logbook_count"))
|
|
.filter(Airport.id == sel_airport)
|
|
.filter(db.or_(Airport.id == Logbook.takeoff_airport_id, Airport.id == Logbook.landing_airport_id))
|
|
.group_by(db.func.date(Logbook.reftime))
|
|
.order_by(db.func.date(Logbook.reftime).desc())
|
|
)
|
|
|
|
return [{"date": date, "logbook_count": logbook_count} for (date, logbook_count) in query.all()]
|
|
|
|
|
|
@bp.route("/")
|
|
@bp.route("/index.html")
|
|
def index():
|
|
return render_template("base.html")
|
|
|
|
|
|
@bp.route("/devices.html", methods=["GET", "POST"])
|
|
def devices():
|
|
devices = db.session.query(Device).order_by(Device.address)
|
|
return render_template("devices.html", devices=devices)
|
|
|
|
|
|
@bp.route("/device_detail.html", methods=["GET", "POST"])
|
|
def device_detail():
|
|
device_name = request.args.get("device_name")
|
|
device = db.session.query(Device).filter(Device.name == device_name).one()
|
|
|
|
return render_template("device_detail.html", title="Device", device=device)
|
|
|
|
|
|
@bp.route("/receivers.html")
|
|
def receivers():
|
|
sel_country = request.args.get("country")
|
|
|
|
countries = get_countries_in_receivers()
|
|
|
|
# Get receiver selection list
|
|
if sel_country:
|
|
receivers = db.session.query(Receiver).filter(db.and_(Receiver.country_id == Country.gid, Country.iso2 == sel_country)).order_by(Receiver.name)
|
|
else:
|
|
receivers = db.session.query(Receiver).order_by(Receiver.name)
|
|
|
|
return render_template("receivers.html", title="Receivers", sel_country=sel_country, countries=countries, receivers=receivers)
|
|
|
|
|
|
@bp.route("/receiver_detail.html")
|
|
def receiver_detail():
|
|
receiver_name = request.args.get("receiver_name")
|
|
|
|
receiver = db.session.query(Receiver).filter(Receiver.name == receiver_name).one()
|
|
|
|
airport = (
|
|
db.session.query(Airport)
|
|
.filter(
|
|
db.and_(
|
|
Receiver.name == receiver_name,
|
|
db.func.st_contains(db.func.st_buffer(Receiver.location_wkt, 0.5), Airport.location_wkt),
|
|
db.func.st_distance_sphere(Airport.location_wkt, Receiver.location_wkt) < 1000,
|
|
)
|
|
)
|
|
.filter(Airport.style.in_((2, 4, 5)))
|
|
)
|
|
return render_template("receiver_detail.html", title="Receiver Detail", receiver=receiver, airport=airport.first())
|
|
|
|
|
|
@bp.route("/airports.html", methods=["GET", "POST"])
|
|
def airports():
|
|
sel_country = request.args.get("country")
|
|
|
|
countries = get_countries_in_logbook()
|
|
|
|
if sel_country:
|
|
airports = get_airports_in_country(sel_country)
|
|
else:
|
|
airports = []
|
|
|
|
page = request.args.get("page", 1, type=int)
|
|
|
|
return render_template("airports.html", sel_country=sel_country, countries=countries, airports=airports)
|
|
|
|
|
|
@bp.route("/airport_detail.html")
|
|
def airport_detail():
|
|
sel_airport = request.args.get("airport")
|
|
|
|
airport = db.session.query(Airport).filter(Airport.id == sel_airport)
|
|
|
|
devices = db.session.query(Device).join(Logbook).filter(Logbook.takeoff_airport_id == sel_airport).order_by(Device.address)
|
|
|
|
return render_template("airport_detail.html", title="Airport Detail", airport=airport.one(), devices=devices)
|
|
|
|
|
|
@bp.route("/logbook.html", methods=["GET", "POST"])
|
|
def logbook():
|
|
sel_country = request.args.get("country")
|
|
sel_airport = request.args.get("airport")
|
|
sel_date = request.args.get("date")
|
|
|
|
sel_device_id = request.args.get("device_id")
|
|
|
|
countries = get_countries_in_logbook()
|
|
|
|
if sel_country:
|
|
airports = get_airports_in_country(sel_country)
|
|
else:
|
|
airports = []
|
|
|
|
if sel_airport:
|
|
sel_airport = int(sel_airport)
|
|
if sel_airport not in [airport["id"] for airport in airports]:
|
|
sel_airport = None
|
|
sel_date = None
|
|
dates = get_dates_for_airport(sel_airport)
|
|
else:
|
|
dates = []
|
|
|
|
if sel_date:
|
|
sel_date = datetime.datetime.strptime(sel_date, "%Y-%m-%d").date()
|
|
if sel_date not in [entry["date"] for entry in dates]:
|
|
sel_date = dates[0]["date"]
|
|
elif len(dates) > 0:
|
|
sel_date = dates[0]["date"]
|
|
|
|
# Get Logbook
|
|
filters = []
|
|
if sel_airport:
|
|
filters.append(db.or_(Logbook.takeoff_airport_id == sel_airport, Logbook.landing_airport_id == sel_airport))
|
|
|
|
if sel_date:
|
|
filters.append(db.func.date(Logbook.reftime) == sel_date)
|
|
|
|
if sel_device_id:
|
|
filters.append(Logbook.device_id == sel_device_id)
|
|
|
|
if len(filters) > 0:
|
|
logbook = db.session.query(Logbook).filter(*filters).order_by(Logbook.reftime)
|
|
else:
|
|
logbook = None
|
|
|
|
return render_template("logbook.html", title="Logbook", sel_country=sel_country, countries=countries, sel_airport=sel_airport, airports=airports, sel_date=sel_date, dates=dates, logbook=logbook)
|
|
|
|
|
|
@bp.route("/download.html")
|
|
def download_flight():
|
|
from io import StringIO
|
|
|
|
buffer = StringIO()
|
|
buffer.write("Moin moin\nAlter Verwalter")
|
|
buffer.seek(0)
|
|
|
|
return send_file(buffer, as_attachment=True, attachment_filename="wtf.igc", mimetype="text/plain")
|