skill_installation.py 1003 B

1234567891011121314151617181920
  1. from datetime import datetime
  2. from core_db import AuditMixin, Base, EntityMixin, VersionMixin
  3. from core_shared import JSONValue
  4. from sqlalchemy import DateTime, String
  5. from sqlalchemy.dialects.sqlite import JSON
  6. from sqlalchemy.orm import Mapped, mapped_column
  7. class SkillInstallation(EntityMixin, AuditMixin, VersionMixin, Base):
  8. __tablename__ = "skill_installation"
  9. skill_id: Mapped[str] = mapped_column(String(36), index=True)
  10. skill_version_id: Mapped[str] = mapped_column(String(36), index=True)
  11. install_scope: Mapped[str] = mapped_column(String(32), default="global", index=True)
  12. scope_id: Mapped[str] = mapped_column(String(64), index=True)
  13. status: Mapped[str] = mapped_column(String(32), default="installed", index=True)
  14. config_json: Mapped[dict[str, JSONValue]] = mapped_column(JSON, default=dict)
  15. installed_by: Mapped[str | None] = mapped_column(String(36), nullable=True)
  16. installed_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)