| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- const API = require("../../lib/API");
- const db = require("../../plugin/DataBase/db");
- const { BaseStdResponse } = require("../../BaseStdResponse");
- class GetArticle extends API {
- constructor() {
- super();
- this.setPath('/Article');
- this.setMethod('GET');
- }
- async onRequest(req, res) {
- const { slug } = req.query;
- if (!slug) {
- return res.json({
- ...BaseStdResponse.MISSING_PARAMETER,
- endpoint: 153123
- });
- }
- const safeSlug = String(slug).trim();
- try {
- await db.query('UPDATE article SET views = views + 1 WHERE state = 1 AND slug = ?', [safeSlug]);
- const sql = `
- SELECT
- a.slug,
- a.title,
- a.cover,
- a.\`describe\`,
- a.content,
- a.type,
- a.views,
- a.time,
- u.username AS author
- FROM article a
- LEFT JOIN users u ON a.author = u.uuid
- WHERE a.state = 1 AND a.slug = ?
- `;
- const rows = await db.query(sql, [safeSlug]);
- if (!rows || rows.length !== 1)
- return res.json({
- ...BaseStdResponse.MISSING_FILE,
- msg: '文章不存在或无查看权限'
- });
- res.json({
- ...BaseStdResponse.OK,
- data: rows[0]
- });
- } catch (err) {
- this.logger.error(`获取文章失败!${err.stack}`);
- res.json({
- ...BaseStdResponse.ERR,
- msg: '获取文章失败!'
- });
- }
- }
- }
- module.exports.GetArticle = GetArticle;
|