GetGoodsList.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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. u1.username AS create_user,
  51. u2.username AS update_user
  52. FROM
  53. goods a
  54. LEFT JOIN
  55. users u1 ON a.create_user = u1.uuid
  56. LEFT JOIN
  57. users u2 ON a.update_user = u2.uuid
  58. WHERE 1=1
  59. `
  60. let countSql = `
  61. SELECT COUNT(*) AS total
  62. FROM goods a
  63. WHERE 1 = 1
  64. `
  65. let params = []
  66. let countParams = []
  67. if (keyword) {
  68. sql += ` AND a.name LIKE ?`
  69. countSql += ` AND a.name LIKE ?`
  70. params.push(`%${keyword}%`)
  71. countParams.push(`%${keyword}%`)
  72. }
  73. sql += `
  74. ORDER BY
  75. a.id DESC
  76. LIMIT ? OFFSET ?
  77. `
  78. params.push(String(pagesize), String(offset))
  79. let rows = await db.query(sql, params);
  80. let countResult = await db.query(countSql, countParams)
  81. if (!rows || !countResult)
  82. return res.json({
  83. ...BaseStdResponse.MISSING_FILE,
  84. msg: '获取产品失败!'
  85. })
  86. let total = countResult[0].total
  87. const totalPages = Math.ceil(total / pagesize)
  88. res.json({
  89. ...BaseStdResponse.OK,
  90. data: rows,
  91. pagination: {
  92. current: current,
  93. pagesize: pagesize,
  94. total: total,
  95. totalPages: totalPages
  96. }
  97. })
  98. }
  99. }
  100. module.exports.GetProductList = GetProductList;