18351212e8
- 问题从文件系统迁移到数据库 problems 表 - 移除 PROBLEMS_DIR 配置和文件读取逻辑 - student.html 完整重写:编辑/添加/删除问题,生成方案进度显示 - 学员详情页支持独立URL访问 (/student/<id>) - 统一侧边栏到 base.html - 更新文档:DEPLOYMENT_SOP, MODELS, STRUCTURE, FRONTEND_ARCH - 部署到生产环境 v1.2.0
107 lines
3.3 KiB
Python
107 lines
3.3 KiB
Python
# 问题记录路由
|
|
|
|
from flask import request, jsonify
|
|
from app.routes import main_bp
|
|
from app.models import db, Student, StudentProblem
|
|
from app.routes.auth import login_required_json
|
|
|
|
|
|
@main_bp.route("/api/students/<int:student_id>/problems", methods=["GET"])
|
|
@login_required_json
|
|
def get_student_problems(student_id):
|
|
"""获取学员的问题列表"""
|
|
student = Student.query.get_or_404(student_id)
|
|
problems = student.problems.all()
|
|
return jsonify([p.to_dict() for p in problems])
|
|
|
|
|
|
@main_bp.route("/api/students/<int:student_id>/problems", methods=["POST"])
|
|
@login_required_json
|
|
def add_student_problem(student_id):
|
|
"""为学员添加问题(同步模式:先删再加)"""
|
|
student = Student.query.get_or_404(student_id)
|
|
data = request.get_json()
|
|
|
|
problems = data.get("problems", [])
|
|
submitted_ids = set()
|
|
|
|
# 删除旧的问题(如果勾选被取消)
|
|
existing = StudentProblem.query.filter_by(student_id=student_id).all()
|
|
for e in existing:
|
|
if e.problem_id not in [p.get("problem_id") for p in problems]:
|
|
db.session.delete(e)
|
|
|
|
# 添加或更新问题
|
|
for p in problems:
|
|
problem_id = p.get("problem_id") # 这是 problems.id
|
|
submitted_ids.add(problem_id)
|
|
|
|
# 检查是否已存在
|
|
existing = StudentProblem.query.filter_by(
|
|
student_id=student_id, problem_id=problem_id
|
|
).first()
|
|
|
|
if existing:
|
|
# 更新现有记录
|
|
existing.severity = p.get("severity")
|
|
existing.level = p.get("level")
|
|
else:
|
|
# 添加新记录
|
|
problem = StudentProblem(
|
|
student_id=student_id,
|
|
problem_id=problem_id,
|
|
severity=p.get("severity"),
|
|
level=p.get("level"),
|
|
)
|
|
db.session.add(problem)
|
|
|
|
db.session.commit()
|
|
return jsonify({"message": "问题记录成功"})
|
|
|
|
|
|
@main_bp.route("/api/students/<int:student_id>/problems", methods=["DELETE"])
|
|
@login_required_json
|
|
def clear_student_problems(student_id):
|
|
"""清除学员的问题记录"""
|
|
StudentProblem.query.filter_by(student_id=student_id).delete()
|
|
db.session.commit()
|
|
return jsonify({"message": "清除成功"})
|
|
|
|
|
|
@main_bp.route(
|
|
"/api/students/<int:student_id>/problems/<int:student_problem_id>", methods=["DELETE"]
|
|
)
|
|
@login_required_json
|
|
def delete_single_problem(student_id, student_problem_id):
|
|
"""删除学员的单个问题"""
|
|
StudentProblem.query.filter_by(
|
|
id=student_problem_id
|
|
).delete()
|
|
db.session.commit()
|
|
return jsonify({"message": "删除成功"})
|
|
|
|
|
|
@main_bp.route(
|
|
"/api/students/<int:student_id>/problems/<int:student_problem_id>", methods=["PUT"]
|
|
)
|
|
@login_required_json
|
|
def update_single_problem(student_id, student_problem_id):
|
|
"""更新学员的单个问题(严重程度和级别)"""
|
|
student = Student.query.get_or_404(student_id)
|
|
data = request.get_json()
|
|
|
|
problem = StudentProblem.query.filter_by(
|
|
id=student_problem_id
|
|
).first()
|
|
|
|
if not problem:
|
|
return jsonify({"error": "问题记录不存在"}), 404
|
|
|
|
if "severity" in data:
|
|
problem.severity = data["severity"]
|
|
if "level" in data:
|
|
problem.level = data["level"]
|
|
|
|
db.session.commit()
|
|
return jsonify({"message": "更新成功", "problem": problem.to_dict()})
|