2023-11-06 19:36:16 +08:00
|
|
|
import enum
|
|
|
|
|
2024-01-12 12:34:01 +08:00
|
|
|
from sqlalchemy.dialects.postgresql import UUID
|
2023-11-06 19:36:16 +08:00
|
|
|
|
2024-02-06 13:21:13 +08:00
|
|
|
from extensions.ext_database import db
|
|
|
|
|
2023-11-06 19:36:16 +08:00
|
|
|
|
|
|
|
class APIBasedExtensionPoint(enum.Enum):
|
|
|
|
APP_EXTERNAL_DATA_TOOL_QUERY = 'app.external_data_tool.query'
|
|
|
|
PING = 'ping'
|
|
|
|
APP_MODERATION_INPUT = 'app.moderation.input'
|
|
|
|
APP_MODERATION_OUTPUT = 'app.moderation.output'
|
|
|
|
|
|
|
|
|
|
|
|
class APIBasedExtension(db.Model):
|
|
|
|
__tablename__ = 'api_based_extensions'
|
|
|
|
__table_args__ = (
|
|
|
|
db.PrimaryKeyConstraint('id', name='api_based_extension_pkey'),
|
|
|
|
db.Index('api_based_extension_tenant_idx', 'tenant_id'),
|
|
|
|
)
|
|
|
|
|
|
|
|
id = db.Column(UUID, server_default=db.text('uuid_generate_v4()'))
|
|
|
|
tenant_id = db.Column(UUID, nullable=False)
|
|
|
|
name = db.Column(db.String(255), nullable=False)
|
|
|
|
api_endpoint = db.Column(db.String(255), nullable=False)
|
|
|
|
api_key = db.Column(db.Text, nullable=False)
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=db.text('CURRENT_TIMESTAMP(0)'))
|