buleprint.py 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. import uuid
  2. from quart import Blueprint, jsonify, request
  3. from applications.config import DEFAULT_MODEL, LOCAL_MODEL_CONFIG, ChunkerConfig
  4. from applications.api import get_basic_embedding
  5. from applications.async_task import ChunkEmbeddingTask
  6. server_bp = Blueprint("api", __name__, url_prefix="/api")
  7. def server_routes(mysql_db, vector_db):
  8. @server_bp.route("/embed", methods=["POST"])
  9. async def embed():
  10. body = await request.get_json()
  11. text = body.get("text")
  12. model_name = body.get("model", DEFAULT_MODEL)
  13. if not LOCAL_MODEL_CONFIG.get(model_name):
  14. return jsonify({"error": "error model"})
  15. embedding = await get_basic_embedding(text, model_name)
  16. return jsonify({"embedding": embedding})
  17. @server_bp.route("/chunk", methods=["POST"])
  18. async def chunk():
  19. body = await request.get_json()
  20. text = body.get("text", "")
  21. text = text.strip()
  22. if not text:
  23. return jsonify({"error": "error text"})
  24. doc_id = f"doc-{uuid.uuid4()}"
  25. chunk_task = ChunkEmbeddingTask(mysql_db, vector_db, cfg=ChunkerConfig(), doc_id=doc_id)
  26. doc_id = await chunk_task.deal(body)
  27. return jsonify({"doc_id": doc_id})
  28. @server_bp.route("/search", methods=["POST"])
  29. async def search():
  30. pass
  31. return server_bp