const API = require("../../../../lib/API.js"); const db = require("../../../../plugin/DataBase/db.js"); const { BaseStdResponse } = require("../../../../BaseStdResponse.js"); const AccessControl = require("../../../../lib/AccessControl.js"); const { enrichLepaoRecordRow } = require("../../../../plugin/jkes/formatRecordRow.js"); class AdminGetLepaoRecords extends API { constructor() { super(); this.setPath('/Admin/Lepao/Records') this.setMethod('GET') } async onRequest(req, res) { let { uuid, session, name, lepao_account, email, queryTime, create_user, pagesize, current } = req.query if ([uuid, session, pagesize, current].some(value => value === '' || value === null || value === undefined)) return res.json({ ...BaseStdResponse.MISSING_PARAMETER, endpoint: 1513126 }) // 校验分页参数 if (isNaN(pagesize) || pagesize <= 0) { return res.json({ ...BaseStdResponse.ERR, msg: '参数错误' }) } if (isNaN(current) || current <= 0) { return res.json({ ...BaseStdResponse.ERR, msg: '参数错误' }) } if (!await AccessControl.checkSession(uuid, session)) return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED }) // 检查权限 let permission = await AccessControl.getPermission(uuid) if (!permission.includes("admin") && !permission.includes("server")) return res.json({ ...BaseStdResponse.PERMISSION_DENIED }) // 计算分页的 offset const offset = (current - 1) * pagesize let sql = ` SELECT r.id, r.time, r.result, r.state, r.lepao_account, r.path_id, a.name, a.user_avatar, u.username, u.avatar FROM lepao_record r LEFT JOIN lepao_account a ON r.lepao_account = a.student_num LEFT JOIN users u ON r.uuid = u.uuid WHERE 1 = 1 ` let countSql = ` SELECT COUNT(*) AS total FROM lepao_record r JOIN lepao_account a ON r.lepao_account = a.student_num WHERE 1 = 1 ` let params = [] let countParams = [] if (lepao_account) { sql += ` AND r.lepao_account LIKE ?` countSql += ` AND r.lepao_account LIKE ?` params.push(`%${lepao_account}%`) countParams.push(`%${lepao_account}%`) } if (email) { sql += ` AND a.email = ?` countSql += ` AND a.email = ?` params.push(email) countParams.push(email) } if (name) { sql += ` AND a.name LIKE ?` countSql += ` AND a.name LIKE ?` params.push(`%${name}%`) countParams.push(`%${name}%`) } if (create_user) { sql += ` AND r.uuid = ?` countSql += ` AND r.uuid = ?` params.push(create_user) countParams.push(create_user) } if(queryTime || (Array.isArray(queryTime) && queryTime.length === 2)) { sql += ` AND r.time >= ? AND r.time < ?` countSql += ` AND r.time >= ? AND r.time < ?` params.push(queryTime[0], queryTime[1]) countParams.push(queryTime[0], queryTime[1]) } sql += ` ORDER BY id DESC LIMIT ? OFFSET ?; ` params.push(String(pagesize), String(offset)) let rows = await db.query(sql, params) let countResult = await db.query(countSql, countParams) if (!rows || !countResult) return res.json({ ...BaseStdResponse.DATABASE_ERR }) let total = countResult[0].total res.json({ ...BaseStdResponse.OK, data: rows.map(enrichLepaoRecordRow), pagination: { current, pagesize, total } }) } } module.exports.AdminGetLepaoRecords = AdminGetLepaoRecords