CloseOrder.js 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. const API = require("../../../lib/API.js");
  2. const db = require("../../../plugin/DataBase/db.js");
  3. const { BaseStdResponse } = require("../../../BaseStdResponse.js");
  4. const AccessControl = require("../../../lib/AccessControl.js");
  5. class CloseOrder extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Kefu/Order')
  9. this.setMethod('DELETE')
  10. }
  11. async onRequest(req, res) {
  12. let { uuid, session, id } = req.body
  13. if ([uuid, session, id].some(value => value === '' || value === null || value === undefined))
  14. return res.json({
  15. ...BaseStdResponse.MISSING_PARAMETER
  16. })
  17. if (!await AccessControl.checkSession(uuid, session))
  18. return res.status(401).json({
  19. ...BaseStdResponse.ACCESS_DENIED
  20. })
  21. const time = new Date().getTime()
  22. let msg = []
  23. const systemMsg = {
  24. time,
  25. content: '当前工单已关闭,若仍有疑问可提交新工单哦~~',
  26. uuid: 'e4fe0277-0b1a-41a1-b25f-8b6e4cec3281',
  27. type: 'system'
  28. }
  29. const selectSql = 'SELECT msg, state, create_user FROM work_order WHERE id = ?'
  30. const selectRows = await db.query(selectSql, [id])
  31. if (!selectRows || selectRows.length !== 1 || selectRows[0].state === 2)
  32. return res.json({
  33. ...BaseStdResponse.ERR,
  34. msg: '工单异常或已关闭,请提交新工单'
  35. })
  36. let permission = await AccessControl.getPermission(uuid)
  37. if(selectRows[0].create_user !== uuid && !permission.includes("admin") && !permission.includes("service"))
  38. return res.json({
  39. ...BaseStdResponse.PERMISSION_DENIED,
  40. msg: '无操作权限'
  41. })
  42. msg = selectRows[0].msg
  43. msg.push(systemMsg)
  44. let sql = 'UPDATE work_order SET msg = ?, update_time = ?, state = 2 WHERE id = ?'
  45. let r = await db.query(sql, [msg, time, id])
  46. try {
  47. if (r && r.affectedRows > 0) {
  48. res.json({
  49. ...BaseStdResponse.OK,
  50. data: r.insertId
  51. })
  52. } else {
  53. return res.json({ ...BaseStdResponse.ERR, msg: '关闭工单失败!数据库错误' })
  54. }
  55. } catch (err) {
  56. this.logger.error(`关闭工单失败!${err.stack}`)
  57. res.json({
  58. ...BaseStdResponse.ERR,
  59. msg: "关闭工单失败!",
  60. })
  61. }
  62. }
  63. }
  64. module.exports.CloseOrder = CloseOrder