CloseOrder.js 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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. if(selectRows[0].create_user !== uuid && !permission.includes("admin") && !permission.includes("service"))
  37. return res.json({
  38. ...BaseStdResponse.PERMISSION_DENIED,
  39. msg: '无操作权限'
  40. })
  41. msg = selectRows[0].msg
  42. msg.push(systemMsg)
  43. let sql = 'UPDATE work_order SET msg = ?, update_time = ?, state = 2 WHERE id = ?'
  44. let r = await db.query(sql, [msg, time, id])
  45. try {
  46. if (r && r.affectedRows > 0) {
  47. res.json({
  48. ...BaseStdResponse.OK,
  49. data: r.insertId
  50. })
  51. } else {
  52. return res.json({ ...BaseStdResponse.ERR, msg: '关闭工单失败!数据库错误' })
  53. }
  54. } catch (err) {
  55. this.logger.error(`关闭工单失败!${err.stack}`)
  56. res.json({
  57. ...BaseStdResponse.ERR,
  58. msg: "关闭工单失败!",
  59. })
  60. }
  61. }
  62. }
  63. module.exports.CloseOrder = CloseOrder