api_based_extension.py 992 B

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