From 31c0aa715eb10f21fd6cfa962c2a5a010978c61a Mon Sep 17 00:00:00 2001 From: niyoh Date: Fri, 8 Sep 2023 22:23:06 +0800 Subject: [PATCH 1/8] =?UTF-8?q?fix(route):=20fix=20A=E5=A7=90=E5=88=86?= =?UTF-8?q?=E4=BA=AB=20(#13196)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix(route): fix A姐分享 * fix: use wordpress api * fix: use flatmap * docs: fix build --------- --- lib/v2/abskoop/index.js | 52 ++++++++++------------- lib/v2/abskoop/nsfw.js | 53 +++++++----------------- lib/v2/abskoop/radar.js | 15 ++++++- lib/v2/abskoop/templates/description.art | 3 -- website/docs/routes/multimedia.md | 6 ++- 5 files changed, 54 insertions(+), 75 deletions(-) delete mode 100644 lib/v2/abskoop/templates/description.art diff --git a/lib/v2/abskoop/index.js b/lib/v2/abskoop/index.js index 8353bc1721c733..a6385aec1714a7 100644 --- a/lib/v2/abskoop/index.js +++ b/lib/v2/abskoop/index.js @@ -1,47 +1,37 @@ -const path = require('path'); const got = require('@/utils/got'); const cheerio = require('cheerio'); -const { art } = require('@/utils/render'); const { parseDate } = require('@/utils/parse-date'); module.exports = async (ctx) => { const response = await got({ method: 'get', - url: 'https://www.abskoop.com/page/1/', + url: 'https://www.ahhhhfs.com/wp-json/wp/v2/posts', + searchParams: { + per_page: ctx.query.limit ? parseInt(ctx.query.limit) : 10, + _embed: '', + }, }); - - const $list = cheerio.load(response.data); - const list = $list('.rizhuti_v2-widget-lastpost .scroll article') - .map(function () { - const link = $list(this).find('.entry-wrapper .entry-header a'); - return { - title: link.attr('title'), - link: link.attr('href'), - }; - }) - .get(); + const list = response.data.map((item) => ({ + title: item.title.rendered, + link: item.link, + pubDate: parseDate(item.date_gmt), + updated: parseDate(item.modified_gmt), + author: item._embedded.author[0].name, + category: [...new Set(item._embedded['wp:term'].flatMap((i) => i.map((j) => j.name)))], + })); const items = await Promise.all( - list.reverse().map((item) => + list.map((item) => ctx.cache.tryGet(item.link, async () => { const detailResponse = await got({ method: 'get', url: item.link }); const $detail = cheerio.load(detailResponse.data); - $detail('article .entry-content').find('#related_posts').remove(); - $detail('article .entry-content').find('#jp-relatedposts').remove(); - $detail('article .entry-content').find('.post-note').remove(); - $detail('article .entry-content').find('.entry-tags').remove(); - $detail('article .entry-content').find('.entry-share').remove(); - $detail('article .entry-content a').each(function () { - if ($detail(this).find('img').length > 0) { - $detail(this).replaceWith(``); - } - }); - const desc = []; - $detail('article .entry-content > *').each(function () { - desc.push($detail(this).html()); + $detail('article.post-content').find('.lwptoc').remove(); + $detail('article.post-content').find('#related_posts').remove(); + $detail('article.post-content').find('.entry-copyright').remove(); + $detail('article.post-content img').each(function () { + $detail(this).replaceWith(``); }); - item.description = art(path.join(__dirname, 'templates/description.art'), { desc }); - item.pubDate = parseDate($detail('meta[property="article:published_time"]').attr('content')); + item.description = $detail('article.post-content').html(); return item; }) ) @@ -49,7 +39,7 @@ module.exports = async (ctx) => { ctx.state.data = { title: 'ahhhhfs-A姐分享', - link: 'https://www.abskoop.com', + link: 'https://www.ahhhhfs.com', description: 'A姐分享,分享各种网络云盘资源、BT种子、高清电影电视剧和羊毛福利,收集各种有趣实用的软件和APP的下载、安装、使用方法,发现一些稀奇古怪的的网站,折腾一些有趣实用的教程,关注谷歌苹果等互联网最新的资讯动态,探索新领域,发现新美好,分享小快乐。', item: items, diff --git a/lib/v2/abskoop/nsfw.js b/lib/v2/abskoop/nsfw.js index fa59f818652801..100695a0f9b6ca 100644 --- a/lib/v2/abskoop/nsfw.js +++ b/lib/v2/abskoop/nsfw.js @@ -1,52 +1,31 @@ -const path = require('path'); const got = require('@/utils/got'); -const cheerio = require('cheerio'); -const { art } = require('@/utils/render'); const { parseDate } = require('@/utils/parse-date'); module.exports = async (ctx) => { const response = await got({ method: 'get', - url: 'https://nsfw.ahhhhfs.com/articles-archive/', + url: 'https://nsfw.abskoop.com/wp-json/wp/v2/posts', + searchParams: { + per_page: ctx.query.limit ? parseInt(ctx.query.limit) : 10, + _embed: '', + }, }); - const $list = cheerio.load(response.data); - const list = $list('article li') - .slice(0, 20) - .map(function () { - return { - link: $list(this).find('a').attr('href'), - }; - }) - .get(); - - const items = await Promise.all( - list.map((item) => - ctx.cache.tryGet(item.link, async () => { - const detailResponse = await got({ method: 'get', url: item.link }); - const $detail = cheerio.load(detailResponse.data); - $detail('article .entry-content a').each(function () { - if ($detail(this).find('img').length > 0) { - $detail(this).replaceWith(``); - } - }); - const desc = []; - $detail('article .entry-content > p').each(function () { - desc.push($detail(this).html()); - }); - item.title = $detail('article h1.entry-title').text(); - item.description = art(path.join(__dirname, 'templates/description.art'), { desc }); - item.pubDate = parseDate($detail('meta[property="article:published_time"]').attr('content')); - return item; - }) - ) - ); + const list = response.data.map((item) => ({ + title: item.title.rendered, + description: item.content.rendered, + link: item.link, + pubDate: parseDate(item.date_gmt), + updated: parseDate(item.modified_gmt), + author: item._embedded.author[0].name, + category: [...new Set(item._embedded['wp:term'].flatMap((i) => i.map((j) => j.name)))], + })); ctx.state.data = { title: 'ahhhhfs-A姐分享NSFW', - link: 'https://nsfw.ahhhhfs.com', + link: 'https://nsfw.ahhhhfs.com/articles-archive', description: 'A姐分享NSFW,分享各种网络云盘资源、BT种子、磁力链接、高清电影电视剧和羊毛福利,收集各种有趣实用的软件和APP的下载、安装、使用方法,发现一些稀奇古怪的的网站,折腾一些有趣实用的教程,关注谷歌苹果等互联网最新的资讯动态,探索新领域,发现新美好,分享小快乐。', - item: items, + item: list, }; }; diff --git a/lib/v2/abskoop/radar.js b/lib/v2/abskoop/radar.js index 8cd53cd15b1afc..60544a7a3761f6 100644 --- a/lib/v2/abskoop/radar.js +++ b/lib/v2/abskoop/radar.js @@ -1,11 +1,22 @@ module.exports = { 'abskoop.com': { + _name: 'A姐分享', + nsfw: [ + { + title: 'NSFW 存档列表', + docs: 'https://docs.rsshub.app/routes/multimedia#a-jie-fen-xiang', + source: ['/articles-archive', '/'], + target: '/abskoop', + }, + ], + }, + 'ahhhhfs.com': { _name: 'A姐分享', '.': [ { title: '存档列表', - docs: 'https://docs.rsshub.app/routes/multimedia#abskoop', - source: ['/archives'], + docs: 'https://docs.rsshub.app/routes/multimedia#a-jie-fen-xiang', + source: ['/'], target: '/abskoop', }, ], diff --git a/lib/v2/abskoop/templates/description.art b/lib/v2/abskoop/templates/description.art deleted file mode 100644 index 4594e979931118..00000000000000 --- a/lib/v2/abskoop/templates/description.art +++ /dev/null @@ -1,3 +0,0 @@ -{{each desc}} -

{{@ $value}}

-{{/each}} diff --git a/website/docs/routes/multimedia.md b/website/docs/routes/multimedia.md index cbe58390c5cdde..e66f0660012056 100644 --- a/website/docs/routes/multimedia.md +++ b/website/docs/routes/multimedia.md @@ -275,7 +275,9 @@ When `uncensored_makersr` as **Uncensored** is chosen as **Category**, the avail ## A 姐分享 {#a-jie-fen-xiang} - +### 存档列表 {#a-jie-fen-xiang-cun-dang-lie-biao} + + ## AV01(av01.tv) {#av01%EF%BC%88av01.tv%EF%BC%89} @@ -981,7 +983,7 @@ See [Directory](https://www.javlibrary.com/en/star_list.php) to view all stars. ### 影视分类 {#mp4ba-ying-shi-fen-lei} - + **类型参考这里** From 31684c94805a0c32aa76c41edbb5b1b43c937028 Mon Sep 17 00:00:00 2001 From: Tony Date: Fri, 8 Sep 2023 22:46:51 +0800 Subject: [PATCH 2/8] fix(route): rsshub routes (#13235) --- lib/v2/rsshub/routes.js | 10 ++++++---- website/docs/routes/program-update.md | 2 +- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/lib/v2/rsshub/routes.js b/lib/v2/rsshub/routes.js index a8ec2b72ebd801..4e1e6389bdf339 100644 --- a/lib/v2/rsshub/routes.js +++ b/lib/v2/rsshub/routes.js @@ -2,7 +2,9 @@ const got = require('@/utils/got'); const cheerio = require('cheerio'); module.exports = async (ctx) => { - const lang = ctx.params.lang === 'en' ? 'en/' : ''; + const isEnglish = ctx.params.lang !== 'zh'; + + const lang = isEnglish ? '' : 'zh/'; const types = [ 'social-media', 'new-media', @@ -43,10 +45,10 @@ module.exports = async (ctx) => { const list = all.flatMap(({ page, item, type }) => item.map((item) => ({ page, item, type }))); ctx.state.data = { - title: lang === 'en/' ? 'RSSHub has new routes' : 'RSSHub 有新路由啦', + title: isEnglish ? 'RSSHub has new routes' : 'RSSHub 有新路由啦', link: 'https://docs.rsshub.app', - description: lang === 'en/' ? 'Everything is RSSible' : '万物皆可 RSS', - language: lang === 'en/' ? 'en-us' : 'zh-cn', + description: isEnglish ? 'Everything is RSSible' : '万物皆可 RSS', + language: isEnglish ? 'en-us' : 'zh-cn', item: list.map(({ page, item, type }) => { const $ = cheerio.load(page); item = $(item); diff --git a/website/docs/routes/program-update.md b/website/docs/routes/program-update.md index 180acc76ff8553..d28660406a1a62 100644 --- a/website/docs/routes/program-update.md +++ b/website/docs/routes/program-update.md @@ -580,7 +580,7 @@ Logseq 开发团队已经放弃了 [旧网站](https://logseq.com/blog)。 ### New routes {#rsshub-new-routes} - + ### New sponsors {#rsshub-new-sponsors} From 536a4002be89d5f8fa5692e990ce0d0c16772d71 Mon Sep 17 00:00:00 2001 From: Zhiyang Guo Date: Fri, 8 Sep 2023 22:54:00 +0800 Subject: [PATCH 3/8] =?UTF-8?q?fix(route):=20=E4=B8=AD=E5=9B=BD=E7=A7=91?= =?UTF-8?q?=E5=AD=A6=E6=8A=80=E6=9C=AF=E5=A4=A7=E5=AD=A6=20(#13234)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/v2/ustc/eeis.js | 9 +++++---- lib/v2/ustc/sist.js | 11 ++++++----- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/lib/v2/ustc/eeis.js b/lib/v2/ustc/eeis.js index bd9eb36209dd2a..68d2528d860098 100644 --- a/lib/v2/ustc/eeis.js +++ b/lib/v2/ustc/eeis.js @@ -21,13 +21,14 @@ module.exports = async (ctx) => { const response = await got(`${host}/${id}/list.htm`); const $ = cheerio.load(response.data); const list = $('div[portletmode=simpleList]') - .find('div.newslist') + .find('article') .toArray() .map((item) => { item = $(item); - const title = item.find('a').attr('title').trim(); - const link = item.find('a').attr('href').startsWith('/') ? host + item.find('a').attr('href') : item.find('a').attr('href'); - const pubDate = timezone(parseDate(item.find('.text-secondary').text() + '/' + item.find('.text-primary').text(), 'YYYY/MM/DD'), +8); + const title = item.find('h4 > a').eq(1).attr('title').trim(); + let link = item.find('h4 > a').attr('href'); + link = link.startsWith('/') ? host + link : link; + const pubDate = timezone(parseDate(item.find('.post-date > time').text().replace('发布时间:', ''), 'YYYY-MM-DD'), +8); return { title, pubDate, diff --git a/lib/v2/ustc/sist.js b/lib/v2/ustc/sist.js index da13224bd1e785..93a1e7738df903 100644 --- a/lib/v2/ustc/sist.js +++ b/lib/v2/ustc/sist.js @@ -20,14 +20,15 @@ module.exports = async (ctx) => { const response = await got(`${host}/${id}/list.htm`); const $ = cheerio.load(response.data); - let items = $('div#wp_news_w12') - .find('li') + let items = $('div[portletmode=simpleList]') + .find('div.card') .toArray() .map((item) => { item = $(item); - const title = item.find('a').attr('title').trim(); - const link = item.find('a').attr('href').startsWith('/') ? host + item.find('a').attr('href') : item.find('a').attr('href'); - const pubDate = timezone(parseDate(item.find('span').text(), 'YYYY-MM-DD'), +8); + const title = item.find('.card-title > a').attr('title').trim(); + let link = item.find('.card-title > a').attr('href'); + link = link.startsWith('/') ? host + link : link; + const pubDate = timezone(parseDate(item.find('time').text().replace('发布时间:', ''), 'YYYY-MM-DD'), +8); return { title, pubDate, From 1d129d80ccaaad49702ac2788c6a799f3a108f1b Mon Sep 17 00:00:00 2001 From: Tony Date: Sat, 9 Sep 2023 03:23:15 +0800 Subject: [PATCH 4/8] fix(route): discuz charset (#13240) * fix(route): discuz charset * fix: lazyload image --- lib/radar.js | 2 +- lib/router.js | 6 +- lib/routes/discuz/discuz.js | 148 ---------------------------------- lib/v2/discuz/discuz.js | 156 ++++++++++++++++++++++++++++++++++++ lib/v2/discuz/maintainer.js | 5 ++ lib/v2/discuz/radar.js | 0 lib/v2/discuz/router.js | 5 ++ 7 files changed, 170 insertions(+), 152 deletions(-) delete mode 100644 lib/routes/discuz/discuz.js create mode 100644 lib/v2/discuz/discuz.js create mode 100644 lib/v2/discuz/maintainer.js create mode 100644 lib/v2/discuz/radar.js create mode 100644 lib/v2/discuz/router.js diff --git a/lib/radar.js b/lib/radar.js index 09f24e6e8e99f4..29efd6ee842b3a 100644 --- a/lib/radar.js +++ b/lib/radar.js @@ -4,7 +4,7 @@ const toSource = require('tosource'); const { join } = require('path'); // Namespaces that do not require radar.js -const allowNamespace = ['discourse', 'ehentai', 'test']; +const allowNamespace = ['discourse', 'discuz', 'ehentai', 'test']; // Check if a radar.js file is exist under each folder of dirname for (const dir of fs.readdirSync(dirname)) { const dirPath = join(dirname, dir); diff --git a/lib/router.js b/lib/router.js index 4a818131d90578..f11c9016b6a2bb 100644 --- a/lib/router.js +++ b/lib/router.js @@ -1446,9 +1446,9 @@ router.get('/gbcc/trust', lazyloadRouteHandler('./routes/gbcc/trust')); router.get('/cbc/topics/:topic?', lazyloadRouteHandler('./routes/cbc/topics')); // discuz -router.get('/discuz/:ver([7|x])/:cid([0-9]{2})/:link(.*)', lazyloadRouteHandler('./routes/discuz/discuz')); -router.get('/discuz/:ver([7|x])/:link(.*)', lazyloadRouteHandler('./routes/discuz/discuz')); -router.get('/discuz/:link(.*)', lazyloadRouteHandler('./routes/discuz/discuz')); +// router.get('/discuz/:ver([7|x])/:cid([0-9]{2})/:link(.*)', lazyloadRouteHandler('./routes/discuz/discuz')); +// router.get('/discuz/:ver([7|x])/:link(.*)', lazyloadRouteHandler('./routes/discuz/discuz')); +// router.get('/discuz/:link(.*)', lazyloadRouteHandler('./routes/discuz/discuz')); // China Dialogue 中外对话 router.get('/chinadialogue/topics/:topic', lazyloadRouteHandler('./routes/chinadialogue/topics')); diff --git a/lib/routes/discuz/discuz.js b/lib/routes/discuz/discuz.js deleted file mode 100644 index b936586c21fed8..00000000000000 --- a/lib/routes/discuz/discuz.js +++ /dev/null @@ -1,148 +0,0 @@ -const got = require('@/utils/got'); -const cheerio = require('cheerio'); -const iconv = require('iconv-lite'); -const dateUtil = require('@/utils/date'); -const config = require('@/config').value; - -// discuz 7.x 与 discuz x系列 通用文章内容抓取 -async function load(baseUrl, itemLink, ctx, charset, header) { - // 处理相对链接 - if (itemLink) { - if (baseUrl && !baseUrl.match(/^https?:\/\//)) { - if (baseUrl.match(/^\/\//)) { - baseUrl = 'http:' + baseUrl; - } else { - baseUrl = 'http://' + baseUrl; - } - } - itemLink = new URL(itemLink, baseUrl).href; - } - - const cache = await ctx.cache.get(itemLink); - if (cache) { - return cache; - } - - // 处理编码问题 - let responseData; - if (charset === 'utf-8') { - responseData = ( - await got({ - method: 'get', - url: itemLink, - headers: header, - }) - ).data; - } else { - responseData = iconv.decode( - ( - await got({ - method: 'get', - url: itemLink, - responseType: 'buffer', - headers: header, - }) - ).data, - charset - ); - } - if (!responseData) { - const description = '获取详细内容失败'; - return { description }; - } - const $ = cheerio.load(responseData); - // 只抓取论坛1楼消息 - const description = $('div#postlist div[id^=post] td[id^=postmessage]').slice(0, 1).html(); - ctx.cache.set(itemLink, description); - return { description }; -} - -module.exports = async (ctx) => { - let link = ctx.params.link; - const ver = ctx.params.ver ? ctx.params.ver.toUpperCase() : undefined; - const cid = ctx.params.cid; - link = link.replace(/:\/\//, ':/').replace(/:\//, '://'); - const cookie = cid === undefined ? '' : config.discuz.cookies[cid]; - if (cookie === undefined) { - throw Error('缺少对应论坛的cookie.'); - } - const header = { - Cookie: cookie, - Referer: link, - }; - const response = await got({ - method: 'get', - url: link, - headers: header, - }); - const contentType = response.headers['content-type'] || ''; - // 若没有指定编码,则默认utf-8 - let charset = 'utf-8'; - for (const attr of contentType.split(';')) { - if (attr.indexOf('charset=') >= 0) { - charset = attr.split('=').pop().toLowerCase(); - } - } - const responseData = - charset === 'utf-8' - ? response.data - : iconv.decode( - ( - await got({ - method: 'get', - url: link, - responseType: 'buffer', - headers: { - Cookie: cookie, - }, - }) - ).data, - charset - ); - const $ = cheerio.load(responseData); - const title = $('head > title').text(); - const version = ver ? 'DISCUZ! ' + ver : $('head > meta[name=generator]').attr('content'); - let process; - if (version.toUpperCase().startsWith('DISCUZ! 7')) { - // discuz 7.x 系列 - // 支持全文抓取,限制抓取页面5个 - const list = $('tbody[id^="normalthread"] > tr').slice(0, 5).get(); - process = await Promise.all( - list.map(async (item) => { - item = $(item); - const itemLink = item.find('span[id^=thread] a').attr('href'); - const single = { - title: item.find('span[id^=thread] a').text(), - link: itemLink, - pubDate: dateUtil(item.find('td.author em').text()), - }; - const detail = await load(link, itemLink, ctx, charset, header); - return Promise.resolve(Object.assign({}, single, detail)); - }) - ); - } else if (version.toUpperCase().startsWith('DISCUZ! X')) { - // discuz X 系列 - // 支持全文抓取,限制抓取页面5个 - const list = $('tbody[id^="normalthread"] > tr').slice(0, 5).get(); - process = await Promise.all( - list.map(async (item) => { - item = $(item); - const itemLink = item.find('a.xst').attr('href'); - const single = { - title: item.find('a.xst').text(), - link: itemLink, - pubDate: dateUtil(item.find('td.by:nth-child(3) em span').last().text()), - }; - const detail = await load(link, itemLink, ctx, charset, header); - return Promise.resolve(Object.assign({}, single, detail)); - }) - ); - } else { - throw Error('不支持当前Discuz版本.'); - } - ctx.state.data = { - title, - link, - item: process, - }; -}; diff --git a/lib/v2/discuz/discuz.js b/lib/v2/discuz/discuz.js new file mode 100644 index 00000000000000..af83e0877d31e7 --- /dev/null +++ b/lib/v2/discuz/discuz.js @@ -0,0 +1,156 @@ +const got = require('@/utils/got'); +const cheerio = require('cheerio'); +const iconv = require('iconv-lite'); +const { parseDate } = require('@/utils/parse-date'); +const config = require('@/config').value; + +function fixUrl(itemLink, baseUrl) { + // 处理相对链接 + if (itemLink) { + if (baseUrl && !baseUrl.match(/^https?:\/\//)) { + if (baseUrl.match(/^\/\//)) { + baseUrl = 'http:' + baseUrl; + } else { + baseUrl = 'http://' + baseUrl; + } + } + itemLink = new URL(itemLink, baseUrl).href; + } + return itemLink; +} + +// discuz 7.x 与 discuz x系列 通用文章内容抓取 +async function load(itemLink, charset, header) { + // 处理编码问题 + const response = await got({ + method: 'get', + url: itemLink, + responseType: 'buffer', + headers: header, + }); + + const responseData = iconv.decode(response.data, charset ?? 'utf-8'); + if (!responseData) { + const description = '获取详细内容失败'; + return { description }; + } + + const $ = cheerio.load(responseData); + + const post = $('div#postlist div[id^=post] td[id^=postmessage]').first(); + + // fix lazyload image + post.find('img').each((_, img) => { + img = $(img); + if (img.attr('src')?.endsWith('none.gif') && img.attr('file')) { + img.attr('src', img.attr('file') || img.attr('zoomfile')); + img.removeAttr('file'); + img.removeAttr('zoomfile'); + } + }); + + // 只抓取论坛1楼消息 + const description = post.html(); + + return { description }; +} + +module.exports = async (ctx) => { + let link = ctx.params.link; + const ver = ctx.params.ver ? ctx.params.ver.toUpperCase() : undefined; + const cid = ctx.params.cid; + link = link.replace(/:\/\//, ':/').replace(/:\//, '://'); + + const cookie = cid === undefined ? '' : config.discuz.cookies[cid]; + if (cookie === undefined) { + throw Error('缺少对应论坛的cookie.'); + } + + const header = { + Cookie: cookie, + }; + + const response = await got({ + method: 'get', + url: link, + responseType: 'buffer', + headers: header, + }); + + const responseData = response.data; + // 若没有指定编码,则默认utf-8 + const contentType = response.headers['content-type'] || ''; + let $ = cheerio.load(iconv.decode(responseData, 'utf-8')); + const charset = contentType.match(/charset=([^;]*)/)?.[1] ?? $('meta[charset]').attr('charset') ?? $('meta[http-equiv="Content-Type"]').attr('content')?.split('charset=')?.[1]; + if (charset?.toLowerCase() !== 'utf-8') { + $ = cheerio.load(iconv.decode(responseData, charset ?? 'utf-8')); + } + + const version = ver ? `DISCUZ! ${ver}` : $('head > meta[name=generator]').attr('content'); + + let items; + if (version.toUpperCase().startsWith('DISCUZ! 7')) { + // discuz 7.x 系列 + // 支持全文抓取,限制抓取页面5个 + const list = $('tbody[id^="normalthread"] > tr') + .slice(0, ctx.query.limit ? parseInt(ctx.query.limit, 10) : 5) + .toArray() + .map((item) => { + item = $(item); + const a = item.find('span[id^=thread] a'); + return { + title: a.text().trim(), + link: fixUrl(a.attr('href'), link), + pubDate: item.find('td.author em').length ? parseDate(item.find('td.author em').text().trim()) : undefined, + author: item.find('td.author cite a').text().trim(), + }; + }); + + items = await Promise.all( + list.map((item) => + ctx.cache.tryGet(item.link, async () => { + const { description } = await load(item.link, charset, header); + + item.description = description; + return item; + }) + ) + ); + } else if (version.toUpperCase().startsWith('DISCUZ! X')) { + // discuz X 系列 + // 支持全文抓取,限制抓取页面5个 + const list = $('tbody[id^="normalthread"] > tr') + .slice(0, ctx.query.limit ? parseInt(ctx.query.limit, 10) : 5) + .toArray() + .map((item) => { + item = $(item); + const a = item.find('a.xst'); + return { + title: a.text(), + link: fixUrl(a.attr('href'), link), + pubDate: item.find('td.by:nth-child(3) em span').last().length ? parseDate(item.find('td.by:nth-child(3) em span').last().text().trim()) : undefined, + author: item.find('td.by:nth-child(3) cite a').text().trim(), + }; + }); + + items = await Promise.all( + list.map((item) => + ctx.cache.tryGet(item.link, async () => { + const { description } = await load(item.link, charset, header); + + item.description = description; + return item; + }) + ) + ); + } else { + throw Error('不支持当前Discuz版本.'); + } + + ctx.state.data = { + title: $('head > title').text(), + description: $('head > meta[name=description]').attr('content'), + link, + item: items, + }; +}; diff --git a/lib/v2/discuz/maintainer.js b/lib/v2/discuz/maintainer.js new file mode 100644 index 00000000000000..cc199b2941c858 --- /dev/null +++ b/lib/v2/discuz/maintainer.js @@ -0,0 +1,5 @@ +module.exports = { + '/:link': ['junfengP'], + '/:ver/:link': ['junfengP'], + '/:ver/:cid/:link': ['junfengP'], +}; diff --git a/lib/v2/discuz/radar.js b/lib/v2/discuz/radar.js new file mode 100644 index 00000000000000..e69de29bb2d1d6 diff --git a/lib/v2/discuz/router.js b/lib/v2/discuz/router.js new file mode 100644 index 00000000000000..fff35e3c42650e --- /dev/null +++ b/lib/v2/discuz/router.js @@ -0,0 +1,5 @@ +module.exports = (router) => { + router.get('/:ver([7|x])/:cid([0-9]{2})/:link(.*)', require('./discuz')); + router.get('/:ver([7|x])/:link(.*)', require('./discuz')); + router.get('/:link(.*)', require('./discuz')); +}; From 853f182f05bcc6c989a8bd602e85c64420030e66 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 9 Sep 2023 07:35:51 +0800 Subject: [PATCH 5/8] chore(deps-dev): bump eslint from 8.48.0 to 8.49.0 (#13241) * chore(deps-dev): bump eslint from 8.48.0 to 8.49.0 Bumps [eslint](https://github.com/eslint/eslint) from 8.48.0 to 8.49.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/compare/v8.48.0...v8.49.0) --- updated-dependencies: - dependency-name: eslint dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] * chore: fix pnpm install --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- package.json | 2 +- pnpm-lock.yaml | 64 +++++++++++++++++++++++++------------------------- 2 files changed, 33 insertions(+), 33 deletions(-) diff --git a/package.json b/package.json index b951ce0ad67cb2..38cd782b62a6ef 100644 --- a/package.json +++ b/package.json @@ -152,7 +152,7 @@ "@types/koa": "2.13.8", "@vercel/nft": "0.23.1", "cross-env": "7.0.3", - "eslint": "8.48.0", + "eslint": "8.49.0", "eslint-config-prettier": "9.0.0", "eslint-plugin-n": "16.0.2", "eslint-plugin-prettier": "5.0.0", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index e1308a19cc36d9..012773eabc3473 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -209,20 +209,20 @@ devDependencies: specifier: 7.0.3 version: 7.0.3 eslint: - specifier: 8.48.0 - version: 8.48.0 + specifier: 8.49.0 + version: 8.49.0 eslint-config-prettier: specifier: 9.0.0 - version: 9.0.0(eslint@8.48.0) + version: 9.0.0(eslint@8.49.0) eslint-plugin-n: specifier: 16.0.2 - version: 16.0.2(eslint@8.48.0) + version: 16.0.2(eslint@8.49.0) eslint-plugin-prettier: specifier: 5.0.0 - version: 5.0.0(eslint-config-prettier@9.0.0)(eslint@8.48.0)(prettier@3.0.3) + version: 5.0.0(eslint-config-prettier@9.0.0)(eslint@8.49.0)(prettier@3.0.3) eslint-plugin-yml: specifier: 1.8.0 - version: 1.8.0(eslint@8.48.0) + version: 1.8.0(eslint@8.49.0) fs-extra: specifier: 11.1.1 version: 11.1.1 @@ -652,13 +652,13 @@ packages: kuler: 2.0.0 dev: false - /@eslint-community/eslint-utils@4.4.0(eslint@8.48.0): + /@eslint-community/eslint-utils@4.4.0(eslint@8.49.0): resolution: {integrity: sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} peerDependencies: eslint: ^6.0.0 || ^7.0.0 || >=8.0.0 dependencies: - eslint: 8.48.0 + eslint: 8.49.0 eslint-visitor-keys: 3.4.3 dev: true @@ -684,13 +684,13 @@ packages: - supports-color dev: true - /@eslint/js@8.48.0: - resolution: {integrity: sha512-ZSjtmelB7IJfWD2Fvb7+Z+ChTIKWq6kjda95fLcQKNS5aheVHn4IkfgRQE3sIIzTcSLwLcLZUD9UBt+V7+h+Pw==} + /@eslint/js@8.49.0: + resolution: {integrity: sha512-1S8uAY/MTJqVx0SC4epBq+N2yhuwtNwLbJYNZyhL2pO1ZVKn5HFXav5T41Ryzy9K9V7ZId2JB2oy/W4aCd9/2w==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dev: true - /@humanwhocodes/config-array@0.11.10: - resolution: {integrity: sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==} + /@humanwhocodes/config-array@0.11.11: + resolution: {integrity: sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA==} engines: {node: '>=10.10.0'} dependencies: '@humanwhocodes/object-schema': 1.2.1 @@ -1009,7 +1009,7 @@ packages: resolution: {integrity: sha512-KIKkT44hEqCzqxODYwFMUvYEK0CrdHx/Ll9xiOWgFbBSRuzbxmVy4d/tzfgoucGz72HJZNOMjuyzFTBKntRK5Q==} engines: {node: '>= 14'} dependencies: - eslint: 8.48.0 + eslint: 8.49.0 jschardet: 3.0.0 lodash: 4.17.21 utf8: 3.0.0 @@ -2890,36 +2890,36 @@ packages: source-map: 0.6.1 dev: false - /eslint-config-prettier@9.0.0(eslint@8.48.0): + /eslint-config-prettier@9.0.0(eslint@8.49.0): resolution: {integrity: sha512-IcJsTkJae2S35pRsRAwoCE+925rJJStOdkKnLVgtE+tEpqU0EVVM7OqrwxqgptKdX29NUwC82I5pXsGFIgSevw==} hasBin: true peerDependencies: eslint: '>=7.0.0' dependencies: - eslint: 8.48.0 + eslint: 8.49.0 dev: true - /eslint-plugin-es-x@7.2.0(eslint@8.48.0): + /eslint-plugin-es-x@7.2.0(eslint@8.49.0): resolution: {integrity: sha512-9dvv5CcvNjSJPqnS5uZkqb3xmbeqRLnvXKK7iI5+oK/yTusyc46zbBZKENGsOfojm/mKfszyZb+wNqNPAPeGXA==} engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: eslint: '>=8' dependencies: - '@eslint-community/eslint-utils': 4.4.0(eslint@8.48.0) + '@eslint-community/eslint-utils': 4.4.0(eslint@8.49.0) '@eslint-community/regexpp': 4.8.0 - eslint: 8.48.0 + eslint: 8.49.0 dev: true - /eslint-plugin-n@16.0.2(eslint@8.48.0): + /eslint-plugin-n@16.0.2(eslint@8.49.0): resolution: {integrity: sha512-Y66uDfUNbBzypsr0kELWrIz+5skicECrLUqlWuXawNSLUq3ltGlCwu6phboYYOTSnoTdHgTLrc+5Ydo6KjzZog==} engines: {node: '>=16.0.0'} peerDependencies: eslint: '>=7.0.0' dependencies: - '@eslint-community/eslint-utils': 4.4.0(eslint@8.48.0) + '@eslint-community/eslint-utils': 4.4.0(eslint@8.49.0) builtins: 5.0.1 - eslint: 8.48.0 - eslint-plugin-es-x: 7.2.0(eslint@8.48.0) + eslint: 8.49.0 + eslint-plugin-es-x: 7.2.0(eslint@8.49.0) ignore: 5.2.4 is-core-module: 2.13.0 minimatch: 3.1.2 @@ -2927,7 +2927,7 @@ packages: semver: 7.5.4 dev: true - /eslint-plugin-prettier@5.0.0(eslint-config-prettier@9.0.0)(eslint@8.48.0)(prettier@3.0.3): + /eslint-plugin-prettier@5.0.0(eslint-config-prettier@9.0.0)(eslint@8.49.0)(prettier@3.0.3): resolution: {integrity: sha512-AgaZCVuYDXHUGxj/ZGu1u8H8CYgDY3iG6w5kUFw4AzMVXzB7VvbKgYR4nATIN+OvUrghMbiDLeimVjVY5ilq3w==} engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: @@ -2941,21 +2941,21 @@ packages: eslint-config-prettier: optional: true dependencies: - eslint: 8.48.0 - eslint-config-prettier: 9.0.0(eslint@8.48.0) + eslint: 8.49.0 + eslint-config-prettier: 9.0.0(eslint@8.49.0) prettier: 3.0.3 prettier-linter-helpers: 1.0.0 synckit: 0.8.5 dev: true - /eslint-plugin-yml@1.8.0(eslint@8.48.0): + /eslint-plugin-yml@1.8.0(eslint@8.49.0): resolution: {integrity: sha512-fgBiJvXD0P2IN7SARDJ2J7mx8t0bLdG6Zcig4ufOqW5hOvSiFxeUyc2g5I1uIm8AExbo26NNYCcTGZT0MXTsyg==} engines: {node: ^14.17.0 || >=16.0.0} peerDependencies: eslint: '>=6.0.0' dependencies: debug: 4.3.4 - eslint: 8.48.0 + eslint: 8.49.0 lodash: 4.17.21 natural-compare: 1.4.0 yaml-eslint-parser: 1.2.2 @@ -2976,16 +2976,16 @@ packages: engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dev: true - /eslint@8.48.0: - resolution: {integrity: sha512-sb6DLeIuRXxeM1YljSe1KEx9/YYeZFQWcV8Rq9HfigmdDEugjLEVEa1ozDjL6YDjBpQHPJxJzze+alxi4T3OLg==} + /eslint@8.49.0: + resolution: {integrity: sha512-jw03ENfm6VJI0jA9U+8H5zfl5b+FvuU3YYvZRdZHOlU2ggJkxrlkJH4HcDrZpj6YwD8kuYqvQM8LyesoazrSOQ==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} hasBin: true dependencies: - '@eslint-community/eslint-utils': 4.4.0(eslint@8.48.0) + '@eslint-community/eslint-utils': 4.4.0(eslint@8.49.0) '@eslint-community/regexpp': 4.8.0 '@eslint/eslintrc': 2.1.2 - '@eslint/js': 8.48.0 - '@humanwhocodes/config-array': 0.11.10 + '@eslint/js': 8.49.0 + '@humanwhocodes/config-array': 0.11.11 '@humanwhocodes/module-importer': 1.0.1 '@nodelib/fs.walk': 1.2.8 ajv: 6.12.6 From fdf2c27c8c59d1706c260032338a0623fc398237 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=B0=8F=E8=99=8E=E6=95=85=E6=B4=9E?= <55782476+TigerCubDen@users.noreply.github.com> Date: Sat, 9 Sep 2023 08:47:44 +0800 Subject: [PATCH 6/8] =?UTF-8?q?fix(route):=20=E7=94=A8=E6=88=B7=E5=85=B3?= =?UTF-8?q?=E6=B3=A8=E5=8A=A8=E6=80=81=E4=B8=8D=E5=A1=AB=E5=85=85=E9=A2=84?= =?UTF-8?q?=E5=AE=9A=E4=B9=89=E4=BD=9C=E8=80=85=E5=90=8D=20(#13242)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/v2/bilibili/followings_dynamic.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/v2/bilibili/followings_dynamic.js b/lib/v2/bilibili/followings_dynamic.js index 777fb9df001f15..244e0b0c872028 100644 --- a/lib/v2/bilibili/followings_dynamic.js +++ b/lib/v2/bilibili/followings_dynamic.js @@ -117,7 +117,7 @@ module.exports = async (ctx) => { }); } // 作者信息 - let author = '哔哩哔哩番剧'; + let author = ''; if (item.desc?.user_profile) { author = item.desc.user_profile.info.uname; } From 3276104c418126df77a5fdf2f267057f4a3f7558 Mon Sep 17 00:00:00 2001 From: Tony Date: Sat, 9 Sep 2023 21:51:44 +0800 Subject: [PATCH 7/8] fix(app): cache logo & subdirectory serving (#13244) --- lib/app.js | 4 ++-- lib/views/error.art | 2 +- lib/views/welcome.art | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/app.js b/lib/app.js index c958f0f6f5994c..39b91f574e1c78 100644 --- a/lib/app.js +++ b/lib/app.js @@ -37,8 +37,8 @@ const app = new Koa(); app.proxy = true; // favicon -app.use(favicon(__dirname + '/favicon.png')); -app.use(serve(__dirname + '/static')); +app.use(favicon(__dirname + '/favicon.png', { maxAge: 31536000000 })); +app.use(serve(__dirname + '/static', { maxage: 31536000000 })); // global error handing app.use(onerror); diff --git a/lib/views/error.art b/lib/views/error.art index 8579fc0e617792..cbd40ed9ddb796 100644 --- a/lib/views/error.art +++ b/lib/views/error.art @@ -36,7 +36,7 @@

- RSSHub + RSSHub

Looks like something went wrong

diff --git a/lib/views/welcome.art b/lib/views/welcome.art index f97703118baa90..0ff6ba6393e238 100644 --- a/lib/views/welcome.art +++ b/lib/views/welcome.art @@ -79,7 +79,7 @@

- RSSHub + RSSHub

Welcome to From 71269cd6960c5d0d432fd85d3c5e6323760e18fa Mon Sep 17 00:00:00 2001 From: Tony Date: Sat, 9 Sep 2023 22:29:20 +0800 Subject: [PATCH 8/8] fix(app): grey logo in error not showing this breaks subdirectory serving --- lib/views/error.art | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/views/error.art b/lib/views/error.art index cbd40ed9ddb796..8579fc0e617792 100644 --- a/lib/views/error.art +++ b/lib/views/error.art @@ -36,7 +36,7 @@

- RSSHub + RSSHub

Looks like something went wrong