mirror of
https://github.com/langgenius/dify.git
synced 2026-05-01 16:08:04 +08:00
* phase1:uuid stringdefault timestamp date * phase2:json adapt * phase3:BinaryData,ARRAY,Text, * fix sa.String() * fix defalut valud * models adapt * models adapt supplement * fix pg unique dialect * supplement * migration fix * migration fix * date sql adapt * model adapt fix * config adapt * migration fix * fix * fix anotation in .env.example * config feat * config fix * .env.example adapt fix
83 lines
4.2 KiB
Python
83 lines
4.2 KiB
Python
"""add tool_invoke_model_log
|
|
|
|
Revision ID: c71211c8f604
|
|
Revises: f25003750af4
|
|
Create Date: 2024-01-09 11:42:50.664797
|
|
|
|
"""
|
|
import sqlalchemy as sa
|
|
from alembic import op
|
|
from uuid import uuid4
|
|
from sqlalchemy.dialects import postgresql
|
|
|
|
import models.types
|
|
|
|
|
|
def _is_pg(conn):
|
|
return conn.dialect.name == "postgresql"
|
|
|
|
# revision identifiers, used by Alembic.
|
|
revision = 'c71211c8f604'
|
|
down_revision = 'f25003750af4'
|
|
branch_labels = None
|
|
depends_on = None
|
|
|
|
|
|
def upgrade():
|
|
# ### commands auto generated by Alembic - please adjust! ###
|
|
conn = op.get_bind()
|
|
|
|
if _is_pg(conn):
|
|
op.create_table('tool_model_invokes',
|
|
sa.Column('id', postgresql.UUID(), server_default=sa.text('uuid_generate_v4()'), nullable=False),
|
|
sa.Column('user_id', postgresql.UUID(), nullable=False),
|
|
sa.Column('tenant_id', postgresql.UUID(), nullable=False),
|
|
sa.Column('provider', sa.String(length=40), nullable=False),
|
|
sa.Column('tool_type', sa.String(length=40), nullable=False),
|
|
sa.Column('tool_name', sa.String(length=40), nullable=False),
|
|
sa.Column('tool_id', postgresql.UUID(), nullable=False),
|
|
sa.Column('model_parameters', sa.Text(), nullable=False),
|
|
sa.Column('prompt_messages', sa.Text(), nullable=False),
|
|
sa.Column('model_response', sa.Text(), nullable=False),
|
|
sa.Column('prompt_tokens', sa.Integer(), server_default=sa.text('0'), nullable=False),
|
|
sa.Column('answer_tokens', sa.Integer(), server_default=sa.text('0'), nullable=False),
|
|
sa.Column('answer_unit_price', sa.Numeric(precision=10, scale=4), nullable=False),
|
|
sa.Column('answer_price_unit', sa.Numeric(precision=10, scale=7), server_default=sa.text('0.001'), nullable=False),
|
|
sa.Column('provider_response_latency', sa.Float(), server_default=sa.text('0'), nullable=False),
|
|
sa.Column('total_price', sa.Numeric(precision=10, scale=7), nullable=True),
|
|
sa.Column('currency', sa.String(length=255), nullable=False),
|
|
sa.Column('created_at', sa.DateTime(), server_default=sa.text('CURRENT_TIMESTAMP(0)'), nullable=False),
|
|
sa.Column('updated_at', sa.DateTime(), server_default=sa.text('CURRENT_TIMESTAMP(0)'), nullable=False),
|
|
sa.PrimaryKeyConstraint('id', name='tool_model_invoke_pkey')
|
|
)
|
|
else:
|
|
op.create_table('tool_model_invokes',
|
|
sa.Column('id', models.types.StringUUID(), default=lambda: str(uuid4()), nullable=False),
|
|
sa.Column('user_id', models.types.StringUUID(), nullable=False),
|
|
sa.Column('tenant_id', models.types.StringUUID(), nullable=False),
|
|
sa.Column('provider', sa.String(length=40), nullable=False),
|
|
sa.Column('tool_type', sa.String(length=40), nullable=False),
|
|
sa.Column('tool_name', sa.String(length=40), nullable=False),
|
|
sa.Column('tool_id', models.types.StringUUID(), nullable=False),
|
|
sa.Column('model_parameters', models.types.LongText(), nullable=False),
|
|
sa.Column('prompt_messages', models.types.LongText(), nullable=False),
|
|
sa.Column('model_response', models.types.LongText(), nullable=False),
|
|
sa.Column('prompt_tokens', sa.Integer(), server_default=sa.text('0'), nullable=False),
|
|
sa.Column('answer_tokens', sa.Integer(), server_default=sa.text('0'), nullable=False),
|
|
sa.Column('answer_unit_price', sa.Numeric(precision=10, scale=4), nullable=False),
|
|
sa.Column('answer_price_unit', sa.Numeric(precision=10, scale=7), server_default=sa.text('0.001'), nullable=False),
|
|
sa.Column('provider_response_latency', sa.Float(), server_default=sa.text('0'), nullable=False),
|
|
sa.Column('total_price', sa.Numeric(precision=10, scale=7), nullable=True),
|
|
sa.Column('currency', sa.String(length=255), nullable=False),
|
|
sa.Column('created_at', sa.DateTime(), server_default=sa.func.current_timestamp(), nullable=False),
|
|
sa.Column('updated_at', sa.DateTime(), server_default=sa.func.current_timestamp(), nullable=False),
|
|
sa.PrimaryKeyConstraint('id', name='tool_model_invoke_pkey')
|
|
)
|
|
# ### end Alembic commands ###
|
|
|
|
|
|
def downgrade():
|
|
# ### commands auto generated by Alembic - please adjust! ###
|
|
op.drop_table('tool_model_invokes')
|
|
# ### end Alembic commands ###
|