GetGoodsList.js 3.3 KB

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