open-law/app/models/book_version.py

126 lines
4.2 KiB
Python
Raw Normal View History

2023-04-21 16:13:43 +03:00
from datetime import datetime
2023-06-20 11:10:27 +03:00
from sqlalchemy import and_
from app import db, models as m
2023-04-21 15:58:47 +03:00
from app.models.utils import BaseModel
class BookVersion(BaseModel):
__tablename__ = "book_versions"
# need to redeclare id to use it in the derivative relationship
id = db.Column(db.Integer, primary_key=True)
2023-04-27 16:17:25 +03:00
semver = db.Column(db.String(16), unique=False, nullable=False)
2023-06-12 15:18:21 +03:00
is_active = db.Column(db.Boolean, default=False)
2023-04-21 16:13:43 +03:00
updated_at = db.Column(db.DateTime, default=datetime.now)
2023-04-21 15:58:47 +03:00
# Foreign keys
derivative_id = db.Column(db.Integer, db.ForeignKey("book_versions.id"))
book_id = db.Column(db.Integer, db.ForeignKey("books.id"))
2023-06-14 14:10:29 +03:00
user_id = db.Column(db.ForeignKey("users.id"))
2023-06-20 15:13:08 +03:00
updated_by = db.Column(db.ForeignKey("users.id"))
2023-04-21 15:58:47 +03:00
# Relationships
2023-06-20 15:13:08 +03:00
user = db.relationship("User", viewonly=True, foreign_keys=[user_id])
updated_by_user = db.relationship("User", viewonly=True, foreign_keys=[updated_by])
2023-04-21 15:58:47 +03:00
book = db.relationship("Book", viewonly=True)
derivative = db.relationship("BookVersion", remote_side=[id])
2023-05-18 16:07:59 +03:00
sections = db.relationship("Section", viewonly=True, order_by="desc(Section.id)")
collections = db.relationship(
"Collection", viewonly=True, order_by="desc(Collection.id)"
)
2023-04-21 15:58:47 +03:00
def __repr__(self):
return f"<{self.id}: {self.semver}>"
@property
def root_collection(self):
for collection in self.collections:
if collection.is_root:
return collection
@property
def children_collections(self):
2023-05-26 12:33:47 +03:00
return [
collection
for collection in self.root_collection.children
if not collection.is_deleted
]
2023-06-20 11:10:27 +03:00
@property
def approved_comments(self):
comments = (
db.session.query(
m.Comment,
)
.filter(
and_(
m.BookVersion.id == self.id,
m.Section.version_id == m.BookVersion.id,
m.Collection.id == m.Section.collection_id,
m.Interpretation.section_id == m.Section.id,
m.Comment.interpretation_id == m.Interpretation.id,
m.Comment.approved.is_(True),
m.Comment.is_deleted.is_(False),
m.BookVersion.is_deleted.is_(False),
m.Interpretation.is_deleted.is_(False),
m.Section.is_deleted.is_(False),
m.Collection.is_deleted.is_(False),
),
)
.order_by(m.Comment.created_at.desc())
.all()
)
return comments
@property
def approved_interpretations(self):
interpretations = (
db.session.query(
m.Interpretation,
)
.filter(
and_(
m.BookVersion.id == self.id,
m.Section.version_id == m.BookVersion.id,
m.Collection.id == m.Section.collection_id,
m.Interpretation.section_id == m.Section.id,
m.Interpretation.approved.is_(True),
m.BookVersion.is_deleted.is_(False),
m.Interpretation.is_deleted.is_(False),
m.Section.is_deleted.is_(False),
m.Collection.is_deleted.is_(False),
),
)
.order_by(m.Interpretation.created_at.desc())
.all()
)
return interpretations
@property
def interpretations(self):
interpretations = (
db.session.query(
m.Interpretation,
)
.filter(
and_(
m.BookVersion.id == self.id,
m.Section.version_id == m.BookVersion.id,
m.Collection.id == m.Section.collection_id,
m.Interpretation.section_id == m.Section.id,
m.BookVersion.is_deleted.is_(False),
m.Interpretation.is_deleted.is_(False),
m.Section.is_deleted.is_(False),
m.Collection.is_deleted.is_(False),
),
)
.order_by(m.Interpretation.created_at.desc())
.all()
)
return interpretations