UNPKG

rsshub

Version:
73 lines (71 loc) 2.74 kB
import "./esm-shims-CzJ_djXG.mjs"; import "./config-C37vj7VH.mjs"; import "./dist-BInvbO1W.mjs"; import "./logger-Czu8UMNd.mjs"; import "./ofetch-BIyrKU3Y.mjs"; import "./md5-C8GRvctM.mjs"; import "./helpers-DxBp0Pty.mjs"; import "./render-BQo6B4tL.mjs"; import { t as got_default } from "./got-KxxWdaxq.mjs"; import { r as utils_default } from "./utils-XRYoJEu4.mjs"; //#region lib/routes/bilibili/partion-ranking.ts const got_ins = got_default.extend({ headers: { Referer: "https://www.bilibili.com/" } }); function formatDate(now) { const year = now.getFullYear(); const month = now.getMonth() + 1; const date = now.getDate(); return year + "" + (month >= 10 ? month : "0" + month) + (date >= 10 ? date : "0" + date); } const route = { path: "/partion/ranking/:tid/:days?/:embed?", categories: ["social-media"], example: "/bilibili/partion/ranking/171/3", parameters: { tid: "分区 id, 见上方表格", days: "缺省为 7, 指最近多少天内的热度排序", embed: "默认为开启内嵌视频, 任意值为关闭" }, features: { requireConfig: false, requirePuppeteer: false, antiCrawler: false, supportBT: false, supportPodcast: false, supportScihub: false }, name: "分区视频排行榜", maintainers: ["lengthmin"], handler }; async function handler(ctx) { const tid = ctx.req.param("tid"); const days = ctx.req.param("days") ?? 7; const embed = !ctx.req.param("embed"); const responseApi = `https://api.bilibili.com/x/web-interface/newlist?ps=15&rid=${tid}&_=${Date.now()}`; const response = await got_ins.get(responseApi); const items = []; let name = "未知"; let list = {}; list = response.data.data.archives; if (list && list[0] && list[0].tname) name = list[0].tname; const HotRankResponseApi = `https://s.search.bilibili.com/cate/search?main_ver=v3&search_type=video&view_type=hot_rank&cate_id=${tid}&time_from=${formatDate(/* @__PURE__ */ new Date(Date.now() - 1e3 * 60 * 60 * 24 * days))}&time_to=${formatDate(/* @__PURE__ */ new Date())}&_=${Date.now()}`; const hotlist = (await got_ins.get(HotRankResponseApi)).data.result; for (let item of hotlist) { item = { title: item.title, description: utils_default.renderUGCDescription(embed, item.pic, `${item.description} - ${item.tag}`, item.id, void 0, item.bvid), pubDate: new Date(item.pubdate).toUTCString(), link: item.pubdate > utils_default.bvidTime && item.bvid ? `https://www.bilibili.com/video/${item.bvid}` : `https://www.bilibili.com/video/av${item.id}`, author: item.author }; items.push(item); } return { title: `bilibili ${name} 最热视频`, link: "https://www.bilibili.com", description: `bilibili ${name}分区 最热视频`, item: items }; } //#endregion export { route };