2024-08-13 14:44:10 +08:00
|
|
|
from flask_restful import Resource, marshal_with, reqparse
|
|
|
|
from sqlalchemy import select
|
|
|
|
from sqlalchemy.orm import Session
|
|
|
|
|
|
|
|
from controllers.console import api
|
|
|
|
from controllers.console.app.wraps import get_app_model
|
2024-11-01 15:51:22 +08:00
|
|
|
from controllers.console.wraps import account_initialization_required, setup_required
|
2024-08-13 14:44:10 +08:00
|
|
|
from extensions.ext_database import db
|
|
|
|
from fields.conversation_variable_fields import paginated_conversation_variable_fields
|
|
|
|
from libs.login import login_required
|
|
|
|
from models import ConversationVariable
|
|
|
|
from models.model import AppMode
|
|
|
|
|
|
|
|
|
|
|
|
class ConversationVariablesApi(Resource):
|
|
|
|
@setup_required
|
|
|
|
@login_required
|
|
|
|
@account_initialization_required
|
|
|
|
@get_app_model(mode=AppMode.ADVANCED_CHAT)
|
|
|
|
@marshal_with(paginated_conversation_variable_fields)
|
|
|
|
def get(self, app_model):
|
|
|
|
parser = reqparse.RequestParser()
|
2024-08-26 15:29:10 +08:00
|
|
|
parser.add_argument("conversation_id", type=str, location="args")
|
2024-08-13 14:44:10 +08:00
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
stmt = (
|
|
|
|
select(ConversationVariable)
|
|
|
|
.where(ConversationVariable.app_id == app_model.id)
|
|
|
|
.order_by(ConversationVariable.created_at)
|
|
|
|
)
|
2024-08-26 15:29:10 +08:00
|
|
|
if args["conversation_id"]:
|
|
|
|
stmt = stmt.where(ConversationVariable.conversation_id == args["conversation_id"])
|
2024-08-13 14:44:10 +08:00
|
|
|
else:
|
2024-08-26 15:29:10 +08:00
|
|
|
raise ValueError("conversation_id is required")
|
2024-08-13 14:44:10 +08:00
|
|
|
|
|
|
|
# NOTE: This is a temporary solution to avoid performance issues.
|
|
|
|
page = 1
|
|
|
|
page_size = 100
|
|
|
|
stmt = stmt.limit(page_size).offset((page - 1) * page_size)
|
|
|
|
|
|
|
|
with Session(db.engine) as session:
|
|
|
|
rows = session.scalars(stmt).all()
|
|
|
|
|
|
|
|
return {
|
2024-08-26 15:29:10 +08:00
|
|
|
"page": page,
|
|
|
|
"limit": page_size,
|
|
|
|
"total": len(rows),
|
|
|
|
"has_more": False,
|
|
|
|
"data": [
|
2024-08-13 14:44:10 +08:00
|
|
|
{
|
2024-08-26 15:29:10 +08:00
|
|
|
"created_at": row.created_at,
|
|
|
|
"updated_at": row.updated_at,
|
2024-08-13 14:44:10 +08:00
|
|
|
**row.to_variable().model_dump(),
|
|
|
|
}
|
|
|
|
for row in rows
|
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2024-08-26 15:29:10 +08:00
|
|
|
api.add_resource(ConversationVariablesApi, "/apps/<uuid:app_id>/conversation-variables")
|