GetRecordDetail.js 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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 AdminGetRecordDetail extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Admin/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. // 检查权限
  27. let permission = await AccessControl.getPermission(uuid)
  28. if (!permission.includes("admin") && !permission.includes("server"))
  29. return res.json({
  30. ...BaseStdResponse.PERMISSION_DENIED
  31. })
  32. let sql = `
  33. SELECT
  34. r.time,
  35. r.result,
  36. r.lepao_account,
  37. r.point_data,
  38. a.name,
  39. p.data
  40. FROM
  41. lepao_record r
  42. LEFT JOIN
  43. lepao_account a
  44. ON
  45. r.lepao_account = a.student_num
  46. LEFT JOIN
  47. path_data p
  48. ON
  49. r.path_id = p.id
  50. WHERE
  51. r.id = ?
  52. `
  53. let rows = await db.query(sql, [id])
  54. if (!rows)
  55. return res.json({
  56. ...BaseStdResponse.MISSING_FILE,
  57. msg: '获取记录数据失败!'
  58. })
  59. if(rows.length === 0)
  60. return res.json({
  61. ...BaseStdResponse.MISSING_FILE,
  62. msg: '记录不存在或已被删除!'
  63. })
  64. let data = rows[0]
  65. data.data = data.data.map(point => [point.o, point.a])
  66. res.json({
  67. ...BaseStdResponse.OK,
  68. data
  69. })
  70. }
  71. }
  72. module.exports.AdminGetRecordDetail = AdminGetRecordDetail