GetGoods.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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 GetGoods extends API {
  7. constructor() {
  8. super();
  9. this.setPath('/Admin/Goods')
  10. this.setMethod('GET')
  11. }
  12. async onRequest(req, res) {
  13. let {
  14. uuid,
  15. session,
  16. id
  17. } = req.query
  18. if ([uuid, session, id].some(value => value === '' || value === null || value === undefined))
  19. return res.json({
  20. ...BaseStdResponse.MISSING_PARAMETER
  21. })
  22. // 检查 session
  23. if (!await AccessControl.checkSession(uuid, session))
  24. return res.status(401).json({
  25. ...BaseStdResponse.ACCESS_DENIED
  26. })
  27. // 检查权限
  28. let permission = await AccessControl.getPermission(uuid)
  29. if (!permission.includes("admin") && !permission.includes("product"))
  30. return res.json({
  31. ...BaseStdResponse.PERMISSION_DENIED
  32. })
  33. let sql = `
  34. SELECT
  35. a.id,
  36. a.name,
  37. a.state,
  38. a.content,
  39. a.price,
  40. a.views,
  41. a.num,
  42. a.ic_count,
  43. a.lepao_count,
  44. a.create_time,
  45. a.update_time,
  46. a.limit,
  47. u1.username AS create_user,
  48. u2.username AS update_user
  49. FROM
  50. goods a
  51. LEFT JOIN
  52. users u1
  53. ON
  54. a.create_user = u1.uuid
  55. LEFT JOIN
  56. users u2
  57. ON
  58. a.update_user = u2.uuid
  59. WHERE a.id = ?
  60. `
  61. let rows = await db.query(sql, [id])
  62. if (!rows || rows.length === 0)
  63. return res.json({
  64. ...BaseStdResponse.MISSING_FILE,
  65. msg: '获取商品失败!'
  66. })
  67. res.json({
  68. ...BaseStdResponse.OK,
  69. data: rows[0]
  70. })
  71. }
  72. }
  73. module.exports.GetGoods = GetGoods