UpdateSelfAccount.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. const API = require("../../../lib/API.js")
  2. const db = require("../../../plugin/DataBase/db.js")
  3. const axios = require("axios")
  4. const AccessControl = require("../../../lib/AccessControl.js")
  5. const { BaseStdResponse } = require("../../../BaseStdResponse.js")
  6. const { dataEncrypt, dataDecrypt, dataSign } = require("../../../plugin/Lepao/Crypto")
  7. const { URLSearchParams } = require("url")
  8. class UpdateSelfAccount extends API {
  9. constructor() {
  10. super()
  11. this.setPath('/Lepao/Account/UpdateSelfAccount')
  12. this.setMethod('POST')
  13. }
  14. async onRequest(req, res) {
  15. const { uuid, session, student_num } = req.body
  16. if ([uuid, session, student_num].some(v => v === '' || v === null || v === undefined)) {
  17. return res.json({
  18. ...BaseStdResponse.MISSING_PARAMETER
  19. })
  20. }
  21. if (!await AccessControl.checkSession(uuid, session)) {
  22. return res.status(401).json({
  23. ...BaseStdResponse.ACCESS_DENIED
  24. })
  25. }
  26. try {
  27. const rows = await db.query(
  28. 'SELECT uid, token, school_id, userAgent, state FROM lepao_account WHERE student_num = ? AND create_user = ?',
  29. [student_num, uuid]
  30. )
  31. if (!rows || rows.length !== 1) {
  32. return res.json({
  33. ...BaseStdResponse.ERR,
  34. msg: '未找到该乐跑账号或无权限操作'
  35. })
  36. }
  37. const account = rows[0]
  38. const raw = {
  39. uid: account.uid,
  40. token: account.token,
  41. school_id: account.school_id,
  42. term_id: 0,
  43. course_id: 0,
  44. class_id: 0,
  45. student_num,
  46. card_id: student_num,
  47. timestamp: Number((Date.now() / 1000).toFixed(3)),
  48. version: 1,
  49. nonce: String(Math.floor(Math.random() * 900000 + 100000)),
  50. ostype: 5
  51. }
  52. raw.sign = dataSign(raw)
  53. const form = new URLSearchParams()
  54. form.append('ostype', '5')
  55. form.append('data', dataEncrypt(JSON.stringify(raw)))
  56. const headers = {
  57. 'Content-Type': 'application/x-www-form-urlencoded',
  58. 'Accept': '*/*',
  59. 'Accept-Language': 'zh-CN,zh-Hans;q=0.9',
  60. 'Accept-Encoding': 'gzip, deflate, br',
  61. 'Referer': 'https://servicewechat.com/wxf94c4ddb63d87ede/32/page-frame.html',
  62. 'User-Agent': account.userAgent || 'Mozilla/5.0 (Linux; Android 16; 2211133C Build/BP2A.250605.031.A3; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/138.0.7204.180 Mobile Safari/537.36 XWEB/1380347 MMWEBSDK/20250202 MMWEBID/1020 wxwork/5.0.6.66174 MicroMessenger/8.0.28.48(0x28001c30) MiniProgramEnv/android Luggage/3.0.2.95ef3f83 NetType/WIFI Language/zh_CN ABI/arm64'
  63. }
  64. const apiRes = await axios.post(
  65. 'https://lepao.ctbu.edu.cn/v3/api.php/Run2/beforeRunV260',
  66. form,
  67. { headers, proxy: false }
  68. )
  69. let result = apiRes.data
  70. if (result?.data && result?.is_encrypt === 1) {
  71. result.data = JSON.parse(dataDecrypt(result.data))
  72. }
  73. const info = result?.info || result?.msg || '系统繁忙,请稍后再试'
  74. const updateTime = Date.now()
  75. // 登录失效:更新 state=0
  76. if (String(info).includes('重新登录') || Number(result?.status) === 101) {
  77. await db.query('UPDATE lepao_account SET state = 0, update_time = ? WHERE student_num = ? AND create_user = ?', [updateTime, student_num, uuid])
  78. return res.json({
  79. ...BaseStdResponse.ERR,
  80. msg: info
  81. })
  82. }
  83. if (!result || Number(result.status) !== 1 || !result.data) {
  84. return res.json({
  85. ...BaseStdResponse.ERR,
  86. msg: info
  87. })
  88. }
  89. const term_num = Number(result.data.term_num ?? 0)
  90. const total_num = Number(result.data.total_num ?? 30)
  91. const updateRows = await db.query(
  92. 'UPDATE lepao_account SET term_num = ?, total_num = ?, state = 1, update_time = ? WHERE student_num = ? AND create_user = ?',
  93. [term_num, total_num, updateTime, student_num, uuid]
  94. )
  95. if (!updateRows || updateRows.affectedRows !== 1) {
  96. return res.json({
  97. ...BaseStdResponse.DATABASE_ERR
  98. })
  99. }
  100. return res.json({
  101. ...BaseStdResponse.OK,
  102. data: {
  103. term_num,
  104. total_num,
  105. state: 1
  106. }
  107. })
  108. } catch (error) {
  109. this.logger.error(`用户自助同步乐跑账号失败: ${error.stack || error}`)
  110. return res.json({
  111. ...BaseStdResponse.ERR,
  112. msg: '同步失败,请稍后再试'
  113. })
  114. }
  115. }
  116. }
  117. module.exports.UpdateSelfAccount = UpdateSelfAccount