2023-11-06 19:36:16 +08:00
|
|
|
import enum
|
|
|
|
|
2024-12-21 23:13:58 +08:00
|
|
|
from sqlalchemy import func
|
2025-07-23 01:39:59 +09:00
|
|
|
from sqlalchemy.orm import mapped_column
|
2024-12-21 23:13:58 +08:00
|
|
|
|
2025-05-09 13:52:05 +08:00
|
|
|
from .base import Base
|
2024-12-20 14:12:29 +08:00
|
|
|
from .engine import db
|
2024-08-13 14:44:10 +08:00
|
|
|
from .types import StringUUID
|
2024-02-06 13:21:13 +08:00
|
|
|
|
2023-11-06 19:36:16 +08:00
|
|
|
|
|
|
|
class APIBasedExtensionPoint(enum.Enum):
|
2024-09-10 17:08:06 +08:00
|
|
|
APP_EXTERNAL_DATA_TOOL_QUERY = "app.external_data_tool.query"
|
|
|
|
PING = "ping"
|
|
|
|
APP_MODERATION_INPUT = "app.moderation.input"
|
|
|
|
APP_MODERATION_OUTPUT = "app.moderation.output"
|
2023-11-06 19:36:16 +08:00
|
|
|
|
|
|
|
|
2025-05-09 13:52:05 +08:00
|
|
|
class APIBasedExtension(Base):
|
2024-09-10 17:08:06 +08:00
|
|
|
__tablename__ = "api_based_extensions"
|
2023-11-06 19:36:16 +08:00
|
|
|
__table_args__ = (
|
2024-09-10 17:08:06 +08:00
|
|
|
db.PrimaryKeyConstraint("id", name="api_based_extension_pkey"),
|
|
|
|
db.Index("api_based_extension_tenant_idx", "tenant_id"),
|
2023-11-06 19:36:16 +08:00
|
|
|
)
|
|
|
|
|
2025-07-23 01:39:59 +09:00
|
|
|
id = mapped_column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
tenant_id = mapped_column(StringUUID, nullable=False)
|
|
|
|
name = mapped_column(db.String(255), nullable=False)
|
|
|
|
api_endpoint = mapped_column(db.String(255), nullable=False)
|
|
|
|
api_key = mapped_column(db.Text, nullable=False)
|
|
|
|
created_at = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|