AddGoods.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. const API = require("../../../lib/API");
  2. const db = require("../../../plugin/DataBase/db");
  3. const AccessControl = require("../../../lib/AccessControl");
  4. const { BaseStdResponse } = require("../../../BaseStdResponse");
  5. // 添加/编辑商品
  6. class AddProduct extends API {
  7. constructor() {
  8. super()
  9. this.setPath('/Admin/Goods')
  10. this.setMethod('POST')
  11. }
  12. async onRequest(req, res) {
  13. let {
  14. uuid,
  15. session,
  16. id,
  17. name,
  18. state,
  19. content,
  20. price,
  21. num,
  22. lepao_count,
  23. ic_count,
  24. icon,
  25. description,
  26. features
  27. } = req.body
  28. const goodsIcon = (icon && String(icon).trim()) ? String(icon).trim().slice(0, 16) : '🏃'
  29. const goodsDesc = description != null ? String(description).trim().slice(0, 200) : ''
  30. let goodsFeatures = '[]'
  31. if (features != null && features !== '') {
  32. const raw = typeof features === 'string' ? features : JSON.stringify(features)
  33. try {
  34. const arr = JSON.parse(raw)
  35. goodsFeatures = JSON.stringify(Array.isArray(arr) ? arr.map(s => String(s).trim()).filter(Boolean).slice(0, 6) : [])
  36. } catch {
  37. goodsFeatures = '[]'
  38. }
  39. }
  40. if ([uuid, session, name, state, content, price, num, lepao_count, ic_count].some(value => value === '' || value === null || value === undefined))
  41. return res.json({
  42. ...BaseStdResponse.MISSING_PARAMETER
  43. })
  44. // 检查 session
  45. if (!await AccessControl.checkSession(uuid, session))
  46. return res.status(401).json({
  47. ...BaseStdResponse.ACCESS_DENIED
  48. })
  49. // 检查权限
  50. let permission = await AccessControl.getPermission(uuid)
  51. if (!permission.includes("admin") && !permission.includes("product"))
  52. return res.json({
  53. ...BaseStdResponse.PERMISSION_DENIED
  54. })
  55. let sql, r
  56. const time = new Date().getTime()
  57. if (!id) {
  58. sql = 'INSERT INTO goods (name, create_user, create_time, update_time, state, content, price, lepao_count, ic_count, num, icon, description, features) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)'
  59. r = await db.query(sql, [name, uuid, time, time, state, content, price, lepao_count, ic_count, num, goodsIcon, goodsDesc, goodsFeatures])
  60. } else {
  61. sql = 'UPDATE goods SET name = ?, update_user = ?, update_time = ?, state = ?, content = ?, price = ?, lepao_count = ?, ic_count = ?, num = ?, icon = ?, description = ?, features = ? WHERE id = ?'
  62. r = await db.query(sql, [name, uuid, time, state, content, price, lepao_count, ic_count, num, goodsIcon, goodsDesc, goodsFeatures, id])
  63. }
  64. try {
  65. if (r && r.affectedRows > 0) {
  66. res.json({
  67. ...BaseStdResponse.OK
  68. })
  69. } else {
  70. res.json({ ...BaseStdResponse.ERR, endpoint: 7894378, 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.AddProduct = AddProduct;