CreateOrder.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. class CreateOrder extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Kefu/Order')
  9. this.setMethod('POST')
  10. }
  11. async onRequest(req, res) {
  12. let { uuid, session, id, title, content, files, email } = req.body
  13. if ([uuid, session, content].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. let message = {
  24. time,
  25. content,
  26. files: files ?? [],
  27. uuid,
  28. type: 'user'
  29. }
  30. let sql, r
  31. if (!id) {
  32. if ([title].some(value => value === '' || value === null || value === undefined))
  33. return res.json({
  34. ...BaseStdResponse.MISSING_PARAMETER
  35. })
  36. msg.push(message)
  37. const systemMsg = {
  38. time,
  39. content: '您的问题已收到,我们将会尽快处理您的问题,请耐心等待,感谢您的支持理解。',
  40. uuid: 'e4fe0277-0b1a-41a1-b25f-8b6e4cec3281',
  41. type: 'system'
  42. }
  43. msg.push(systemMsg)
  44. sql = 'INSERT INTO work_order (title, email, msg, create_user, create_time, update_time) VALUES (?, ?, ?, ?, ?, ?)'
  45. r = await db.query(sql, [title, email, msg, uuid, time, time])
  46. } else {
  47. const selectSql = 'SELECT msg, state, email FROM work_order WHERE id = ? AND create_user = ?'
  48. const selectRows = await db.query(selectSql, [id, uuid])
  49. if (!selectRows || selectRows.length !== 1 || selectRows[0].state === 2)
  50. return res.json({
  51. ...BaseStdResponse.ERR,
  52. msg: '工单异常或已关闭,请提交新工单'
  53. })
  54. msg = selectRows[0].msg
  55. msg.push(message)
  56. sql = 'UPDATE work_order SET msg = ?, update_time = ?, state = 0 WHERE id = ? AND create_user = ?'
  57. r = await db.query(sql, [msg, time, id, uuid])
  58. }
  59. try {
  60. if (r && r.affectedRows > 0) {
  61. res.json({
  62. ...BaseStdResponse.OK,
  63. data: r.insertId
  64. })
  65. // 完善功能:发送提醒邮件
  66. } else {
  67. return res.json({ ...BaseStdResponse.ERR, msg: '提交工单失败!数据库错误' })
  68. }
  69. } catch (err) {
  70. this.logger.error(`提交工单失败!${err.stack}`)
  71. res.json({
  72. ...BaseStdResponse.ERR,
  73. msg: "提交工单失败!",
  74. })
  75. }
  76. }
  77. }
  78. module.exports.CreateOrder = CreateOrder