20 lines
857 B
Python
20 lines
857 B
Python
from sqlalchemy import String, Text, Boolean, Index
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
|
from app.models.base import Base, UUIDMixin, TimestampMixin
|
|
|
|
|
|
class Page(Base, UUIDMixin, TimestampMixin):
|
|
__tablename__ = "pages"
|
|
|
|
title: Mapped[str] = mapped_column(String(255), nullable=False)
|
|
slug: Mapped[str] = mapped_column(String(255), nullable=False, unique=True)
|
|
body: Mapped[str] = mapped_column(Text, nullable=False, default="")
|
|
meta_title: Mapped[str | None] = mapped_column(String(255), nullable=True)
|
|
meta_description: Mapped[str | None] = mapped_column(String(500), nullable=True)
|
|
og_image_url: Mapped[str | None] = mapped_column(String(2048), nullable=True)
|
|
published: Mapped[bool] = mapped_column(Boolean, default=False, nullable=False)
|
|
|
|
__table_args__ = (
|
|
Index("ix_pages_slug", "slug"),
|
|
)
|