ByAccount.js 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. const API = require("../../../../lib/API.js")
  2. const db = require("../../../../plugin/DataBase/db.js")
  3. const { BaseStdResponse } = require("../../../../BaseStdResponse.js")
  4. const AccessControl = require("../../../../lib/AccessControl.js")
  5. function parseDetail(value) {
  6. if (value === null || value === undefined || value === '') return null
  7. if (typeof value === 'object') return value
  8. try {
  9. return JSON.parse(value)
  10. } catch {
  11. return null
  12. }
  13. }
  14. class AdminBindAuditByAccount extends API {
  15. constructor() {
  16. super()
  17. this.setPath('/Admin/Lepao/BindAudit/ByAccount')
  18. this.setMethod('GET')
  19. }
  20. async onRequest(req, res) {
  21. let { uuid, session, student_num, pagesize, current, queryTime } = req.query
  22. if ([uuid, session, student_num, pagesize, current].some(v => v === '' || v === null || v === undefined))
  23. return res.json({ ...BaseStdResponse.MISSING_PARAMETER })
  24. if (isNaN(pagesize) || Number(pagesize) <= 0 || isNaN(current) || Number(current) <= 0)
  25. return res.json({ ...BaseStdResponse.ERR, msg: '参数错误' })
  26. if (!await AccessControl.checkSession(uuid, session))
  27. return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED })
  28. const permission = await AccessControl.getPermission(uuid)
  29. if (!permission.includes("admin") && !permission.includes("server") && !permission.includes("service"))
  30. return res.json({ ...BaseStdResponse.PERMISSION_DENIED })
  31. const offset = (Number(current) - 1) * Number(pagesize)
  32. const where = ['lba.student_num COLLATE utf8mb4_general_ci = (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)']
  33. const params = [student_num]
  34. const countParams = [student_num]
  35. if (Array.isArray(queryTime) && queryTime.length === 2) {
  36. where.push('lba.created_at >= ? AND lba.created_at < ?')
  37. params.push(queryTime[0], queryTime[1])
  38. countParams.push(queryTime[0], queryTime[1])
  39. }
  40. const whereSql = where.join(' AND ')
  41. const listSql = `
  42. SELECT
  43. lba.id,
  44. lba.student_num,
  45. lba.owner_uuid,
  46. lba.action,
  47. lba.source,
  48. lba.operator_uuid,
  49. lba.detail_json,
  50. lba.created_at,
  51. la.name AS lepao_name,
  52. la.user_avatar AS lepao_avatar,
  53. owner_u.username AS owner_username,
  54. owner_u.avatar AS owner_avatar,
  55. op_u.username AS operator_username,
  56. op_u.avatar AS operator_avatar
  57. FROM lepao_bind_audit lba
  58. LEFT JOIN lepao_account la ON la.student_num COLLATE utf8mb4_general_ci = lba.student_num COLLATE utf8mb4_general_ci
  59. LEFT JOIN users owner_u ON owner_u.uuid COLLATE utf8mb4_general_ci = lba.owner_uuid COLLATE utf8mb4_general_ci
  60. LEFT JOIN users op_u ON op_u.uuid COLLATE utf8mb4_general_ci = lba.operator_uuid COLLATE utf8mb4_general_ci
  61. WHERE ${whereSql}
  62. ORDER BY lba.id DESC
  63. LIMIT ? OFFSET ?
  64. `
  65. const countSql = `SELECT COUNT(*) AS total FROM lepao_bind_audit lba WHERE ${whereSql}`
  66. params.push(String(pagesize), String(offset))
  67. const rows = await db.query(listSql, params)
  68. const countRows = await db.query(countSql, countParams)
  69. if (!rows || !countRows) return res.json({ ...BaseStdResponse.DATABASE_ERR })
  70. const data = rows.map(item => ({
  71. ...item,
  72. detail_json: parseDetail(item.detail_json)
  73. }))
  74. return res.json({
  75. ...BaseStdResponse.OK,
  76. data,
  77. pagination: {
  78. current: Number(current),
  79. pagesize: Number(pagesize),
  80. total: countRows[0]?.total || 0
  81. }
  82. })
  83. }
  84. }
  85. module.exports.AdminBindAuditByAccount = AdminBindAuditByAccount