rsshub
Version:
Make RSS Great Again!
71 lines (69 loc) • 2.55 kB
JavaScript
import "./esm-shims-CzJ_djXG.mjs";
import "./config-C37vj7VH.mjs";
import "./dist-BInvbO1W.mjs";
import "./logger-Czu8UMNd.mjs";
import "./ofetch-BIyrKU3Y.mjs";
import { t as parseDate } from "./parse-date-BrP7mxXf.mjs";
import { t as cache_default } from "./cache-Bo__VnGm.mjs";
import "./helpers-DxBp0Pty.mjs";
import { t as got_default } from "./got-KxxWdaxq.mjs";
import { load } from "cheerio";
//#region lib/routes/thehindu/topic.ts
const route = {
path: "/topic/:topic",
categories: ["traditional-media"],
example: "/thehindu/topic/rains",
parameters: { topic: "Topic slug, can be found in URL." },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false
},
radar: [{ source: ["thehindu.com/topic/:topic"] }],
name: "Topic",
maintainers: ["TonyRL"],
handler
};
async function handler(ctx) {
const baseUrl = "https://www.thehindu.com";
const topic = ctx.req.param("topic");
const link = `${baseUrl}/topic/${topic}/`;
const apiLink = `${baseUrl}/topic/${topic}/fragment/showmoreTag`;
const { data: response } = await got_default(link);
const { data: apiResponse } = await got_default(apiLink);
const $ = load(response);
const $api = load(apiResponse);
const list = $(".element").toArray().map((item) => {
item = $api(item);
const a = item.find(".title a");
return {
title: a.text().trim(),
link: a.attr("href"),
author: item.find(".author-name").text()
};
});
const items = await Promise.all(list.map((item) => cache_default.tryGet(item.link, async () => {
const { data: response$1 } = await got_default(item.link);
const $$1 = load(response$1);
$$1(".position-relative, .articleblock-container, .article-ad, .comments-shares").remove();
item.description = $$1(".sub-title").prop("outerHTML") + $$1("div.article-picture").html() + $$1("div[itemprop=\"articleBody\"]").html();
item.pubDate = parseDate($$1("meta[itemprop=\"datePublished\"]").attr("content"));
item.updated = parseDate($$1("meta[itemprop=\"dateModified\"]").attr("content"));
item.category = $$1("meta[property=\"article:tag\"]").toArray().map((item$1) => $$1(item$1).attr("content"));
return item;
})));
return {
title: $("head title").text().trim(),
link: `${baseUrl}/topic/${topic}/`,
image: $("meta[property=\"og:image\"]").attr("content"),
logo: $("link[rel=\"apple-touch-icon\"]").attr("href"),
icon: $("link[rel=\"icon\"]").attr("href"),
language: "en",
item: items
};
}
//#endregion
export { route };