AddRule.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. const API = require("../../../lib/API");
  2. const db = require("../../../plugin/DataBase/db");
  3. const AccessControl = require("../../../lib/AccessControl");
  4. const { BaseStdResponse } = require("../../../BaseStdResponse");
  5. class AddRule extends API {
  6. constructor() {
  7. super()
  8. this.setPath('/IC/Rule')
  9. this.setMethod('POST')
  10. }
  11. async onRequest(req, res) {
  12. let {
  13. uuid,
  14. session,
  15. id,
  16. name,
  17. loop,
  18. mode,
  19. day_of_week,
  20. state,
  21. users,
  22. beginTime,
  23. endTime
  24. } = req.body
  25. if ([uuid, session, name, loop, mode, users, beginTime, endTime].some(value => value === '' || value === null || value === undefined) || (loop && !day_of_week))
  26. return res.json({
  27. ...BaseStdResponse.MISSING_PARAMETER
  28. })
  29. // 检查 session
  30. if (!await AccessControl.checkSession(uuid, session))
  31. return res.status(401).json({
  32. ...BaseStdResponse.ACCESS_DENIED
  33. })
  34. let sql, r
  35. const time = new Date().getTime()
  36. if (!id) {
  37. sql = 'INSERT INTO ic_rule (\`name\`, create_user, create_time, \`loop\`, \`mode\`, day_of_week, users, beginTime, endTime) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)'
  38. r = await db.query(sql, [name, uuid, time, loop, mode, day_of_week, users, beginTime, endTime])
  39. } else {
  40. // 确保只有一个规则生效
  41. // if(state == 1) {
  42. // sql = 'UPDATE ic_rule SET \`state\` = 0 WHERE create_user = ?'
  43. // await db.query(sql, [uuid])
  44. // }
  45. sql = 'UPDATE ic_rule SET \`name\` = ?, \`loop\` = ?, \`mode\` = ?, day_of_week = ?, update_time = ?, \`state\` = ?, users = ?, beginTime = ?, endTime = ? WHERE id = ? AND create_user = ?'
  46. r = await db.query(sql, [name, loop, mode, day_of_week, time, state, users, beginTime, endTime, id, uuid])
  47. }
  48. try {
  49. if (r && r.affectedRows > 0) {
  50. res.json({
  51. ...BaseStdResponse.OK
  52. })
  53. } else {
  54. res.json({ ...BaseStdResponse.ERR, endpoint: 7894378, msg: '添加规则失败!数据库错误' })
  55. }
  56. } catch (err) {
  57. this.logger.error(`添加规则失败!${err.stack}`)
  58. res.json({
  59. ...BaseStdResponse.ERR,
  60. msg: "添加规则失败!",
  61. });
  62. }
  63. }
  64. }
  65. module.exports.AddRule = AddRule;