GetPathDetail.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  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 GetPathDetail extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Lepao/GetPathDetail')
  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("path"))
  29. return res.json({
  30. ...BaseStdResponse.PERMISSION_DENIED
  31. })
  32. let sql = `
  33. SELECT
  34. id,
  35. run_zone_name,
  36. distance,
  37. point_list,
  38. time,
  39. data,
  40. count,
  41. speed,
  42. state
  43. FROM
  44. path_data
  45. WHERE id = ?
  46. `
  47. let rows = await db.query(sql, [id])
  48. if (!rows || rows.length === 0)
  49. return res.json({
  50. ...BaseStdResponse.MISSING_FILE,
  51. msg: '获取路径数据失败!'
  52. })
  53. data.data = data.data.map(point => [point.o, point.a])
  54. res.json({
  55. ...BaseStdResponse.OK,
  56. data
  57. })
  58. }
  59. }
  60. module.exports.GetPathDetail = GetPathDetail