rsshub
Version:
Make RSS Great Again!
112 lines (110 loc) • 4.81 kB
JavaScript
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 };