DeleteAccount.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. const API = require("../../../lib/API");
  2. const db = require("../../../plugin/DataBase/db");
  3. const Redis = require("../../../plugin/DataBase/Redis");
  4. const jkesRedisKeys = require("../../../plugin/jkes/redisKeys");
  5. const AccessControl = require("../../../lib/AccessControl");
  6. const { BaseStdResponse } = require("../../../BaseStdResponse");
  7. class DeleteAccount extends API {
  8. constructor() {
  9. super();
  10. this.setPath('/Lepao/Account')
  11. this.setMethod('DELETE')
  12. }
  13. async onRequest(req, res) {
  14. let { uuid, session, id } = req.body
  15. if ([uuid, session, id].some(value => value === '' || value === null || value === undefined))
  16. return res.json({
  17. ...BaseStdResponse.MISSING_PARAMETER
  18. })
  19. // 检查 session
  20. if (!await AccessControl.checkSession(uuid, session))
  21. return res.status(401).json({
  22. ...BaseStdResponse.ACCESS_DENIED
  23. })
  24. let selectSql = 'SELECT create_user FROM lepao_account WHERE id = ?'
  25. let selectRows = await db.query(selectSql, [id])
  26. if (!selectRows || selectRows.length === 0)
  27. return res.json({
  28. ...BaseStdResponse.ERR,
  29. msg: '解绑账号失败!未找到账户信息'
  30. })
  31. if (selectRows[0].create_user !== uuid) {
  32. let permission = await AccessControl.getPermission(uuid)
  33. if (!permission.includes("admin") && !permission.includes("service"))
  34. return res.json({
  35. ...BaseStdResponse.ERR,
  36. msg: '解绑账号失败!未找到账户信息'
  37. })
  38. }
  39. let snRows = await db.query('SELECT student_num FROM lepao_account WHERE id = ?', [id])
  40. const sn = snRows?.[0]?.student_num
  41. let sql = 'UPDATE lepao_account SET create_user = NULL, auto_run = 0 WHERE id = ?'
  42. let r = await db.query(sql, [id])
  43. try {
  44. if (r && r.affectedRows > 0) {
  45. if (sn) {
  46. try {
  47. await Redis.del(jkesRedisKeys.runnerFlag(sn))
  48. } catch (e) {
  49. this.logger.error(`解绑清理 jkes_runner 失败 ${sn}: ${e.message || e}`)
  50. }
  51. }
  52. res.json({
  53. ...BaseStdResponse.OK
  54. })
  55. } else {
  56. return res.json({
  57. ...BaseStdResponse.ERR,
  58. msg: '解绑账号失败!数据库错误'
  59. })
  60. }
  61. } catch (err) {
  62. this.logger.error(`解绑账号失败!${err.stack}`)
  63. res.json({
  64. ...BaseStdResponse.ERR,
  65. msg: "解绑账号失败!",
  66. });
  67. }
  68. }
  69. }
  70. module.exports.DeleteAccount = DeleteAccount