ChangeAutoRun.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. const API = require("../../lib/API.js");
  2. const db = require("../../plugin/DataBase/db.js");
  3. const { BaseStdResponse } = require("../../BaseStdResponse.js");
  4. const AccessControl = require("../../lib/AccessControl.js");
  5. class ChangeAutoRun extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Lepao/ChangeAutoRun')
  9. this.setMethod('GET')
  10. }
  11. async onRequest(req, res) {
  12. let { uuid, session, id } = req.query
  13. if ([uuid, session, id].some(value => value === '' || value === null || value === undefined))
  14. return res.json({
  15. ...BaseStdResponse.MISSING_PARAMETER
  16. });
  17. if (!await AccessControl.checkSession(uuid, session))
  18. return res.status(401).json({
  19. ...BaseStdResponse.ACCESS_DENIED
  20. })
  21. let selectSql = 'SELECT create_user, target_count, total_num, auto_run FROM lepao_account WHERE id = ?'
  22. let selectRows = await db.query(selectSql, [id])
  23. if (!selectRows || selectRows.length === 0)
  24. return res.json({
  25. ...BaseStdResponse.ERR,
  26. msg: '切换自动乐跑状态失败!未找到账户信息'
  27. })
  28. if (selectRows[0].create_user !== uuid) {
  29. let permission = await AccessControl.getPermission(uuid)
  30. if (!permission.includes("admin") && !permission.includes("service"))
  31. return res.json({
  32. ...BaseStdResponse.ERR,
  33. msg: '切换自动乐跑状态失败!未找到账户信息'
  34. })
  35. }
  36. if (selectRows[0].auto_run === 0 && (selectRows[0].target_count <= selectRows[0].total_num)) {
  37. return res.json({
  38. ...BaseStdResponse.ERR,
  39. msg: '该账号累计跑步次数已达到预设目标次数,请尝试增大目标次数后再试'
  40. })
  41. }
  42. let sql = 'UPDATE lepao_account SET auto_run = 1 - auto_run WHERE id = ?';
  43. try {
  44. let r = await db.query(sql, [id]);
  45. if (r && r.affectedRows > 0) {
  46. res.json({
  47. ...BaseStdResponse.OK
  48. })
  49. } else {
  50. res.json({
  51. ...BaseStdResponse.ERR,
  52. msg: '切换自动乐跑状态失败!未找到对应数据或数据库未更新'
  53. })
  54. }
  55. } catch (err) {
  56. this.logger.error(`切换自动乐跑状态失败!${err.stack}`);
  57. res.json({
  58. ...BaseStdResponse.ERR,
  59. msg: "切换自动乐跑状态失败!数据库异常"
  60. });
  61. }
  62. }
  63. }
  64. module.exports.ChangeAutoRun = ChangeAutoRun;