gallery.accords-library.com/server/szurubooru/db/post.py

162 lines
5.8 KiB
Python
Raw Normal View History

2016-04-22 16:36:12 +00:00
from sqlalchemy import Column, Integer, DateTime, String, Text, PickleType, ForeignKey
2016-04-22 18:58:04 +00:00
from sqlalchemy.orm import relationship, column_property, object_session
2016-04-17 10:55:07 +00:00
from sqlalchemy.sql.expression import func, select
from szurubooru.db.base import Base
2016-04-22 16:36:12 +00:00
class PostFeature(Base):
__tablename__ = 'post_feature'
post_feature_id = Column('id', Integer, primary_key=True)
post_id = Column('post_id', Integer, ForeignKey('post.id'), nullable=False)
user_id = Column('user_id', Integer, ForeignKey('user.id'), nullable=False)
time = Column('time', DateTime, nullable=False)
post = relationship('Post')
user = relationship('User')
class PostScore(Base):
__tablename__ = 'post_score'
post_id = Column('post_id', Integer, ForeignKey('post.id'), primary_key=True)
user_id = Column('user_id', Integer, ForeignKey('user.id'), primary_key=True)
time = Column('time', DateTime, nullable=False)
score = Column('score', Integer, nullable=False)
post = relationship('Post')
user = relationship('User')
class PostFavorite(Base):
__tablename__ = 'post_favorite'
post_id = Column('post_id', Integer, ForeignKey('post.id'), primary_key=True)
user_id = Column('user_id', Integer, ForeignKey('user.id'), primary_key=True)
time = Column('time', DateTime, nullable=False)
post = relationship('Post')
user = relationship('User')
class PostNote(Base):
__tablename__ = 'post_note'
post_note_id = Column('id', Integer, primary_key=True)
post_id = Column('post_id', Integer, ForeignKey('post.id'), nullable=False)
polygon = Column('polygon', PickleType, nullable=False)
text = Column('text', Text, nullable=False)
post = relationship('Post')
2016-04-17 10:55:07 +00:00
class PostRelation(Base):
__tablename__ = 'post_relation'
parent_id = Column('parent_id', Integer, ForeignKey('post.id'), primary_key=True)
child_id = Column('child_id', Integer, ForeignKey('post.id'), primary_key=True)
def __init__(self, parent_id, child_id):
self.parent_id = parent_id
self.child_id = child_id
class PostTag(Base):
__tablename__ = 'post_tag'
post_id = Column('post_id', Integer, ForeignKey('post.id'), primary_key=True)
tag_id = Column('tag_id', Integer, ForeignKey('tag.id'), primary_key=True)
def __init__(self, tag_id, post_id):
self.tag_id = tag_id
self.post_id = post_id
class Post(Base):
__tablename__ = 'post'
SAFETY_SAFE = 'safe'
SAFETY_SKETCHY = 'sketchy'
SAFETY_UNSAFE = 'unsafe'
2016-04-30 21:17:08 +00:00
TYPE_IMAGE = 'image'
TYPE_ANIMATION = 'animation'
2016-04-17 10:55:07 +00:00
TYPE_VIDEO = 'video'
2016-04-30 21:17:08 +00:00
TYPE_FLASH = 'flash'
2016-04-17 10:55:07 +00:00
2016-04-30 21:17:08 +00:00
# basic meta
2016-04-17 10:55:07 +00:00
post_id = Column('id', Integer, primary_key=True)
user_id = Column('user_id', Integer, ForeignKey('user.id'))
creation_time = Column('creation_time', DateTime, nullable=False)
last_edit_time = Column('last_edit_time', DateTime)
safety = Column('safety', String(32), nullable=False)
2016-04-30 21:17:08 +00:00
source = Column('source', String(200))
flags = Column('flags', PickleType, default=None)
# content description
2016-04-17 10:55:07 +00:00
type = Column('type', String(32), nullable=False)
checksum = Column('checksum', String(64), nullable=False)
file_size = Column('file_size', Integer)
2016-04-22 18:58:04 +00:00
canvas_width = Column('image_width', Integer)
canvas_height = Column('image_height', Integer)
2016-04-30 21:17:08 +00:00
mime_type = Column('mime-type', String(32), nullable=False)
2016-04-17 10:55:07 +00:00
2016-04-30 21:17:08 +00:00
# foreign tables
2016-04-17 10:55:07 +00:00
user = relationship('User')
tags = relationship('Tag', backref='posts', secondary='post_tag')
relations = relationship(
'Post',
secondary='post_relation',
primaryjoin=post_id == PostRelation.parent_id,
secondaryjoin=post_id == PostRelation.child_id)
2016-04-22 16:36:12 +00:00
features = relationship(
'PostFeature', cascade='all, delete-orphan', lazy='joined')
scores = relationship(
'PostScore', cascade='all, delete-orphan', lazy='joined')
2016-04-22 18:58:04 +00:00
favorited_by = relationship(
2016-04-22 16:36:12 +00:00
'PostFavorite', cascade='all, delete-orphan', lazy='joined')
notes = relationship(
'PostNote', cascade='all, delete-orphan', lazy='joined')
2016-04-25 08:48:15 +00:00
comments = relationship('Comment')
2016-04-30 21:17:08 +00:00
# dynamic columns
2016-04-17 10:55:07 +00:00
tag_count = column_property(
2016-04-20 13:09:36 +00:00
select([func.count(PostTag.tag_id)]) \
.where(PostTag.post_id == post_id) \
2016-04-20 13:09:36 +00:00
.correlate_except(PostTag))
2016-04-17 10:55:07 +00:00
2016-04-22 18:58:04 +00:00
@property
def is_featured(self):
featured_post = object_session(self) \
.query(PostFeature) \
.order_by(PostFeature.time.desc()) \
.first()
return featured_post and featured_post.post_id == self.post_id
2016-04-24 14:34:06 +00:00
@property
def score(self):
return object_session(self) \
.query(func.sum(PostScore.score)) \
.filter(PostScore.post_id == self.post_id) \
.one()[0] or 0
2016-04-28 17:04:44 +00:00
favorite_count = column_property(
select([func.count(PostFavorite.post_id)]) \
.where(PostFavorite.post_id == post_id) \
.correlate_except(PostFavorite))
last_favorite_time = column_property(
select([func.max(PostFavorite.time)]) \
.where(PostFavorite.post_id == post_id) \
.correlate_except(PostFavorite))
2016-04-24 14:34:06 +00:00
feature_count = column_property(
select([func.count(PostFeature.post_id)]) \
.where(PostFeature.post_id == post_id) \
.correlate_except(PostFeature))
last_feature_time = column_property(
select([func.max(PostFeature.time)]) \
.where(PostFeature.post_id == post_id) \
.correlate_except(PostFeature))
2016-04-17 10:55:07 +00:00
# TODO: wire these
2016-04-24 14:34:06 +00:00
#comment_count = Column('auto_comment_count', Integer, nullable=False, default=0)
#note_count = Column('auto_note_count', Integer, nullable=False, default=0)
#last_comment_edit_time = Column(
# 'auto_comment_creation_time', Integer, nullable=False, default=0)
#last_comment_creation_time = Column(
# 'auto_comment_edit_time', Integer, nullable=False, default=0)