const API = require("../../../lib/API.js") const db = require("../../../plugin/DataBase/db.js") const { BaseStdResponse } = require("../../../BaseStdResponse.js") const AccessControl = require("../../../lib/AccessControl.js") function parseBookList(value) { if (value === null || value === undefined || value === '') return [] if (Array.isArray(value)) return value try { const parsed = JSON.parse(value) return Array.isArray(parsed) ? parsed : [] } catch { return [] } } function extractClassName(bookList) { if (!Array.isArray(bookList) || bookList.length === 0) return '' const book = bookList.find(b => b && b.className) return book?.className ?? '' } class AdminQxsAccountList extends API { constructor() { super() this.setPath('/Admin/QXS/Account/List') this.setMethod('GET') } async onRequest(req, res) { let { uuid, session, username, realname, email, mobile, termName, className, queryTime, pagesize, current } = req.query if ([uuid, session, pagesize, current].some(v => v === '' || v === null || v === undefined)) return res.json({ ...BaseStdResponse.MISSING_PARAMETER }) if (isNaN(pagesize) || Number(pagesize) <= 0 || isNaN(current) || Number(current) <= 0) return res.json({ ...BaseStdResponse.ERR, msg: '参数错误' }) if (!await AccessControl.checkSession(uuid, session)) return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED }) const permission = await AccessControl.getPermission(uuid) if (!permission.includes('admin') && !permission.includes('server') && !permission.includes('service')) return res.json({ ...BaseStdResponse.PERMISSION_DENIED }) const offset = (Number(current) - 1) * Number(pagesize) const where = ['1 = 1'] const params = [] const countParams = [] if (username) { where.push('qa.username COLLATE utf8mb4_general_ci LIKE (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)') params.push(`%${username}%`) countParams.push(`%${username}%`) } if (realname) { where.push('qa.realname COLLATE utf8mb4_general_ci LIKE (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)') params.push(`%${realname}%`) countParams.push(`%${realname}%`) } if (email) { where.push('qa.email COLLATE utf8mb4_general_ci LIKE (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)') params.push(`%${email}%`) countParams.push(`%${email}%`) } if (mobile) { where.push('qa.mobile COLLATE utf8mb4_general_ci LIKE (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)') params.push(`%${mobile}%`) countParams.push(`%${mobile}%`) } if (termName) { where.push('qa.termName COLLATE utf8mb4_general_ci LIKE (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)') params.push(`%${termName}%`) countParams.push(`%${termName}%`) } if (className) { where.push('qa.book_list COLLATE utf8mb4_general_ci LIKE (CONVERT(? USING utf8mb4) COLLATE utf8mb4_general_ci)') params.push(`%"className"%${className}%`) countParams.push(`%"className"%${className}%`) } if (Array.isArray(queryTime) && queryTime.length === 2) { where.push('qa.create_time >= ? AND qa.create_time < ?') params.push(queryTime[0], queryTime[1]) countParams.push(queryTime[0], queryTime[1]) } const whereSql = where.join(' AND ') const listSql = ` SELECT qa.id, qa.username, qa.create_time, qa.realname, qa.email, qa.mobile, qa.termName, qa.book_list FROM qsx_account qa WHERE ${whereSql} ORDER BY qa.id DESC LIMIT ? OFFSET ? ` const countSql = `SELECT COUNT(*) AS total FROM qsx_account qa WHERE ${whereSql}` params.push(String(pagesize), String(offset)) const rows = await db.query(listSql, params) const countRows = await db.query(countSql, countParams) if (!rows || !countRows) return res.json({ ...BaseStdResponse.DATABASE_ERR }) const data = rows.map(item => { const bookList = parseBookList(item.book_list) return { id: item.id, username: item.username, create_time: item.create_time, realname: item.realname, email: item.email, mobile: item.mobile, termName: item.termName, className: extractClassName(bookList), book_count: bookList.length } }) return res.json({ ...BaseStdResponse.OK, data, pagination: { current: Number(current), pagesize: Number(pagesize), total: countRows[0]?.total || 0 } }) } } module.exports.AdminQxsAccountList = AdminQxsAccountList