rsshub
Version:
Make RSS Great Again!
89 lines (87 loc) • 3.29 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 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 invalid_parameter_default } from "./invalid-parameter-rr4AgGpp.mjs";
import { t as isValidHost } from "./valid-host-C-u5eW3j.mjs";
import path from "node:path";
import { load } from "cheerio";
//#region lib/routes/myfigurecollection/index.ts
init_esm_shims();
const shortcuts = {
potd: "picture/browse/potd/",
potw: "picture/browse/potw/",
potm: "picture/browse/potm/"
};
const route = {
path: "/:category?/:language?",
categories: ["shopping"],
example: "/myfigurecollection/potd",
parameters: {
category: "分类,默认为每日圖片",
language: "语言,见上表,默认为空,即 `en`"
},
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false
},
radar: [{ source: ["zh.myfigurecollection.net/browse", "zh.myfigurecollection.net/"] }],
name: "圖片",
maintainers: ["nczitzk"],
handler,
url: "zh.myfigurecollection.net/browse",
description: `| 每日圖片 | 每週圖片 | 每月圖片 |
| -------- | -------- | -------- |
| potd | potw | potm |`
};
async function handler(ctx) {
const language = ctx.req.param("language") ?? "";
const category = ctx.req.param("category") ?? "figure";
if (language && !isValidHost(language)) throw new invalid_parameter_default("Invalid language");
const rootUrl = `https://${language === "en" || language === "" ? "" : `${language}.`}myfigurecollection.net`;
const currentUrl = `${rootUrl}/${Object.hasOwn(shortcuts, category) ? shortcuts[category] : category}`;
const $ = load((await got_default({
method: "get",
url: currentUrl
})).data);
let items = $(".item-icon, .picture-icon").slice(0, ctx.req.query("limit") ? Number.parseInt(ctx.req.query("limit")) : 25).toArray().map((item) => {
item = $(item).find("a");
const link = item.attr("href");
return { link: link.startsWith("http") ? link : `${rootUrl}${link}` };
});
items = await Promise.all(items.map((item) => cache_default.tryGet(item.link, async () => {
try {
const content = load((await got_default({
method: "get",
url: item.link
})).data);
item.title = content(".headline").text();
item.description = art(path.join(__dirname, "templates/description-49fdbaa3.art"), {
pictures: /myfigurecollection\.net\/picture\//.test(item.link) ? [{ src: content("meta[property=\"og:image\"]").attr("content") }] : JSON.parse(decodeURIComponent(content("meta[name=\"pictures\"]").attr("content"))),
fields: content(".form-field").toArray().map((f) => ({
key: content(f).find(".form-label").text(),
value: content(f).find(".form-input").text()
}))
});
} catch {
item.title = `Item #${item.link.split("/").pop()}`;
}
return item;
})));
return {
title: $("title").text().replace(/ \(.*\)/, ""),
link: currentUrl,
item: items
};
}
//#endregion
export { route };