1
Fork 0
mirror of https://github.com/pds-nest/nest.git synced 2024-11-23 21:44:19 +00:00
pds-2021-g2-nest/nest_backend/database/tables/Tweet.py
2021-05-30 17:47:11 +02:00

25 lines
1.1 KiB
Python

"""
This module defines the Tweet database class.
"""
from ..base import ext
class Tweet(ext.Model):
__tablename__ = "tweet"
snowflake = ext.Column(ext.String, primary_key=True)
content = ext.Column(ext.String)
location = ext.Column(ext.String)
place = ext.Column(ext.String)
poster = ext.Column(ext.String)
insert_time = ext.Column(ext.DateTime, nullable=False)
post_time = ext.Column(ext.DateTime, nullable=True)
image_url = ext.Column(ext.String, nullable=True)
# Relationships
repositories = ext.relationship("Composed", back_populates="tweet", cascade="all, delete")
conditions = ext.relationship("Contains", back_populates="tweet", cascade="all, delete")
def to_json(self):
return {"snowflake": self.snowflake, "content": self.content, "location": self.location, "poster": self.poster,
"place": self.place, "insert_time": self.insert_time.isoformat(), "post_time": self.post_time.isoformat(),
"image_url": self.image_url, "conditions": [c.condition.to_json() for c in self.conditions]}