GetRecordDetail.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. const API = require("../../../lib/API")
  2. const db = require("../../../plugin/DataBase/db")
  3. const AccessControl = require("../../../lib/AccessControl")
  4. const { BaseStdResponse } = require("../../../BaseStdResponse")
  5. class GetRecordDetail extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Lepao/GetRecordDetail')
  9. this.setMethod('GET')
  10. }
  11. async onRequest(req, res) {
  12. let {
  13. uuid,
  14. session,
  15. id
  16. } = req.query
  17. if ([uuid, session, id].some(value => value === '' || value === null || value === undefined))
  18. return res.json({
  19. ...BaseStdResponse.MISSING_PARAMETER
  20. })
  21. // 检查 session
  22. if (!await AccessControl.checkSession(uuid, session))
  23. return res.status(401).json({
  24. ...BaseStdResponse.ACCESS_DENIED
  25. })
  26. let sql = `
  27. SELECT
  28. r.time,
  29. r.result,
  30. r.lepao_account,
  31. a.name,
  32. p.data
  33. FROM
  34. lepao_record r
  35. LEFT JOIN
  36. lepao_account a
  37. ON
  38. r.lepao_account = a.student_num
  39. LEFT JOIN
  40. path_data p
  41. ON
  42. r.path_id = p.id
  43. WHERE
  44. (r.uuid = ? OR (a.create_user IS NOT NULL AND a.create_user = ?)) AND r.id = ?
  45. `
  46. let rows = await db.query(sql, [uuid, uuid, id])
  47. if (!rows)
  48. return res.json({
  49. ...BaseStdResponse.MISSING_FILE,
  50. msg: '获取记录数据失败!'
  51. })
  52. if(rows.length === 0)
  53. return res.json({
  54. ...BaseStdResponse.MISSING_FILE,
  55. msg: '记录不存在或已被删除!'
  56. })
  57. let data = rows[0]
  58. data.data = data.data.map(point => [point.o, point.a])
  59. res.json({
  60. ...BaseStdResponse.OK,
  61. data
  62. })
  63. }
  64. }
  65. module.exports.GetRecordDetail = GetRecordDetail