RAGflow/management/server/app.py

90 lines
2.6 KiB
Python
Raw Normal View History

2025-03-28 22:45:42 +08:00
from flask import Flask, jsonify, request
from flask_cors import CORS
import mysql.connector
import database
app = Flask(__name__)
# 启用CORS允许前端访问
CORS(app, resources={r"/api/*": {"origins": "*"}}, supports_credentials=True)
# 添加 v1 前缀
@app.route('/api/v1/auth/login', methods=['POST'])
def login():
# 实现登录逻辑
return {"code": 0, "data": {"token": "your-token"}, "message": "登录成功"}
@app.route('/api/v1/users/me', methods=['GET'])
def get_current_user():
return jsonify({
"code": 0,
"data": {
"username": "admin",
"roles": ["admin"]
},
"message": "获取用户信息成功"
})
@app.route('/api/v1/users', methods=['GET'])
def get_users():
"""获取用户的API端点,支持分页和条件查询"""
try:
# 获取查询参数
current_page = int(request.args.get('currentPage', 1))
page_size = int(request.args.get('size', 10))
username = request.args.get('username', '')
email = request.args.get('email', '')
# 调用数据库函数获取分页和筛选后的用户数据
users, total = database.get_users_with_pagination(current_page, page_size, username, email)
# 返回符合前端期望格式的数据
return jsonify({
"code": 0, # 成功状态码
"data": {
"list": users,
"total": total
},
"message": "获取用户列表成功"
})
except Exception as e:
# 错误处理
return jsonify({
"code": 500,
"message": f"获取用户列表失败: {str(e)}"
}), 500
@app.route('/api/v1/users/<string:user_id>', methods=['DELETE'])
def delete_user(user_id):
"""删除用户的API端点"""
database.delete_user(user_id)
return jsonify({
"code": 0,
"message": f"用户 {user_id} 删除成功"
})
@app.route('/api/v1/users', methods=['POST'])
def create_user():
"""创建用户的API端点"""
data = request.json
# 创建用户
database.create_user(user_data=data)
return jsonify({
"code": 0,
"message": "用户创建成功"
})
@app.route('/api/v1/users/<string:user_id>', methods=['PUT'])
def update_user(user_id):
"""更新用户的API端点"""
data = request.json
user_id = data.get('id')
database.update_user(user_id=user_id, user_data=data)
return jsonify({
"code": 0,
"message": f"用户 {user_id} 更新成功"
})
if __name__ == '__main__':
app.run(host='0.0.0.0', port=5000, debug=True)