You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

api_based_extension.py 1.0KB

123456789101112131415161718192021222324252627282930
  1. import enum
  2. from sqlalchemy import func
  3. from sqlalchemy.orm import mapped_column
  4. from .base import Base
  5. from .engine import db
  6. from .types import StringUUID
  7. class APIBasedExtensionPoint(enum.Enum):
  8. APP_EXTERNAL_DATA_TOOL_QUERY = "app.external_data_tool.query"
  9. PING = "ping"
  10. APP_MODERATION_INPUT = "app.moderation.input"
  11. APP_MODERATION_OUTPUT = "app.moderation.output"
  12. class APIBasedExtension(Base):
  13. __tablename__ = "api_based_extensions"
  14. __table_args__ = (
  15. db.PrimaryKeyConstraint("id", name="api_based_extension_pkey"),
  16. db.Index("api_based_extension_tenant_idx", "tenant_id"),
  17. )
  18. id = mapped_column(StringUUID, server_default=db.text("uuid_generate_v4()"))
  19. tenant_id = mapped_column(StringUUID, nullable=False)
  20. name = mapped_column(db.String(255), nullable=False)
  21. api_endpoint = mapped_column(db.String(255), nullable=False)
  22. api_key = mapped_column(db.Text, nullable=False)
  23. created_at = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())