const API = require("../../../lib/API") const db = require("../../../plugin/DataBase/db") const AccessControl = require("../../../lib/AccessControl") const { BaseStdResponse } = require("../../../BaseStdResponse") class GetRecordDetail extends API { constructor() { super(); this.setPath('/Lepao/GetRecordDetail') this.setMethod('GET') } async onRequest(req, res) { let { uuid, session, id, public_id } = req.query if ([uuid, session].some(value => value === '' || value === null || value === undefined)) return res.json({ ...BaseStdResponse.MISSING_PARAMETER }) if ((id === '' || id === null || id === undefined) && (public_id === '' || public_id === null || public_id === undefined)) return res.json({ ...BaseStdResponse.MISSING_PARAMETER }) // 检查 session if (!await AccessControl.checkSession(uuid, session)) return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED }) let sql = ` SELECT r.public_id, r.time, r.result, r.run_mode, r.lepao_account, r.point_data, a.name, p.data FROM lepao_record r LEFT JOIN lepao_account a ON r.lepao_account = a.student_num LEFT JOIN path_data p ON r.path_id = p.id WHERE (r.uuid = ? OR (a.create_user IS NOT NULL AND a.create_user = ?)) ` const params = [uuid, uuid] if (public_id !== '' && public_id !== null && public_id !== undefined) { sql += ' AND r.public_id = ?' params.push(public_id) } else { sql += ' AND r.id = ?' params.push(id) } let rows = await db.query(sql, params) if (!rows) return res.json({ ...BaseStdResponse.MISSING_FILE, msg: '获取记录数据失败!' }) if(rows.length === 0) return res.json({ ...BaseStdResponse.MISSING_FILE, msg: '记录不存在或已被删除!' }) let data = rows[0] data.data = data.data.map(point => [point.o, point.a]) res.json({ ...BaseStdResponse.OK, data }) } } module.exports.GetRecordDetail = GetRecordDetail