UpdateAccount.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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')
  5. const config = require('../../config.json')
  6. const { BaseStdResponse } = require("../../BaseStdResponse.js")
  7. // 客户端上传数据接口
  8. class UpdateAccount extends API {
  9. constructor() {
  10. super();
  11. this.setPath('/Lepao/UpdateAccount')
  12. this.setMethod('POST')
  13. }
  14. async onRequest(req, res) {
  15. let { data } = req.body
  16. if ([data].some(value => value === '' || value === null || value === undefined))
  17. return res.json({
  18. ...BaseStdResponse.MISSING_PARAMETER,
  19. endpoint: 1513126
  20. })
  21. try {
  22. const endpoint = config.runpy + '/decrypted_data'
  23. const resData = await axios.post(endpoint, { data })
  24. const userData = resData.data
  25. if (userData?.code !== 200 || !userData.data)
  26. return res.json({
  27. ...BaseStdResponse.ERR,
  28. msg: '无法解析用户数据,请重试'
  29. })
  30. const { uid, student_num, school_id, token } = userData.data
  31. if ([uid, student_num, school_id, token].some(value => value === '' || value === null || value === undefined))
  32. return res.json({
  33. ...BaseStdResponse.ERR,
  34. msg: '未提取出用户登录信息,请重试'
  35. })
  36. let findSql = 'SELECT email, name FROM lepao_account WHERE student_num = ?'
  37. let findRows = await db.query(findSql, [student_num])
  38. if (!findRows)
  39. return res.json({
  40. ...BaseStdResponse.ERR,
  41. msg: '无法解析用户数据,请重试'
  42. })
  43. if(findRows.length === 0)
  44. return res.json({
  45. ...BaseStdResponse.ERR,
  46. msg: '该乐跑账号尚未在RunForge系统中添加,请先前往 https://lepao.ctbu.top/ 添加你的账户'
  47. })
  48. let updateSql = 'UPDATE lepao_account SET uid = ?, token = ?, school_id = ?, state = 1 WHERE student_num = ?'
  49. let updateRows = await db.query(updateSql, [uid, token, school_id, student_num])
  50. if(updateRows && updateRows.affectedRows > 0) {
  51. res.json({
  52. ...BaseStdResponse.OK,
  53. data: {
  54. name: findRows[0].name,
  55. account: student_num
  56. }
  57. })
  58. let emailData = {
  59. name: findRows[0].name,
  60. account: student_num
  61. }
  62. await EmailTemplate.updateSuccess(findRows[0].email, emailData)
  63. }
  64. } catch (error) {
  65. }
  66. }
  67. }
  68. module.exports.UpdateAccount = UpdateAccount;