| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- const API = require("../../../../lib/API");
- const db = require("../../../../plugin/DataBase/db");
- const AccessControl = require("../../../../lib/AccessControl");
- const { BaseStdResponse } = require("../../../../BaseStdResponse");
- class AdminArticleCategoryDelete extends API {
- constructor() {
- super();
- this.setPath('/Admin/Article/Category');
- this.setMethod('DELETE');
- }
- async onRequest(req, res) {
- const { uuid, session, id } = req.body;
- if ([uuid, session, id].some(v => v === '' || v === null || v === undefined))
- return res.json({ ...BaseStdResponse.MISSING_PARAMETER });
- if (!await AccessControl.checkSession(uuid, session))
- return res.status(401).json({ ...BaseStdResponse.ACCESS_DENIED });
- const permission = await AccessControl.getPermission(uuid);
- if (!permission.includes('admin') && !permission.includes('article'))
- return res.json({ ...BaseStdResponse.PERMISSION_DENIED });
- try {
- const cat = await db.query('SELECT slug FROM article_category WHERE id = ?', [id]);
- if (!cat || cat.length === 0)
- return res.json({ ...BaseStdResponse.ERR, msg: '分类不存在' });
- const count = await db.query('SELECT COUNT(*) AS total FROM article WHERE type = ?', [cat[0].slug]);
- if (count && count[0].total > 0)
- return res.json({ ...BaseStdResponse.ERR, msg: '该分类下仍有文章,无法删除' });
- const r = await db.query('DELETE FROM article_category WHERE id = ?', [id]);
- if (!r || r.affectedRows === 0)
- return res.json({ ...BaseStdResponse.ERR, msg: '删除分类失败' });
- return res.json({ ...BaseStdResponse.OK });
- } catch (err) {
- this.logger.error(`删除文章分类失败!${err.stack}`);
- res.json({ ...BaseStdResponse.ERR, msg: '删除文章分类失败!' });
- }
- }
- }
- module.exports.AdminArticleCategoryDelete = AdminArticleCategoryDelete;
|