|
@@ -0,0 +1,148 @@
|
|
|
|
|
+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
|