UpdateAccountAndroidApp.js 6.0 KB

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