GetGoodsList.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  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 GetProductList extends API {
  7. constructor() {
  8. super();
  9. this.setPath('/Admin/Product/List');
  10. this.setMethod('post');
  11. }
  12. async onRequest(req, res) {
  13. let { uuid, session, pagesize, current, keyword } = req.body;
  14. if ([uuid, session, pagesize, current].some(value => value === '' || value === null || value === undefined))
  15. return res.json({
  16. ...BaseStdResponse.MISSING_PARAMETER
  17. })
  18. // 校验分页参数
  19. if (isNaN(pagesize) || pagesize <= 0 || isNaN(current) || current <= 0) {
  20. return res.json({
  21. ...BaseStdResponse.ERR,
  22. msg: '参数错误'
  23. })
  24. }
  25. // 计算分页的 offset
  26. const offset = (current - 1) * pagesize
  27. // 检查 session
  28. if (!await AccessControl.checkSession(uuid, session))
  29. return res.status(401).json({
  30. ...BaseStdResponse.ACCESS_DENIED
  31. })
  32. // 检查权限
  33. let permission = await AccessControl.getPermission(uuid)
  34. if (!permission.includes("admin") && !permission.includes("product"))
  35. return res.json({
  36. ...BaseStdResponse.PERMISSION_DENIED
  37. })
  38. let sql = `
  39. SELECT
  40. a.id,
  41. a.name,
  42. a.state,
  43. a.price,
  44. a.num,
  45. a.ic_count,
  46. a.lepao_count,
  47. a.views,
  48. a.create_time,
  49. a.update_time,
  50. a.limit,
  51. u1.username AS create_user,
  52. u2.username AS update_user
  53. FROM
  54. goods a
  55. LEFT JOIN
  56. users u1 ON a.create_user = u1.uuid
  57. LEFT JOIN
  58. users u2 ON a.update_user = u2.uuid
  59. WHERE 1=1
  60. `
  61. let countSql = `
  62. SELECT COUNT(*) AS total
  63. FROM goods a
  64. WHERE 1 = 1
  65. `
  66. let params = []
  67. let countParams = []
  68. if (keyword) {
  69. sql += ` AND a.name LIKE ?`
  70. countSql += ` AND a.name LIKE ?`
  71. params.push(`%${keyword}%`)
  72. countParams.push(`%${keyword}%`)
  73. }
  74. sql += `
  75. ORDER BY
  76. a.id DESC
  77. LIMIT ? OFFSET ?
  78. `
  79. params.push(String(pagesize), String(offset))
  80. let rows = await db.query(sql, params);
  81. let countResult = await db.query(countSql, countParams)
  82. if (!rows || !countResult)
  83. return res.json({
  84. ...BaseStdResponse.MISSING_FILE,
  85. msg: '获取产品失败!'
  86. })
  87. let total = countResult[0].total
  88. const totalPages = Math.ceil(total / pagesize)
  89. res.json({
  90. ...BaseStdResponse.OK,
  91. data: rows,
  92. pagination: {
  93. current: current,
  94. pagesize: pagesize,
  95. total: total,
  96. totalPages: totalPages
  97. }
  98. })
  99. }
  100. }
  101. module.exports.GetProductList = GetProductList;