UpdateAccount.js 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. const API = require("../../../lib/API.js")
  2. const db = require("../../../plugin/DataBase/db.js")
  3. const axios = require('axios')
  4. const EmailTemplate = require('../../../plugin/Email/emailTemplate.js')
  5. const config = require('../../../config.json')
  6. const lepao = require("../../../lib/Lepao/Lepao.js").lepao
  7. const { BaseStdResponse } = require("../../../BaseStdResponse.js")
  8. // 客户端上传数据接口
  9. class UpdateAccount extends API {
  10. constructor() {
  11. super()
  12. this.runpy = config.runpy
  13. this.noEncrypt()
  14. this.setPath('/Lepao/UpdateAccount')
  15. this.setMethod('POST')
  16. }
  17. async onRequest(req, res) {
  18. let { reqData, resData } = req.body
  19. if ([reqData, resData].some(value => value === '' || value === null || value === undefined))
  20. return res.json({
  21. ...BaseStdResponse.MISSING_PARAMETER
  22. })
  23. try {
  24. const endpoint = config.runpy + '/decrypted_data'
  25. const ReqData = await axios.post(endpoint, { data: reqData })
  26. let userData = ReqData.data
  27. if (userData?.code !== 200 || !userData.data)
  28. return res.json({
  29. ...BaseStdResponse.ERR,
  30. msg: '无法解析用户数据,请重试'
  31. })
  32. const { token } = userData.data
  33. if ([token].some(value => value === '' || value === null || value === undefined))
  34. return res.json({
  35. ...BaseStdResponse.ERR,
  36. msg: '未提取出用户登录信息,请重试'
  37. })
  38. const ResData = await axios.post(endpoint, { data: resData })
  39. let userData2 = ResData.data
  40. if (userData2?.code !== 200 || !userData2.data)
  41. return res.json({
  42. ...BaseStdResponse.ERR,
  43. msg: '无法解析用户数据,请重试'
  44. })
  45. const { uid, user_avatar, student_num, school_id, grade_id, class_id, sex, name, academy_name } = userData2.data
  46. if ([uid, student_num, school_id, grade_id, class_id, sex, name, academy_name].some(value => value === '' || value === null || value === undefined))
  47. return res.json({
  48. ...BaseStdResponse.ERR,
  49. msg: '未提取出用户登录信息,请重试'
  50. })
  51. let findSql = 'SELECT email, create_user, auto_run FROM lepao_account WHERE student_num = ? AND create_user IS NOT NULL'
  52. let findRows = await db.query(findSql, [student_num])
  53. if (!findRows)
  54. return res.json({
  55. ...BaseStdResponse.ERR,
  56. msg: '无法解析用户数据,请重试'
  57. })
  58. if (findRows.length === 0)
  59. return res.json({
  60. ...BaseStdResponse.ERR,
  61. msg: '该乐跑账号尚未在RunForge系统中添加,请先前往 https://xxoo365.top/ 添加你的账户'
  62. })
  63. const time = new Date().getTime()
  64. let updateSql = 'UPDATE lepao_account SET uid = ?, token = ?, school_id = ?, name = ?, grade_id = ?, class_id = ?, sex = ?, academy_name = ?, update_time = ?, user_avatar = ?, state = 1 WHERE student_num = ?'
  65. let updateRows = await db.query(updateSql, [uid, token, school_id, name, grade_id, class_id, sex, academy_name, time, user_avatar ?? 'https://lepao-cloud.xxoo365.top/view.php/25aa126dc406974ff3579a99a2c6501a.png', student_num])
  66. if (updateRows && updateRows.affectedRows > 0) {
  67. let msg
  68. if(findRows[0].auto_run === 1) {
  69. msg = `当前已开启自动乐跑,系统随后将自动进行乐跑。后续通知将发送到您的邮箱:${findRows[0].email}。请留意邮箱提醒。`
  70. }
  71. else {
  72. msg = `当前未开启自动乐跑,如需进行乐跑,请前往 RunForge 手动执行乐跑操作。后续通知将发送到您的邮箱:${findRows[0].email},请留意邮箱提醒。`
  73. }
  74. res.json({
  75. ...BaseStdResponse.OK,
  76. data: {
  77. name,
  78. academy_name,
  79. grade_id,
  80. auto_run: findRows[0].auto_run,
  81. account: student_num,
  82. msg
  83. }
  84. })
  85. let emailData = {
  86. name,
  87. account: student_num,
  88. academy_name,
  89. grade_id,
  90. auto_run: findRows[0].auto_run
  91. }
  92. await EmailTemplate.updateSuccess(findRows[0].email, emailData)
  93. if (findRows[0].auto_run === 1) {
  94. lepao.beginLepao(findRows[0].create_user, student_num, token, uid, school_id, 1)
  95. }
  96. }
  97. // 获取新加账号中存在的路径
  98. try {
  99. let sql = 'SELECT id FROM lepao_record WHERE lepao_account = ?'
  100. let rows = await db.query(sql, [student_num])
  101. // 不是老帐号就不获取
  102. if (!rows || rows.length !== 0) return
  103. const reqData = { uid, token, school_id, student_id: student_num }
  104. this.logger.info(`开始请求获取跑步记录 uid=${uid} student_id=${student_num}`)
  105. const recordUrl = this.runpy + '/get_path_data'
  106. await axios.post(recordUrl, reqData)
  107. } catch (error) {
  108. this.logger.info(`获取跑步记录出错 ${error.stack}`)
  109. }
  110. } catch (error) {
  111. this.logger.error(`更新用户信息时出错。${error.stack}`)
  112. return res.json({
  113. ...BaseStdResponse.ERR,
  114. msg: '更新用户信息失败,请重试'
  115. })
  116. }
  117. }
  118. }
  119. module.exports.UpdateAccount = UpdateAccount;