ogn-python/app/model/logbook.py

35 wiersze
1.5 KiB
Python
Czysty Zwykły widok Historia

2017-10-03 11:31:24 +00:00
from sqlalchemy.ext.hybrid import hybrid_property
2016-06-29 21:26:30 +00:00
2019-08-31 08:14:41 +00:00
from app import db
2016-06-29 21:26:30 +00:00
2019-02-10 12:10:19 +00:00
class Logbook(db.Model):
2019-08-31 08:14:41 +00:00
__tablename__ = "logbook"
2016-06-29 21:26:30 +00:00
2019-02-10 12:25:24 +00:00
id = db.Column(db.Integer, primary_key=True)
2016-06-29 21:26:30 +00:00
2019-02-10 12:25:24 +00:00
reftime = db.Column(db.DateTime, index=True)
takeoff_timestamp = db.Column(db.DateTime)
takeoff_track = db.Column(db.SmallInteger)
landing_timestamp = db.Column(db.DateTime)
landing_track = db.Column(db.SmallInteger)
max_altitude = db.Column(db.Float(precision=2))
2016-06-29 21:26:30 +00:00
# Relations
2019-08-31 08:14:41 +00:00
takeoff_airport_id = db.Column(db.Integer, db.ForeignKey("airports.id", ondelete="CASCADE"), index=True)
takeoff_airport = db.relationship("Airport", foreign_keys=[takeoff_airport_id])
2016-06-29 21:26:30 +00:00
2019-08-31 08:14:41 +00:00
landing_airport_id = db.Column(db.Integer, db.ForeignKey("airports.id", ondelete="CASCADE"), index=True)
landing_airport = db.relationship("Airport", foreign_keys=[landing_airport_id])
2016-06-29 21:26:30 +00:00
2019-08-31 08:14:41 +00:00
device_id = db.Column(db.Integer, db.ForeignKey("devices.id", ondelete="CASCADE"), index=True)
device = db.relationship("Device", foreign_keys=[device_id], backref=db.backref("logbook", order_by="Logbook.reftime"))
@hybrid_property
def duration(self):
return None if (self.landing_timestamp is None or self.takeoff_timestamp is None) else self.landing_timestamp - self.takeoff_timestamp
@duration.expression
def duration(cls):
return case({False: None, True: cls.landing_timestamp - cls.takeoff_timestamp}, cls.landing_timestamp != null() and cls.takeoff_timestamp != null())