UNPKG

rsshub

Version:
71 lines (69 loc) 2.55 kB
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 };