rsshub
Version:
Make RSS Great Again!
92 lines (90 loc) • 3.71 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 path from "node:path";
import { load } from "cheerio";
//#region lib/routes/logclub/report.ts
init_esm_shims();
const route = {
path: ["/lc_report/:id?", "/report/:id?"],
categories: ["new-media"],
example: "/logclub/lc_report",
parameters: { id: "报告 id,见下表,默认为罗戈研究出品" },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false
},
name: "报告",
maintainers: ["nczitzk"],
handler,
description: `| 罗戈研究出品 | 物流报告 | 绿色双碳报告 |
| ------------ | -------------- | --------------------- |
| Report | IndustryReport | GreenDualCarbonReport |`
};
async function handler(ctx) {
const { id = "Report" } = ctx.req.param();
const limit = ctx.req.query("limit") ? Number.parseInt(ctx.req.query("limit"), 10) : 11;
const rootUrl = "https://www.logclub.com";
const currentUrl = new URL("lc_report", rootUrl).href;
const apiUrl = new URL(`front/lc_report/load${id}List`, rootUrl).href;
const { data: response } = await got_default.post(apiUrl, { json: { page: 1 } });
let items = response.list.slice(0, limit).map((item) => ({
title: item.title,
link: new URL(`front/lc_report/get_report_info/${item.id}`, rootUrl).href,
description: art(path.join(__dirname, "templates/description-b417c82f.art"), { image: {
src: item.img_url?.split(/\?/)[0] ?? void 0,
alt: item.title
} }),
author: item.author,
category: [item.channel_name],
guid: `logclub-report-${item.id}`,
pubDate: timezone(parseDate(item.release_time), 8)
}));
items = await Promise.all(items.map((item) => cache_default.tryGet(item.link, async () => {
const { data: detailResponse } = await got_default(item.link);
const content = load(detailResponse);
content("img").each((_, el) => {
el = content(el);
el.replaceWith(art(path.join(__dirname, "templates/description-b417c82f.art"), { image: {
src: el.prop("src")?.split(/\?/)[0] ?? void 0,
alt: el.prop("title")
} }));
});
item.title = content("h1").first().text();
item.description += art(path.join(__dirname, "templates/description-b417c82f.art"), { description: content("div.article-cont").html() });
item.author = content("div.lc-infos a").toArray().map((a) => content(a).text()).join("/");
item.category = [...new Set([...item.category ?? [], ...content("div.article-label-r a.label").toArray().map((c) => content(c).text())])].filter(Boolean);
return item;
})));
const { data: currentResponse } = await got_default(currentUrl);
const $ = load(currentResponse);
const title = $("div.this_nav").text().trim();
const icon = new URL($("link[rel=\"shortcut icon\"]").prop("href"), rootUrl).href;
const subtitle = $("meta[name=\"keywords\"]").prop("content");
return {
item: items,
title: `${$("title").text()}${title}`,
link: currentUrl,
description: $("meta[name=\"description\"]").prop("content"),
language: "zh",
image: new URL($("div.logo_img img").prop("src"), rootUrl).href,
icon,
logo: icon,
subtitle: subtitle.replaceAll(",", ""),
author: subtitle.split(/,/)[0]
};
}
//#endregion
export { route };