rDrama/files/classes/views.py
2023-09-11 02:25:45 -05:00

38 lines
1 KiB
Python

import time
from sqlalchemy import *
from sqlalchemy.orm import relationship
from sqlalchemy.sql.functions import now
from files.classes.base import Base
from files.helpers.lazy import lazy
from files.helpers.time import format_age
class ViewerRelationship(Base):
__tablename__ = "viewers"
user_id = Column(Integer, ForeignKey('users.id'), primary_key=True)
viewer_id = Column(Integer, ForeignKey('users.id'), primary_key=True)
last_view_datetimez = Column(DateTime(timezone=True), nullable=False, server_default=now())
Index('fki_view_viewer_fkey', viewer_id)
viewer = relationship("User", primaryjoin="ViewerRelationship.viewer_id == User.id", viewonly=True)
@property
def last_view_utc(self):
"""
the last view timestamp in UTC seconds. Milliseconds are truncated/rounded down.
"""
return int(self.last_view_datetimez.timestamp())
@property
@lazy
def last_view_since(self):
return int(time.time()) - self.last_view_utc
@property
@lazy
def last_view_string(self):
return format_age(self.last_view_utc)