List.js 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. const API = require("../../../lib/API.js")
  2. const db = require("../../../plugin/DataBase/db.js")
  3. const AccessControl = require("../../../lib/AccessControl.js")
  4. const { BaseStdResponse } = require("../../../BaseStdResponse.js")
  5. class AdminPopupList extends API {
  6. constructor() {
  7. super()
  8. this.setPath('/Admin/Popup/List')
  9. this.setMethod('GET')
  10. }
  11. async onRequest(req, res) {
  12. const { uuid, session, title, is_active, pagesize, current } = req.query
  13. if ([uuid, session, pagesize, current].some(v => v === '' || v === null || v === undefined))
  14. return res.json({ ...BaseStdResponse.MISSING_PARAMETER })
  15. if (isNaN(pagesize) || Number(pagesize) <= 0 || isNaN(current) || Number(current) <= 0)
  16. return res.json({ ...BaseStdResponse.ERR, msg: '参数错误' })
  17. if (!await AccessControl.checkSession(uuid, session))
  18. return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED })
  19. const permission = await AccessControl.getPermission(uuid)
  20. if (!permission.includes("admin") && !permission.includes("server"))
  21. return res.json({ ...BaseStdResponse.PERMISSION_DENIED })
  22. const offset = (Number(current) - 1) * Number(pagesize)
  23. const where = ['1 = 1']
  24. const params = []
  25. const countParams = []
  26. if (title) {
  27. where.push('p.title LIKE ?')
  28. params.push(`%${title}%`)
  29. countParams.push(`%${title}%`)
  30. }
  31. if (is_active !== undefined && is_active !== null && is_active !== '') {
  32. where.push('p.is_active = ?')
  33. params.push(Number(is_active) === 1 ? 1 : 0)
  34. countParams.push(Number(is_active) === 1 ? 1 : 0)
  35. }
  36. const whereSql = where.join(' AND ')
  37. const listSql = `
  38. SELECT
  39. p.id,
  40. p.title,
  41. p.content_html,
  42. p.priority,
  43. p.is_active,
  44. p.repeat_show,
  45. p.start_at,
  46. p.end_at,
  47. p.created_by,
  48. p.created_at,
  49. p.updated_at,
  50. (
  51. SELECT COUNT(*)
  52. FROM site_popup_read r
  53. WHERE r.popup_id = p.id
  54. ) AS read_count
  55. FROM site_popup p
  56. WHERE ${whereSql}
  57. ORDER BY p.id DESC
  58. LIMIT ? OFFSET ?
  59. `
  60. const countSql = `SELECT COUNT(*) AS total FROM site_popup p WHERE ${whereSql}`
  61. params.push(String(pagesize), String(offset))
  62. const rows = await db.query(listSql, params)
  63. const countRows = await db.query(countSql, countParams)
  64. if (!rows || !countRows) return res.json({ ...BaseStdResponse.DATABASE_ERR })
  65. return res.json({
  66. ...BaseStdResponse.OK,
  67. data: rows,
  68. pagination: {
  69. current: Number(current),
  70. pagesize: Number(pagesize),
  71. total: countRows[0]?.total || 0
  72. }
  73. })
  74. }
  75. }
  76. module.exports.AdminPopupList = AdminPopupList