Delete.js 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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 AdminArticleCategoryDelete extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Admin/Article/Category');
  9. this.setMethod('DELETE');
  10. }
  11. async onRequest(req, res) {
  12. const { uuid, session, id } = req.body;
  13. if ([uuid, session, id].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('article'))
  19. return res.json({ ...BaseStdResponse.PERMISSION_DENIED });
  20. try {
  21. const cat = await db.query('SELECT slug FROM article_category WHERE id = ?', [id]);
  22. if (!cat || cat.length === 0)
  23. return res.json({ ...BaseStdResponse.ERR, msg: '分类不存在' });
  24. const count = await db.query('SELECT COUNT(*) AS total FROM article WHERE type = ?', [cat[0].slug]);
  25. if (count && count[0].total > 0)
  26. return res.json({ ...BaseStdResponse.ERR, msg: '该分类下仍有文章,无法删除' });
  27. const r = await db.query('DELETE FROM article_category WHERE id = ?', [id]);
  28. if (!r || r.affectedRows === 0)
  29. return res.json({ ...BaseStdResponse.ERR, msg: '删除分类失败' });
  30. return res.json({ ...BaseStdResponse.OK });
  31. } catch (err) {
  32. this.logger.error(`删除文章分类失败!${err.stack}`);
  33. res.json({ ...BaseStdResponse.ERR, msg: '删除文章分类失败!' });
  34. }
  35. }
  36. }
  37. module.exports.AdminArticleCategoryDelete = AdminArticleCategoryDelete;