ReplyOrder.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. if (!await AccessControl.canAccess(uuid, ['action.service.replyOrder']))
  25. return res.json({
  26. ...BaseStdResponse.PERMISSION_DENIED
  27. })
  28. const time = new Date().getTime()
  29. let msg = []
  30. let message = {
  31. time,
  32. content,
  33. files: files ?? [],
  34. uuid,
  35. type: 'server'
  36. }
  37. const selectSql = 'SELECT msg, state, email FROM work_order WHERE id = ?'
  38. const selectRows = await db.query(selectSql, [id])
  39. if (!selectRows || selectRows.length !== 1 || selectRows[0].state === 2)
  40. return res.json({
  41. ...BaseStdResponse.ERR,
  42. msg: '工单异常或已关闭'
  43. })
  44. msg = selectRows[0].msg
  45. msg.push(message)
  46. let sql = 'UPDATE work_order SET msg = ?, update_time = ?, state = 1 WHERE id = ?'
  47. let r = await db.query(sql, [msg, time, id])
  48. try {
  49. if (r && r.affectedRows > 0) {
  50. res.json({
  51. ...BaseStdResponse.OK,
  52. data: r.insertId
  53. })
  54. if (selectRows[0].email) {
  55. await EmailTemplate.orderNewReply(selectRows[0].email, { id, content, files })
  56. }
  57. // try {
  58. // await OneBotV11.sendOrderMessage({
  59. // orderId: id,
  60. // role: '客服',
  61. // senderUuid: uuid,
  62. // content,
  63. // files: files ?? []
  64. // })
  65. // } catch (botErr) {
  66. // this.logger.error(`OneBot v11 转发客服回复失败:${botErr.stack}`)
  67. // }
  68. } else {
  69. return res.json({ ...BaseStdResponse.ERR, msg: '回复工单失败!数据库错误' })
  70. }
  71. } catch (err) {
  72. this.logger.error(`回复工单失败!${err.stack}`)
  73. res.json({
  74. ...BaseStdResponse.ERR,
  75. msg: "回复工单失败!",
  76. })
  77. }
  78. }
  79. }
  80. module.exports.ReplyOrder = ReplyOrder