UNPKG

rsshub

Version:
112 lines (110 loc) 4.81 kB
import { n as init_esm_shims, t as __dirname } from "./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 art } from "./render-BQo6B4tL.mjs"; import { t as got_default } from "./got-KxxWdaxq.mjs"; import { t as timezone } from "./timezone-D8cuwzTY.mjs"; import { t as invalid_parameter_default } from "./invalid-parameter-rr4AgGpp.mjs"; import { t as config_not_found_default } from "./config-not-found-Dyp3RlZZ.mjs"; import path from "node:path"; import { load } from "cheerio"; //#region lib/routes/kyodonews/index.ts init_esm_shims(); const resolveRelativeLink = (link, baseUrl) => link.startsWith("http") ? link : `${baseUrl}${link}`; const route = { path: "/:language?/:keyword?", categories: ["traditional-media"], example: "/kyodonews", parameters: { language: "语言: `china` = 简体中文 (默认), `tchina` = 繁體中文", keyword: "关键词" }, features: { requireConfig: false, requirePuppeteer: false, antiCrawler: false, supportBT: false, supportPodcast: false, supportScihub: false }, name: "最新报道", maintainers: ["Rongronggg9"], handler, description: `\`keyword\` 为关键词,由于共同网有许多关键词并不在主页列出,此处不一一列举,可从关键词页的 URL 的最后一级路径中提取。如 \`日中关系\` 的关键词页 URL 为 \`https://china.kyodonews.net/news/japan-china_relationship\`, 则将 \`japan-china_relationship\` 填入 \`keyword\`。特别地,当填入 \`rss\` 时,将从共同网官方 RSS 中抓取文章;略去时,将从首页抓取最新报道 (注意:首页更新可能比官方 RSS 稍慢)。` }; async function handler(ctx) { const language = ctx.req.param("language") ?? "china"; const keyword = ctx.req.param("keyword") === "RSS" ? "rss" : ctx.req.param("keyword") ?? ""; if (!["china", "tchina"].includes(language)) throw new config_not_found_default("Invalid language"); const rootUrl = `https://${language}.kyodonews.net`; const currentUrl = `${rootUrl}/${keyword ? keyword === "rss" ? "rss/news.xml" : `news/${keyword}` : ""}`; let response; try { response = await got_default(currentUrl); } catch (error) { throw error.response && error.response.statusCode === 404 ? new invalid_parameter_default("Invalid keyword") : error; } const $ = load(response.data, { xmlMode: keyword === "rss" }); let title, description, image, items; image = `${rootUrl}/apple-touch-icon-180x180.png`; if (keyword === "rss") { title = $("channel > title").text(); description = $("channel > description").text(); items = $("item").toArray().map((item) => { return { link: $(item).find("link").text() }; }); } else { title = $("head > title").text(); description = $("meta[name=\"description\"]").attr("content"); image = resolveRelativeLink($("head > link[rel=\"apple-touch-icon\"]").attr("href"), rootUrl) || image; items = $("div.sec-latest > ul > li").toArray().map((item) => { item = $(item); return { link: resolveRelativeLink(item.find("a").attr("href"), rootUrl) }; }); } items = await Promise.all(items.map((item) => cache_default.tryGet(item.link, async () => { const $$1 = load((await got_default(item.link)).data); item.title = $$1("head > title").text(); item.author = $$1("meta[name=\"author\"]").attr("content"); const mainPicArea = $$1("div.mainpic"); mainPicArea.find("div").each((_, elem) => { elem = $$1(elem); elem.css("text-align", "center"); }); mainPicArea.find("img").each((_, img) => { img = $$1(img); img.attr("src", img.attr("data-src")); img.removeAttr("data-src"); img.wrap("<div>"); }); let mainPic = mainPicArea.html(); mainPic = mainPic ? mainPic.trim() : ""; let articleBody = $$1("div.article-body").html(); articleBody = articleBody ? articleBody.trim().replace(/(完)(?=<\/p>\s*$)/m, "") : ""; item.description = art(path.join(__dirname, "templates/article-a61942d2.art"), { mainPic, articleBody }); const ldJson = $$1("script[type=\"application/ld+json\"]").html(); const pubDate_match = ldJson && ldJson.match(/"datePublished":"([\d\s-:]*?)"/); const updated_match = ldJson && ldJson.match(/"dateModified":"([\d\s-:]*?)"/); if (pubDate_match) item.pubDate = timezone(parseDate(pubDate_match[1]), 9); if (updated_match) item.updated = timezone(parseDate(updated_match[1]), 9); item.category = $$1("p.credit > a").toArray().map((a) => $$1(a).text()); return item; }))); return { title, description, link: currentUrl, item: items, image }; } //#endregion export { route };