MarseyWorld/files/classes/flags.py

44 lines
1.3 KiB
Python

from sqlalchemy import *
from sqlalchemy.orm import relationship
from files.__main__ import Base
from files.helpers.lazy import lazy
from files.helpers.const import *
from files.helpers.regex import *
import time
class Flag(Base):
__tablename__ = "flags"
post_id = Column(Integer, ForeignKey("submissions.id"), primary_key=True)
user_id = Column(Integer, ForeignKey("users.id"), primary_key=True)
reason = Column(String)
created_utc = Column(Integer, default=int(time.time()))
user = relationship("User", primaryjoin = "Flag.user_id == User.id", uselist = False)
def __repr__(self):
return f"<Flag(user_id={self.user_id}, post_id={self.post_id})>"
@lazy
def realreason(self, v):
return censor_slurs(self.reason, v)
class CommentFlag(Base):
__tablename__ = "commentflags"
comment_id = Column(Integer, ForeignKey("comments.id"), primary_key=True)
user_id = Column(Integer, ForeignKey("users.id"), primary_key=True)
reason = Column(String)
created_utc = Column(Integer, default=int(time.time()))
user = relationship("User", primaryjoin = "CommentFlag.user_id == User.id", uselist = False)
def __repr__(self):
return f"<CommentFlag(user_id={self.user_id}, comment_id={self.comment_id})>"
@lazy
def realreason(self, v):
return censor_slurs(self.reason, v)