Upsert.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. const API = require("../../../lib/API.js")
  2. const db = require("../../../plugin/DataBase/db.js")
  3. const AccessControl = require("../../../lib/AccessControl.js")
  4. const { BaseStdResponse } = require("../../../BaseStdResponse.js")
  5. class AdminNoticeUpsert extends API {
  6. constructor() {
  7. super()
  8. this.setPath('/Admin/Notice')
  9. this.setMethod('POST')
  10. }
  11. async onRequest(req, res) {
  12. const { uuid, session, key, content } = req.body
  13. if ([uuid, session, key, content].some(v => v === '' || v === null || v === undefined))
  14. return res.json({ ...BaseStdResponse.MISSING_PARAMETER })
  15. if (!await AccessControl.checkSession(uuid, session))
  16. return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED })
  17. const permission = await AccessControl.getPermission(uuid)
  18. if (!permission.includes("admin") && !permission.includes("service") && !permission.includes("server"))
  19. return res.json({ ...BaseStdResponse.PERMISSION_DENIED })
  20. const safeKey = String(key).trim()
  21. if (!safeKey) return res.json({ ...BaseStdResponse.ERR, msg: '公告标识不能为空' })
  22. const sql = `
  23. INSERT INTO notice (\`key\`, content)
  24. VALUES (?, ?)
  25. ON DUPLICATE KEY UPDATE content = VALUES(content)
  26. `
  27. const rows = await db.query(sql, [safeKey, String(content)])
  28. if (!rows) return res.json({ ...BaseStdResponse.DATABASE_ERR })
  29. return res.json({ ...BaseStdResponse.OK })
  30. }
  31. }
  32. module.exports.AdminNoticeUpsert = AdminNoticeUpsert