|
|
|
|
@ -1,6 +1,9 @@
|
|
|
|
|
from datetime import datetime
|
|
|
|
|
from enum import Enum
|
|
|
|
|
from typing import Optional
|
|
|
|
|
|
|
|
|
|
from sqlalchemy import func
|
|
|
|
|
from sqlalchemy import func, text
|
|
|
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
|
|
|
|
|
|
|
|
|
from .base import Base
|
|
|
|
|
from .engine import db
|
|
|
|
|
@ -51,20 +54,24 @@ class Provider(Base):
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
provider_type = db.Column(db.String(40), nullable=False, server_default=db.text("'custom'::character varying"))
|
|
|
|
|
encrypted_config = db.Column(db.Text, nullable=True)
|
|
|
|
|
is_valid = db.Column(db.Boolean, nullable=False, server_default=db.text("false"))
|
|
|
|
|
last_used = db.Column(db.DateTime, nullable=True)
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
provider_type: Mapped[str] = mapped_column(
|
|
|
|
|
db.String(40), nullable=False, server_default=text("'custom'::character varying")
|
|
|
|
|
)
|
|
|
|
|
encrypted_config: Mapped[Optional[str]] = mapped_column(db.Text, nullable=True)
|
|
|
|
|
is_valid: Mapped[bool] = mapped_column(db.Boolean, nullable=False, server_default=text("false"))
|
|
|
|
|
last_used: Mapped[Optional[datetime]] = mapped_column(db.DateTime, nullable=True)
|
|
|
|
|
|
|
|
|
|
quota_type = db.Column(db.String(40), nullable=True, server_default=db.text("''::character varying"))
|
|
|
|
|
quota_limit = db.Column(db.BigInteger, nullable=True)
|
|
|
|
|
quota_used = db.Column(db.BigInteger, default=0)
|
|
|
|
|
quota_type: Mapped[Optional[str]] = mapped_column(
|
|
|
|
|
db.String(40), nullable=True, server_default=text("''::character varying")
|
|
|
|
|
)
|
|
|
|
|
quota_limit: Mapped[Optional[int]] = mapped_column(db.BigInteger, nullable=True)
|
|
|
|
|
quota_used: Mapped[Optional[int]] = mapped_column(db.BigInteger, default=0)
|
|
|
|
|
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
|
return (
|
|
|
|
|
@ -104,15 +111,15 @@ class ProviderModel(Base):
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_type = db.Column(db.String(40), nullable=False)
|
|
|
|
|
encrypted_config = db.Column(db.Text, nullable=True)
|
|
|
|
|
is_valid = db.Column(db.Boolean, nullable=False, server_default=db.text("false"))
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_type: Mapped[str] = mapped_column(db.String(40), nullable=False)
|
|
|
|
|
encrypted_config: Mapped[Optional[str]] = mapped_column(db.Text, nullable=True)
|
|
|
|
|
is_valid: Mapped[bool] = mapped_column(db.Boolean, nullable=False, server_default=text("false"))
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class TenantDefaultModel(Base):
|
|
|
|
|
@ -122,13 +129,13 @@ class TenantDefaultModel(Base):
|
|
|
|
|
db.Index("tenant_default_model_tenant_id_provider_type_idx", "tenant_id", "provider_name", "model_type"),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_type = db.Column(db.String(40), nullable=False)
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_type: Mapped[str] = mapped_column(db.String(40), nullable=False)
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class TenantPreferredModelProvider(Base):
|
|
|
|
|
@ -138,12 +145,12 @@ class TenantPreferredModelProvider(Base):
|
|
|
|
|
db.Index("tenant_preferred_model_provider_tenant_provider_idx", "tenant_id", "provider_name"),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
preferred_provider_type = db.Column(db.String(40), nullable=False)
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
preferred_provider_type: Mapped[str] = mapped_column(db.String(40), nullable=False)
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ProviderOrder(Base):
|
|
|
|
|
@ -153,22 +160,24 @@ class ProviderOrder(Base):
|
|
|
|
|
db.Index("provider_order_tenant_provider_idx", "tenant_id", "provider_name"),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
account_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
payment_product_id = db.Column(db.String(191), nullable=False)
|
|
|
|
|
payment_id = db.Column(db.String(191))
|
|
|
|
|
transaction_id = db.Column(db.String(191))
|
|
|
|
|
quantity = db.Column(db.Integer, nullable=False, server_default=db.text("1"))
|
|
|
|
|
currency = db.Column(db.String(40))
|
|
|
|
|
total_amount = db.Column(db.Integer)
|
|
|
|
|
payment_status = db.Column(db.String(40), nullable=False, server_default=db.text("'wait_pay'::character varying"))
|
|
|
|
|
paid_at = db.Column(db.DateTime)
|
|
|
|
|
pay_failed_at = db.Column(db.DateTime)
|
|
|
|
|
refunded_at = db.Column(db.DateTime)
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
account_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
payment_product_id: Mapped[str] = mapped_column(db.String(191), nullable=False)
|
|
|
|
|
payment_id: Mapped[Optional[str]] = mapped_column(db.String(191))
|
|
|
|
|
transaction_id: Mapped[Optional[str]] = mapped_column(db.String(191))
|
|
|
|
|
quantity: Mapped[int] = mapped_column(db.Integer, nullable=False, server_default=text("1"))
|
|
|
|
|
currency: Mapped[Optional[str]] = mapped_column(db.String(40))
|
|
|
|
|
total_amount: Mapped[Optional[int]] = mapped_column(db.Integer)
|
|
|
|
|
payment_status: Mapped[str] = mapped_column(
|
|
|
|
|
db.String(40), nullable=False, server_default=text("'wait_pay'::character varying")
|
|
|
|
|
)
|
|
|
|
|
paid_at: Mapped[Optional[datetime]] = mapped_column(db.DateTime)
|
|
|
|
|
pay_failed_at: Mapped[Optional[datetime]] = mapped_column(db.DateTime)
|
|
|
|
|
refunded_at: Mapped[Optional[datetime]] = mapped_column(db.DateTime)
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ProviderModelSetting(Base):
|
|
|
|
|
@ -182,15 +191,15 @@ class ProviderModelSetting(Base):
|
|
|
|
|
db.Index("provider_model_setting_tenant_provider_model_idx", "tenant_id", "provider_name", "model_type"),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_type = db.Column(db.String(40), nullable=False)
|
|
|
|
|
enabled = db.Column(db.Boolean, nullable=False, server_default=db.text("true"))
|
|
|
|
|
load_balancing_enabled = db.Column(db.Boolean, nullable=False, server_default=db.text("false"))
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_type: Mapped[str] = mapped_column(db.String(40), nullable=False)
|
|
|
|
|
enabled: Mapped[bool] = mapped_column(db.Boolean, nullable=False, server_default=text("true"))
|
|
|
|
|
load_balancing_enabled: Mapped[bool] = mapped_column(db.Boolean, nullable=False, server_default=text("false"))
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class LoadBalancingModelConfig(Base):
|
|
|
|
|
@ -204,13 +213,13 @@ class LoadBalancingModelConfig(Base):
|
|
|
|
|
db.Index("load_balancing_model_config_tenant_provider_model_idx", "tenant_id", "provider_name", "model_type"),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
id = db.Column(StringUUID, server_default=db.text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id = db.Column(StringUUID, nullable=False)
|
|
|
|
|
provider_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
model_type = db.Column(db.String(40), nullable=False)
|
|
|
|
|
name = db.Column(db.String(255), nullable=False)
|
|
|
|
|
encrypted_config = db.Column(db.Text, nullable=True)
|
|
|
|
|
enabled = db.Column(db.Boolean, nullable=False, server_default=db.text("true"))
|
|
|
|
|
created_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at = db.Column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
id: Mapped[str] = mapped_column(StringUUID, server_default=text("uuid_generate_v4()"))
|
|
|
|
|
tenant_id: Mapped[str] = mapped_column(StringUUID, nullable=False)
|
|
|
|
|
provider_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
model_type: Mapped[str] = mapped_column(db.String(40), nullable=False)
|
|
|
|
|
name: Mapped[str] = mapped_column(db.String(255), nullable=False)
|
|
|
|
|
encrypted_config: Mapped[Optional[str]] = mapped_column(db.Text, nullable=True)
|
|
|
|
|
enabled: Mapped[bool] = mapped_column(db.Boolean, nullable=False, server_default=text("true"))
|
|
|
|
|
created_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
updated_at: Mapped[datetime] = mapped_column(db.DateTime, nullable=False, server_default=func.current_timestamp())
|
|
|
|
|
|