team_definition.py 856 B

123456789101112131415161718
  1. from sqlalchemy import String, Text
  2. from sqlalchemy.dialects.sqlite import JSON
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from core_db import AuditMixin, Base, TenantMixin, VersionMixin
  5. from core_shared import JSONValue
  6. class TeamDefinition(TenantMixin, AuditMixin, VersionMixin, Base):
  7. __tablename__ = "team_definition"
  8. code: Mapped[str] = mapped_column(String(64), index=True)
  9. name: Mapped[str] = mapped_column(String(128))
  10. description: Mapped[str | None] = mapped_column(Text, nullable=True)
  11. team_type: Mapped[str] = mapped_column(String(32), default="collaborative")
  12. status: Mapped[str] = mapped_column(String(32), default="draft", index=True)
  13. owner_user_id: Mapped[str | None] = mapped_column(String(36), nullable=True)
  14. metadata_json: Mapped[dict[str, JSONValue] | None] = mapped_column(JSON, nullable=True)