rsshub
Version:
Make RSS Great Again!
51 lines (44 loc) • 1.72 kB
text/typescript
import { Route } from '@/types';
import cache from '@/utils/cache';
import got from '@/utils/got';
import { baseUrl, getBuildId, parseList, parseItem } from './utils';
export const route: Route = {
path: '/topic/:topicId/:lang?',
categories: ['finance'],
example: '/followin/topic/40',
parameters: { topicId: 'Topic ID, can be found in URL', lang: 'Language, see table above, `en` by default' },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false,
},
radar: [
{
source: ['followin.io/:lang/topic/:topicId', 'followin.io/topic/:topicId'],
},
],
name: 'Topic',
maintainers: ['TonyRL'],
handler,
};
async function handler(ctx) {
const { topicId, lang = 'en' } = ctx.req.param();
const { limit = 20 } = ctx.req.query();
const buildId = await getBuildId(cache.tryGet);
const { data: response } = await got(`${baseUrl}/_next/data/${buildId}/${lang}/topic/${topicId}.json`);
const { queries } = response.pageProps.dehydratedState;
const { data: topicInfo } = queries.find((q) => q.queryKey[0] === '/topic/info').state;
const list = parseList(queries.find((q) => q.queryKey[0] === '/feed/list/topic').state.data.pages[0].list.slice(0, limit), lang, buildId);
const items = await Promise.all(list.map((item) => parseItem(item, cache.tryGet)));
return {
title: `${topicInfo.title} - Followin`,
description: topicInfo.desc,
link: `${baseUrl}/${lang}/topic/${topicId}`,
image: topicInfo.logo,
language: lang,
item: items,
};
}