rsshub
Version:
Make RSS Great Again!
66 lines (52 loc) • 1.89 kB
text/typescript
import { Route } from '@/types';
import ofetch from '@/utils/ofetch';
import InvalidParameterError from '@/errors/types/invalid-parameter';
import { rootUrl, apiRootUrl, parseResult, parseArticle } from './utils';
export const route: Route = {
path: '/topic/:topic?',
categories: ['new-media'],
example: '/utgd/topic/在线阅读专栏',
parameters: { topic: '专题,默认为在线阅读专栏' },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false,
},
radar: [
{
source: ['utgd.net/topic', 'utgd.net/'],
target: '/topic/:topic',
},
],
name: '专题',
maintainers: ['nczitzk'],
handler,
url: 'utgd.net/topic',
description: `| 在线阅读专栏 | 卡片笔记专题 |
| ------------ | ------------ |
更多专栏请见 [专题广场](https://utgd.net/topic)`,
};
async function handler(ctx) {
const topic = ctx.req.param('topic') ?? '在线阅读专栏';
const limit = ctx.req.query('limit') ? Number.parseInt(ctx.req.query('limit')) : 20;
const currentUrl = `${rootUrl}/topic`;
const topicUrl = `${apiRootUrl}/api/v2/topic/`;
let response = await ofetch(topicUrl);
const topicItem = response.find((i) => i.title === topic);
if (!topicItem) {
throw new InvalidParameterError(`No topic named ${topic}`);
}
const apiUrl = `${rootUrl}/api/v2/topic/${topicItem.id}/article/`;
response = await ofetch(apiUrl);
const list = parseResult(response.results, limit);
const items = await Promise.all(list.map((item) => parseArticle(item)));
return {
title: `UNTAG - ${topicItem.title}`,
link: currentUrl,
item: items,
description: topicItem.summary,
};
}