GetArticle.js 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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 GetArticle extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Admin/Article');
  9. this.setMethod('GET');
  10. }
  11. async onRequest(req, res) {
  12. let { uuid, session, id } = req.query;
  13. if ([uuid, session, id].some(value => value === '' || value === null || value === 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
  22. a.id,
  23. a.slug,
  24. a.title,
  25. a.cover,
  26. a.describe,
  27. a.content,
  28. a.type,
  29. a.state,
  30. a.views,
  31. a.time,
  32. u.username AS author
  33. FROM article a
  34. LEFT JOIN users u ON a.author = u.uuid
  35. WHERE a.id = ?
  36. `;
  37. try {
  38. const rows = await db.query(sql, [id]);
  39. if (!rows || rows.length !== 1)
  40. return res.json({ ...BaseStdResponse.MISSING_FILE, msg: '文章不存在' });
  41. res.json({
  42. ...BaseStdResponse.OK,
  43. data: rows[0]
  44. });
  45. } catch (err) {
  46. this.logger.error(`获取文章失败!${err.stack}`);
  47. res.json({ ...BaseStdResponse.ERR, msg: '获取文章失败!' });
  48. }
  49. }
  50. }
  51. module.exports.GetArticle = GetArticle;