ReplyOrder.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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. const EmailTemplate = require('../../../../plugin/Email/emailTemplate')
  6. const OneBotV11 = require('../../../../plugin/OneBot/OneBotV11')
  7. class ReplyOrder extends API {
  8. constructor() {
  9. super();
  10. this.setPath('/Admin/Kefu/Order')
  11. this.setMethod('PUT')
  12. }
  13. async onRequest(req, res) {
  14. let { uuid, session, id, content, files } = req.body
  15. if ([uuid, session, id, content].some(value => value === '' || value === null || value === undefined))
  16. return res.json({
  17. ...BaseStdResponse.MISSING_PARAMETER
  18. })
  19. if (!await AccessControl.checkSession(uuid, session))
  20. return res.status(401).json({
  21. ...BaseStdResponse.ACCESS_DENIED
  22. })
  23. // 检查权限
  24. let permission = await AccessControl.getPermission(uuid)
  25. if (!permission.includes("admin") && !permission.includes("service"))
  26. return res.json({
  27. ...BaseStdResponse.PERMISSION_DENIED
  28. })
  29. const time = new Date().getTime()
  30. let msg = []
  31. let message = {
  32. time,
  33. content,
  34. files: files ?? [],
  35. uuid,
  36. type: 'server'
  37. }
  38. const selectSql = 'SELECT msg, state, email FROM work_order WHERE id = ?'
  39. const selectRows = await db.query(selectSql, [id])
  40. if (!selectRows || selectRows.length !== 1 || selectRows[0].state === 2)
  41. return res.json({
  42. ...BaseStdResponse.ERR,
  43. msg: '工单异常或已关闭'
  44. })
  45. msg = selectRows[0].msg
  46. msg.push(message)
  47. let sql = 'UPDATE work_order SET msg = ?, update_time = ?, state = 1 WHERE id = ?'
  48. let r = await db.query(sql, [msg, time, id])
  49. try {
  50. if (r && r.affectedRows > 0) {
  51. res.json({
  52. ...BaseStdResponse.OK,
  53. data: r.insertId
  54. })
  55. if (selectRows[0].email) {
  56. await EmailTemplate.orderNewReply(selectRows[0].email, { id, content, files })
  57. }
  58. // try {
  59. // await OneBotV11.sendOrderMessage({
  60. // orderId: id,
  61. // role: '客服',
  62. // senderUuid: uuid,
  63. // content,
  64. // files: files ?? []
  65. // })
  66. // } catch (botErr) {
  67. // this.logger.error(`OneBot v11 转发客服回复失败:${botErr.stack}`)
  68. // }
  69. } else {
  70. return res.json({ ...BaseStdResponse.ERR, msg: '回复工单失败!数据库错误' })
  71. }
  72. } catch (err) {
  73. this.logger.error(`回复工单失败!${err.stack}`)
  74. res.json({
  75. ...BaseStdResponse.ERR,
  76. msg: "回复工单失败!",
  77. })
  78. }
  79. }
  80. }
  81. module.exports.ReplyOrder = ReplyOrder