List.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  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 AdminArticleCategoryList extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Admin/Article/Category/List');
  9. this.setMethod('GET');
  10. }
  11. async onRequest(req, res) {
  12. const { uuid, session } = req.query;
  13. if ([uuid, session].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. const sql = `
  21. SELECT id, name, slug, icon, sort_order, is_active, created_at
  22. FROM article_category
  23. ORDER BY sort_order ASC, id ASC
  24. `;
  25. try {
  26. const rows = await db.query(sql);
  27. res.json({ ...BaseStdResponse.OK, data: rows || [] });
  28. } catch (err) {
  29. this.logger.error(`获取文章分类列表失败!${err.stack}`);
  30. res.json({ ...BaseStdResponse.ERR, msg: '获取文章分类列表失败!' });
  31. }
  32. }
  33. }
  34. module.exports.AdminArticleCategoryList = AdminArticleCategoryList;