rsshub 1.0.0-master.f78ad03 → 1.0.0-master.f792555
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -8
- package/lib/config.js +20 -4
- package/lib/middleware/parameter.js +10 -10
- package/lib/middleware/template.js +29 -11
- package/lib/radar-rules.js +53 -391
- package/lib/router.js +135 -144
- package/lib/routes/bbc/index.js +1 -0
- package/lib/routes/cell/cover.js +1 -1
- package/lib/routes/sankakucomplex/post.js +1 -4
- package/lib/routes/v2ex/post.js +3 -0
- package/lib/routes/v2ex/topics.js +4 -8
- package/lib/utils/parse-date.js +4 -4
- package/lib/utils/puppeteer-utils.js +63 -0
- package/lib/utils/puppeteer.js +16 -0
- package/lib/utils/render.js +45 -0
- package/lib/utils/request-wrapper.js +38 -94
- package/lib/utils/unify-proxy.js +116 -0
- package/lib/utils/wechat-mp.js +3 -0
- package/lib/v2/18comic/utils.js +2 -2
- package/lib/v2/35photo/genre.js +2 -1
- package/lib/v2/35photo/utils.js +19 -4
- package/lib/v2/36kr/index.js +29 -24
- package/lib/v2/8world/index.js +8 -8
- package/lib/v2/8world/maintainer.js +1 -0
- package/lib/v2/8world/radar.js +6 -0
- package/lib/v2/8world/router.js +1 -1
- package/lib/v2/agora0/maintainer.js +1 -0
- package/lib/v2/agora0/pen0.js +43 -0
- package/lib/v2/agora0/radar.js +12 -1
- package/lib/v2/agora0/router.js +1 -0
- package/lib/v2/aicaijing/index.js +73 -0
- package/lib/v2/aicaijing/maintainer.js +6 -0
- package/lib/v2/aicaijing/radar.js +31 -0
- package/lib/v2/aicaijing/router.js +3 -0
- package/lib/v2/aicaijing/templates/description.art +4 -0
- package/lib/v2/aiea/index.js +39 -0
- package/lib/v2/aiea/maintainer.js +3 -0
- package/lib/v2/aiea/radar.js +13 -0
- package/lib/v2/aiea/router.js +3 -0
- package/lib/v2/aliyundrive/files.js +63 -0
- package/lib/v2/aliyundrive/maintainer.js +3 -0
- package/lib/v2/aliyundrive/radar.js +13 -0
- package/lib/v2/aliyundrive/router.js +3 -0
- package/lib/v2/aljazeera/index.js +87 -0
- package/lib/v2/aljazeera/maintainer.js +5 -0
- package/lib/v2/aljazeera/radar.js +62 -0
- package/lib/v2/aljazeera/router.js +3 -0
- package/lib/v2/aljazeera/templates/description.art +8 -0
- package/lib/v2/anquanke/category.js +39 -0
- package/lib/v2/anquanke/maintainer.js +4 -0
- package/lib/v2/anquanke/radar.js +13 -0
- package/lib/v2/anquanke/router.js +4 -0
- package/lib/{routes/aqk → v2/anquanke}/vul.js +3 -2
- package/lib/v2/apnews/topics.js +20 -18
- package/lib/v2/asus/bios.js +1 -0
- package/lib/v2/baidu/gushitong/index.js +28 -0
- package/lib/v2/baidu/maintainer.js +8 -0
- package/lib/v2/baidu/radar.js +60 -0
- package/lib/v2/baidu/router.js +8 -0
- package/lib/v2/baidu/templates/forum.art +1 -0
- package/lib/v2/baidu/templates/gushitong.art +9 -0
- package/lib/v2/baidu/templates/post.art +4 -0
- package/lib/v2/baidu/tieba/forum.js +64 -0
- package/lib/{routes → v2/baidu}/tieba/post.js +30 -16
- package/lib/v2/baidu/tieba/user.js +33 -0
- package/lib/v2/bangumi/maintainer.js +15 -2
- package/lib/v2/bangumi/{index.js → moe/index.js} +2 -2
- package/lib/v2/bangumi/online/online.js +28 -0
- package/lib/v2/bangumi/radar.js +77 -4
- package/lib/v2/bangumi/router.js +12 -1
- package/lib/v2/bangumi/templates/online/image.art +1 -0
- package/lib/v2/bangumi/templates/tv/ep.art +2 -0
- package/lib/v2/bangumi/templates/tv/today.art +12 -0
- package/lib/v2/bangumi/tv/calendar/_base.js +37 -0
- package/lib/{routes/bangumi → v2/bangumi/tv}/calendar/today.js +15 -27
- package/lib/v2/bangumi/tv/group/reply.js +59 -0
- package/lib/v2/bangumi/tv/group/topic.js +39 -0
- package/lib/{routes/bangumi → v2/bangumi/tv}/person/index.js +14 -10
- package/lib/{routes/bangumi → v2/bangumi/tv}/subject/comments.js +12 -14
- package/lib/v2/bangumi/tv/subject/ep.js +31 -0
- package/lib/{routes/bangumi → v2/bangumi/tv}/subject/index.js +1 -2
- package/lib/{routes/bangumi → v2/bangumi/tv}/subject/offcial-subject-api.js +7 -5
- package/lib/{routes/bangumi → v2/bangumi/tv}/user/blog.js +7 -6
- package/lib/v2/bilibili/cache.js +98 -70
- package/lib/v2/bilibili/dynamic.js +5 -2
- package/lib/v2/bilibili/maintainer.js +2 -2
- package/lib/v2/bilibili/radar.js +18 -9
- package/lib/v2/bilibili/router.js +2 -2
- package/lib/v2/bilibili/userChannel.js +31 -35
- package/lib/v2/bilibili/userCollection.js +51 -0
- package/lib/v2/bilibili/utils.js +10 -0
- package/lib/v2/bilibili/video-all.js +29 -8
- package/lib/v2/bilibili/video.js +11 -3
- package/lib/v2/bilibili/vsearch.js +29 -9
- package/lib/v2/bloomberg/index.js +37 -0
- package/lib/v2/bloomberg/maintainer.js +4 -0
- package/lib/v2/bloomberg/radar.js +13 -0
- package/lib/v2/bloomberg/router.js +4 -0
- package/lib/v2/bloomberg/templates/audio_media.art +13 -0
- package/lib/v2/bloomberg/templates/image_figure.art +9 -0
- package/lib/v2/bloomberg/templates/lede_media.art +14 -0
- package/lib/v2/bloomberg/templates/video_media.art +25 -0
- package/lib/v2/bloomberg/utils.js +395 -0
- package/lib/v2/bluestacks/maintainer.js +3 -0
- package/lib/v2/bluestacks/radar.js +13 -0
- package/lib/v2/bluestacks/release.js +63 -0
- package/lib/v2/bluestacks/router.js +3 -0
- package/lib/v2/bnu/dwxgb.js +57 -0
- package/lib/v2/bnu/radar.js +7 -1
- package/lib/v2/bnu/router.js +1 -0
- package/lib/v2/bytes/bytes.js +25 -0
- package/lib/v2/bytes/maintainer.js +4 -0
- package/lib/v2/bytes/radar.js +13 -0
- package/lib/v2/bytes/router.js +3 -0
- package/lib/v2/caijing/maintainer.js +3 -0
- package/lib/v2/caijing/radar.js +13 -0
- package/lib/v2/caijing/roll.js +46 -0
- package/lib/v2/caijing/router.js +3 -0
- package/lib/v2/cdzjryb/maintainer.js +3 -0
- package/lib/v2/cdzjryb/projectList.js +49 -0
- package/lib/v2/cdzjryb/radar.js +13 -0
- package/lib/v2/cdzjryb/router.js +3 -0
- package/lib/v2/cdzjryb/templates/projectList.art +23 -0
- package/lib/v2/chsi/kydt.js +51 -0
- package/lib/v2/chsi/maintainer.js +3 -0
- package/lib/v2/chsi/radar.js +13 -0
- package/lib/v2/chsi/router.js +3 -0
- package/lib/v2/cnbc/maintainer.js +3 -0
- package/lib/v2/cnbc/radar.js +21 -0
- package/lib/v2/cnbc/router.js +3 -0
- package/lib/v2/cnbc/rss.js +54 -0
- package/lib/v2/cnbeta/radar.js +6 -6
- package/lib/v2/cnbeta/router.js +1 -1
- package/lib/v2/cnbeta/type.js +6 -12
- package/lib/v2/cnbeta/utils.js +5 -8
- package/lib/v2/cnblogs/common.js +30 -0
- package/lib/v2/cnblogs/maintainer.js +7 -0
- package/lib/v2/cnblogs/radar.js +37 -0
- package/lib/v2/cnblogs/router.js +7 -0
- package/lib/v2/cngal/entry.js +25 -0
- package/lib/v2/cngal/maintainer.js +4 -0
- package/lib/v2/cngal/radar.js +19 -0
- package/lib/v2/cngal/router.js +4 -0
- package/lib/v2/cngal/templates/entry-description.art +4 -0
- package/lib/v2/cngal/templates/weekly-description.art +4 -0
- package/lib/v2/cngal/weekly.js +20 -0
- package/lib/v2/cnki/author.js +45 -0
- package/lib/v2/cnki/journals.js +2 -23
- package/lib/v2/cnki/maintainer.js +1 -0
- package/lib/v2/cnki/radar.js +8 -0
- package/lib/v2/cnki/router.js +1 -0
- package/lib/v2/cnki/utils.js +26 -0
- package/lib/v2/codeforces/maintainer.js +1 -0
- package/lib/v2/codeforces/radar.js +8 -0
- package/lib/v2/codeforces/recent_actions.js +47 -0
- package/lib/v2/codeforces/router.js +1 -0
- package/lib/v2/codeforces/templates/contest.art +5 -10
- package/lib/{routes → v2}/comicskingdom/index.js +18 -19
- package/lib/v2/comicskingdom/maintainer.js +3 -0
- package/lib/v2/comicskingdom/radar.js +13 -0
- package/lib/v2/comicskingdom/router.js +3 -0
- package/lib/v2/comicskingdom/templates/desc.art +1 -0
- package/lib/{routes → v2}/coolapk/dyh.js +2 -6
- package/lib/{routes → v2}/coolapk/hot.js +1 -3
- package/lib/{routes → v2}/coolapk/huati.js +1 -3
- package/lib/v2/coolapk/maintainer.js +9 -0
- package/lib/v2/coolapk/radar.js +31 -0
- package/lib/v2/coolapk/router.js +9 -0
- package/lib/{routes → v2}/coolapk/toutiao.js +1 -3
- package/lib/{routes → v2}/coolapk/tuwen.js +2 -4
- package/lib/{routes → v2}/coolapk/userDynamic.js +1 -3
- package/lib/{routes → v2}/coolapk/utils.js +7 -9
- package/lib/v2/cqwu/index.js +1 -1
- package/lib/v2/creative-comic/book.js +60 -0
- package/lib/v2/creative-comic/maintainer.js +3 -0
- package/lib/v2/creative-comic/radar.js +13 -0
- package/lib/v2/creative-comic/router.js +3 -0
- package/lib/v2/creative-comic/templates/chapter.art +11 -0
- package/lib/v2/creative-comic/utils.js +96 -0
- package/lib/v2/cts/maintainer.js +3 -0
- package/lib/v2/cts/news.js +40 -0
- package/lib/v2/cts/radar.js +13 -0
- package/lib/v2/cts/router.js +3 -0
- package/lib/v2/cuc/maintainer.js +3 -0
- package/lib/v2/cuc/radar.js +13 -0
- package/lib/v2/cuc/router.js +3 -0
- package/lib/{routes/universities → v2}/cuc/yz.js +2 -4
- package/lib/v2/curius/links.js +43 -0
- package/lib/v2/curius/maintainer.js +3 -0
- package/lib/v2/curius/radar.js +13 -0
- package/lib/v2/curius/router.js +3 -0
- package/lib/v2/curius/templates/description.art +16 -0
- package/lib/v2/cw/maintainer.js +5 -0
- package/lib/v2/cw/master.js +31 -0
- package/lib/v2/cw/radar.js +25 -0
- package/lib/v2/cw/router.js +5 -0
- package/lib/v2/cw/sub.js +31 -0
- package/lib/v2/cw/today.js +27 -0
- package/lib/v2/cw/utils.js +75 -0
- package/lib/v2/dcard/maintainer.js +4 -0
- package/lib/v2/dcard/radar.js +31 -0
- package/lib/v2/dcard/router.js +3 -0
- package/lib/v2/dcard/section.js +66 -0
- package/lib/v2/dcard/utils.js +50 -0
- package/lib/{routes → v2}/dedao/index.js +11 -8
- package/lib/v2/dedao/knowledge.js +64 -0
- package/lib/{routes → v2}/dedao/list.js +16 -10
- package/lib/v2/dedao/maintainer.js +8 -0
- package/lib/v2/dedao/radar.js +50 -0
- package/lib/v2/dedao/router.js +6 -0
- package/lib/v2/dedao/templates/knowledge.art +29 -0
- package/lib/v2/dedao/templates/user.art +38 -0
- package/lib/v2/dedao/user.js +79 -0
- package/lib/v2/deepmind/blog.js +32 -0
- package/lib/v2/deepmind/maintainer.js +3 -0
- package/lib/v2/deepmind/radar.js +13 -0
- package/lib/v2/deepmind/router.js +3 -0
- package/lib/v2/diershoubing/maintainer.js +3 -0
- package/lib/v2/diershoubing/news.js +50 -0
- package/lib/v2/diershoubing/radar.js +13 -0
- package/lib/v2/diershoubing/router.js +3 -0
- package/lib/v2/diershoubing/templates/news.art +9 -0
- package/lib/v2/dmzj/maintainer.js +3 -0
- package/lib/v2/dmzj/news.js +26 -0
- package/lib/v2/dmzj/radar.js +67 -0
- package/lib/v2/dmzj/router.js +3 -0
- package/lib/v2/docschina/jsweekly.js +114 -0
- package/lib/v2/docschina/maintainer.js +3 -0
- package/lib/v2/docschina/radar.js +13 -0
- package/lib/v2/docschina/router.js +3 -0
- package/lib/v2/domp4/detail.js +7 -3
- package/lib/v2/domp4/utils.js +14 -0
- package/lib/v2/dongqiudi/player_news.js +2 -3
- package/lib/v2/dongqiudi/result.js +1 -1
- package/lib/v2/dongqiudi/router.js +1 -1
- package/lib/v2/dongqiudi/special.js +21 -27
- package/lib/v2/dongqiudi/team_news.js +2 -3
- package/lib/v2/dongqiudi/top_news.js +18 -24
- package/lib/v2/dongqiudi/utils.js +36 -36
- package/lib/v2/douban/other/weekly_best.js +5 -3
- package/lib/v2/douyin/hashtag.js +20 -19
- package/lib/v2/douyin/live.js +2 -21
- package/lib/v2/douyin/user.js +2 -17
- package/lib/v2/douyin/utils.js +85 -0
- package/lib/v2/{acm-ecnu → ecnu}/contest.js +1 -4
- package/lib/v2/ecnu/maintainer.js +4 -0
- package/lib/v2/ecnu/radar.js +30 -0
- package/lib/v2/ecnu/router.js +4 -0
- package/lib/v2/{acm-ecnu → ecnu}/templates/description.art +0 -0
- package/lib/v2/ecnu/yjs.js +37 -0
- package/lib/v2/economist/full.js +1 -1
- package/lib/v2/ehentai/ehapi.js +54 -10
- package/lib/v2/ehentai/maintainer.js +3 -3
- package/lib/v2/fantia/maintainer.js +4 -0
- package/lib/v2/fantia/radar.js +13 -0
- package/lib/v2/fantia/router.js +4 -0
- package/lib/{routes → v2}/fantia/search.js +8 -3
- package/lib/{routes → v2}/fantia/user.js +10 -5
- package/lib/v2/fastbull/express-news.js +33 -0
- package/lib/v2/fastbull/maintainer.js +5 -0
- package/lib/v2/fastbull/news.js +57 -0
- package/lib/v2/fastbull/radar.js +19 -0
- package/lib/v2/fastbull/router.js +5 -0
- package/lib/v2/fastbull/templates/description.art +7 -0
- package/lib/v2/finviz/maintainer.js +4 -0
- package/lib/v2/finviz/news.js +45 -0
- package/lib/{routes/finviz/news.js → v2/finviz/quote.js} +5 -5
- package/lib/v2/finviz/radar.js +19 -0
- package/lib/v2/finviz/router.js +4 -0
- package/lib/v2/foresightnews/index.js +8 -11
- package/lib/v2/foreverblog/feeds.js +36 -0
- package/lib/v2/foreverblog/maintainer.js +3 -0
- package/lib/v2/foreverblog/radar.js +13 -0
- package/lib/v2/foreverblog/router.js +3 -0
- package/lib/v2/freewechat/maintainer.js +3 -0
- package/lib/v2/freewechat/profile.js +61 -0
- package/lib/v2/freewechat/radar.js +13 -0
- package/lib/v2/freewechat/router.js +3 -0
- package/lib/v2/ft/maintainer.js +2 -2
- package/lib/v2/ft/utils.js +10 -7
- package/lib/v2/gamme/category.js +46 -0
- package/lib/v2/gamme/maintainer.js +6 -0
- package/lib/v2/gamme/radar.js +33 -0
- package/lib/v2/gamme/router.js +4 -0
- package/lib/v2/gamme/tag.js +57 -0
- package/lib/v2/gcores/category.js +16 -6
- package/lib/v2/gelonghui/home.js +31 -0
- package/lib/v2/gelonghui/keyword.js +34 -0
- package/lib/v2/gelonghui/maintainer.js +6 -0
- package/lib/v2/gelonghui/radar.js +31 -0
- package/lib/v2/gelonghui/router.js +6 -0
- package/lib/v2/gelonghui/subject.js +36 -0
- package/lib/v2/gelonghui/user.js +33 -0
- package/lib/v2/gelonghui/utils.js +21 -0
- package/lib/v2/gihyo/group.js +48 -0
- package/lib/v2/gihyo/maintainer.js +3 -0
- package/lib/v2/gihyo/radar.js +13 -0
- package/lib/v2/gihyo/router.js +3 -0
- package/lib/v2/github/pulls.js +7 -8
- package/lib/v2/github/router.js +1 -1
- package/lib/v2/github/topic.js +1 -1
- package/lib/v2/github/trending.js +68 -36
- package/lib/v2/good/index.js +53 -0
- package/lib/v2/good/maintainer.js +3 -0
- package/lib/v2/good/radar.js +13 -0
- package/lib/v2/good/router.js +3 -0
- package/lib/v2/gov/beijing/bphc/index.js +54 -0
- package/lib/v2/gov/ccdi/index.js +18 -0
- package/lib/v2/gov/ccdi/utils.js +94 -0
- package/lib/{routes/sse/sserules.js → v2/gov/cnnic/index.js} +18 -13
- package/lib/v2/gov/customs/list.js +1 -1
- package/lib/v2/gov/dianbai/dianbai.js +18 -0
- package/lib/v2/gov/gaozhou/gaozhou.js +19 -0
- package/lib/v2/gov/general/general.js +250 -0
- package/lib/v2/gov/general/templates/zcjdpt.art +128 -0
- package/lib/v2/gov/gz/index.js +38 -0
- package/lib/v2/gov/huazhou/huazhou.js +19 -0
- package/lib/v2/gov/hunan/changsha/major-email.js +52 -0
- package/lib/v2/gov/maintainer.js +29 -5
- package/lib/v2/gov/maoming/maoming.js +417 -0
- package/lib/v2/gov/maonan/maonan.js +100 -0
- package/lib/v2/gov/mgs/mgs.js +19 -0
- package/lib/v2/gov/mmht/mmht.js +19 -0
- package/lib/v2/gov/mofcom/article.js +68 -0
- package/lib/v2/gov/nmpa/generic.js +1 -1
- package/lib/v2/gov/nopss/index.js +57 -0
- package/lib/v2/gov/nrta/news.js +0 -1
- package/lib/v2/gov/radar.js +272 -1
- package/lib/v2/gov/router.js +28 -5
- package/lib/v2/gov/sasac/generic.js +42 -0
- package/lib/v2/gov/sdb/sdb.js +19 -0
- package/lib/v2/gov/shanghai/yjj/index.js +3 -1
- package/lib/{routes → v2}/gov/shenzhen/xxgk/zfxxgj.js +21 -15
- package/lib/v2/gov/stats/index.js +19 -0
- package/lib/v2/gov/stats/templates/attachments.art +5 -0
- package/lib/v2/gov/stats/utils.js +73 -0
- package/lib/v2/gov/xinyi/xinyi.js +19 -0
- package/lib/v2/gov/zhengce/govall.js +55 -0
- package/lib/v2/gov/zhengce/wenjian.js +47 -0
- package/lib/v2/gov/zhengce/zhengceku.js +22 -0
- package/lib/v2/gov/zhengce/zuixin.js +39 -0
- package/lib/v2/greasyfork/feedback.js +31 -0
- package/lib/v2/greasyfork/maintainer.js +5 -0
- package/lib/v2/greasyfork/radar.js +25 -0
- package/lib/v2/greasyfork/router.js +5 -0
- package/lib/{routes → v2}/greasyfork/scripts.js +4 -4
- package/lib/v2/greasyfork/versions.js +29 -0
- package/lib/v2/guanhai/index.js +47 -0
- package/lib/v2/guanhai/maintainer.js +4 -0
- package/lib/v2/guanhai/radar.js +13 -0
- package/lib/v2/guanhai/router.js +3 -0
- package/lib/v2/hackernews/index.js +16 -7
- package/lib/v2/hellogithub/index.js +102 -0
- package/lib/v2/hellogithub/maintainer.js +7 -3
- package/lib/v2/hellogithub/radar.js +35 -11
- package/lib/v2/hellogithub/report.js +56 -0
- package/lib/v2/hellogithub/router.js +6 -3
- package/lib/v2/hellogithub/templates/description.art +99 -0
- package/lib/v2/hellogithub/templates/report.art +118 -0
- package/lib/v2/hellogithub/templates/volume.art +36 -0
- package/lib/v2/hellogithub/volume.js +49 -0
- package/lib/v2/hit/hitgs.js +46 -0
- package/lib/v2/hit/jwc.js +60 -0
- package/lib/v2/hit/maintainer.js +5 -0
- package/lib/v2/hit/radar.js +29 -0
- package/lib/v2/hit/router.js +6 -0
- package/lib/v2/hit/today.js +59 -0
- package/lib/v2/hitwh/maintainer.js +3 -0
- package/lib/v2/hitwh/radar.js +13 -0
- package/lib/v2/hitwh/router.js +3 -0
- package/lib/v2/hitwh/today.js +52 -0
- package/lib/v2/hjedd/utils.js +2 -2
- package/lib/v2/{heu → hrbeu}/gx/card.js +5 -10
- package/lib/v2/{heu → hrbeu}/gx/list.js +12 -20
- package/lib/v2/hrbeu/job/bigemploy.js +25 -0
- package/lib/v2/{heu → hrbeu}/job/calendar.js +8 -16
- package/lib/v2/{heu → hrbeu}/job/list.js +11 -16
- package/lib/v2/{heu → hrbeu}/maintainer.js +2 -1
- package/lib/v2/{heu → hrbeu}/radar.js +18 -10
- package/lib/v2/{heu → hrbeu}/router.js +3 -2
- package/lib/v2/{heu → hrbeu}/uae/list.js +12 -17
- package/lib/v2/hrbeu/ugs/news.js +98 -0
- package/lib/v2/{heu → hrbeu}/yjsy/list.js +8 -16
- package/lib/v2/huanqiu/index.js +5 -3
- package/lib/v2/hupu/all.js +8 -8
- package/lib/v2/hupu/bbs.js +22 -1
- package/lib/v2/hupu/templates/description.art +11 -0
- package/lib/v2/hupu/templates/match.art +22 -0
- package/lib/v2/huxiu/briefColumn.js +51 -0
- package/lib/v2/huxiu/maintainer.js +1 -0
- package/lib/v2/huxiu/moment.js +40 -0
- package/lib/v2/huxiu/radar.js +12 -0
- package/lib/v2/huxiu/router.js +2 -0
- package/lib/v2/huxiu/templates/moment.art +16 -0
- package/lib/v2/ieee-security/maintainer.js +3 -0
- package/lib/v2/ieee-security/radar.js +13 -0
- package/lib/v2/ieee-security/router.js +3 -0
- package/lib/v2/ieee-security/sp.js +36 -0
- package/lib/v2/ifeng/maintainer.js +1 -0
- package/lib/v2/ifeng/news.js +54 -0
- package/lib/v2/ifeng/radar.js +7 -0
- package/lib/v2/ifeng/router.js +1 -0
- package/lib/v2/ifeng/templates/description.art +16 -0
- package/lib/v2/indiansinkuwait/latest.js +43 -0
- package/lib/v2/indiansinkuwait/maintainer.js +3 -0
- package/lib/v2/indiansinkuwait/radar.js +13 -0
- package/lib/v2/indiansinkuwait/router.js +3 -0
- package/lib/v2/iresearch/maintainer.js +1 -0
- package/lib/v2/iresearch/radar.js +7 -1
- package/lib/v2/iresearch/router.js +1 -0
- package/lib/v2/iresearch/templates/weekly.art +11 -0
- package/lib/v2/iresearch/weekly.js +39 -0
- package/lib/v2/islander/maintainer.js +4 -0
- package/lib/v2/islander/radar.js +19 -0
- package/lib/v2/islander/router.js +4 -0
- package/lib/v2/islander/search.js +33 -0
- package/lib/v2/islander/top30event.js +28 -0
- package/lib/v2/ithome/maintainer.js +1 -0
- package/lib/v2/ithome/radar.js +11 -0
- package/lib/v2/ithome/router.js +1 -0
- package/lib/v2/ithome/tw/feeds.js +38 -0
- package/lib/v2/iwara/subscriptions.js +1 -1
- package/lib/v2/jandan/index.js +17 -51
- package/lib/v2/jandan/maintainer.js +1 -1
- package/lib/v2/jandan/section.js +0 -1
- package/lib/v2/javbus/index.js +8 -2
- package/lib/v2/javbus/templates/description.art +12 -1
- package/lib/v2/jiemian/list.js +2 -2
- package/lib/v2/jike/user.js +1 -0
- package/lib/v2/jornada/index.js +59 -0
- package/lib/v2/jornada/maintainer.js +3 -0
- package/lib/v2/jornada/radar.js +13 -0
- package/lib/v2/jornada/router.js +3 -0
- package/lib/v2/jseea/maintainer.js +3 -0
- package/lib/v2/jseea/news.js +64 -0
- package/lib/v2/jseea/radar.js +13 -0
- package/lib/v2/jseea/router.js +3 -0
- package/lib/v2/kemono/index.js +2 -2
- package/lib/{routes → v2}/kuaidi100/index.js +0 -0
- package/lib/v2/kuaidi100/maintainer.js +4 -0
- package/lib/v2/kuaidi100/radar.js +25 -0
- package/lib/v2/kuaidi100/router.js +4 -0
- package/lib/{routes → v2}/kuaidi100/supported_company.js +0 -1
- package/lib/{routes → v2}/kuaidi100/utils.js +46 -11
- package/lib/v2/kuwaitlocal/index.js +47 -0
- package/lib/v2/kuwaitlocal/maintainer.js +4 -0
- package/lib/v2/kuwaitlocal/radar.js +19 -0
- package/lib/v2/kuwaitlocal/router.js +3 -0
- package/lib/v2/lang/maintainer.js +3 -0
- package/lib/v2/lang/radar.js +13 -0
- package/lib/v2/lang/room.js +40 -0
- package/lib/v2/lang/router.js +3 -0
- package/lib/v2/lang/templates/room.art +1 -0
- package/lib/v2/lianxh/index.js +61 -0
- package/lib/v2/{techflow520 → lianxh}/maintainer.js +0 -1
- package/lib/v2/lianxh/radar.js +13 -0
- package/lib/v2/{techflow520 → lianxh}/router.js +0 -1
- package/lib/{routes → v2}/linkresearcher/index.js +16 -13
- package/lib/v2/linkresearcher/maintainer.js +3 -0
- package/lib/v2/linkresearcher/radar.js +19 -0
- package/lib/v2/linkresearcher/router.js +3 -0
- package/lib/v2/linovelib/maintainer.js +3 -0
- package/lib/v2/linovelib/novel.js +33 -0
- package/lib/v2/linovelib/radar.js +13 -0
- package/lib/v2/linovelib/router.js +3 -0
- package/lib/v2/liulinblog/utils.js +7 -4
- package/lib/v2/lkong/forum.js +3 -2
- package/lib/v2/lofter/user.js +6 -1
- package/lib/v2/loltw/maintainer.js +3 -0
- package/lib/v2/loltw/news.js +36 -0
- package/lib/v2/loltw/radar.js +13 -0
- package/lib/v2/loltw/router.js +3 -0
- package/lib/v2/loltw/templates/news.art +6 -0
- package/lib/v2/lovelive-anime/maintainer.js +2 -0
- package/lib/v2/lovelive-anime/radar.js +21 -3
- package/lib/v2/lovelive-anime/router.js +2 -0
- package/lib/v2/lovelive-anime/schedules.js +56 -0
- package/lib/v2/lovelive-anime/templates/scheduleDesc.art +3 -0
- package/lib/v2/lovelive-anime/topics.js +84 -0
- package/lib/v2/luogu/contest.js +72 -0
- package/lib/v2/luogu/daily.js +33 -0
- package/lib/v2/luogu/maintainer.js +6 -0
- package/lib/v2/luogu/radar.js +31 -0
- package/lib/v2/luogu/router.js +6 -0
- package/lib/v2/luogu/userBlog.js +48 -0
- package/lib/v2/luogu/userFeed.js +30 -0
- package/lib/v2/lxixsxa/discography.js +54 -0
- package/lib/v2/lxixsxa/information.js +48 -0
- package/lib/v2/lxixsxa/jsonpHelper.js +19 -0
- package/lib/v2/lxixsxa/maintainer.js +4 -0
- package/lib/v2/lxixsxa/radar.js +36 -0
- package/lib/v2/lxixsxa/router.js +4 -0
- package/lib/v2/lxixsxa/templates/disco.art +5 -0
- package/lib/v2/lxixsxa/templates/info.art +4 -0
- package/lib/v2/macfilos/blog.js +61 -0
- package/lib/v2/macfilos/maintainer.js +3 -0
- package/lib/v2/macfilos/radar.js +13 -0
- package/lib/v2/macfilos/router.js +3 -0
- package/lib/v2/mangadex/index.js +73 -0
- package/lib/v2/mangadex/maintainer.js +3 -0
- package/lib/v2/mangadex/radar.js +13 -0
- package/lib/v2/mangadex/router.js +3 -0
- package/lib/{routes → v2}/manhuagui/comic.js +27 -12
- package/lib/v2/manhuagui/maintainer.js +6 -0
- package/lib/v2/manhuagui/radar.js +33 -0
- package/lib/v2/manhuagui/router.js +5 -0
- package/lib/v2/manhuagui/subscribe.js +54 -0
- package/lib/v2/manhuagui/templates/manga.art +2 -0
- package/lib/v2/mckinsey/cn/categoryMap.js +79 -0
- package/lib/v2/mckinsey/cn/index.js +37 -0
- package/lib/v2/mckinsey/radar.js +12 -0
- package/lib/v2/mckinsey/router.js +3 -0
- package/lib/v2/meituclub/latest.js +41 -0
- package/lib/v2/meituclub/maintainer.js +3 -0
- package/lib/v2/meituclub/radar.js +13 -0
- package/lib/v2/meituclub/router.js +3 -0
- package/lib/v2/meituclub/templates/description.art +1 -0
- package/lib/v2/meteor/boards.js +11 -0
- package/lib/v2/meteor/index.js +45 -0
- package/lib/v2/meteor/maintainer.js +4 -0
- package/lib/v2/meteor/radar.js +19 -0
- package/lib/v2/meteor/router.js +4 -0
- package/lib/v2/meteor/templates/desc.art +7 -0
- package/lib/v2/meteor/utils.js +90 -0
- package/lib/v2/mihoyo/maintainer.js +1 -0
- package/lib/v2/mihoyo/radar.js +20 -1
- package/lib/v2/mihoyo/router.js +1 -0
- package/lib/v2/mihoyo/ys/news.js +81 -0
- package/lib/v2/mingpao/index.js +28 -33
- package/lib/v2/mingpao/templates/description.art +1 -1
- package/lib/v2/mingpao/templates/fancybox.art +6 -2
- package/lib/v2/mirror/index.js +16 -12
- package/lib/v2/mrdx/daily.js +79 -0
- package/lib/v2/mrdx/maintainer.js +3 -0
- package/lib/v2/mrdx/radar.js +13 -0
- package/lib/v2/mrdx/router.js +3 -0
- package/lib/v2/mrdx/utils.js +17 -0
- package/lib/v2/mtime/maintainer.js +1 -1
- package/lib/v2/mtime/news.js +28 -24
- package/lib/v2/mtime/radar.js +1 -1
- package/lib/v2/nature/maintainer.js +5 -5
- package/lib/v2/nautil/maintainer.js +3 -0
- package/lib/v2/nautil/radar.js +13 -0
- package/lib/v2/nautil/router.js +3 -0
- package/lib/v2/nautil/templates/description.art +6 -0
- package/lib/v2/nautil/topics.js +57 -0
- package/lib/v2/ndss-symposium/maintainer.js +3 -0
- package/lib/v2/ndss-symposium/ndss.js +80 -0
- package/lib/v2/ndss-symposium/radar.js +13 -0
- package/lib/v2/ndss-symposium/router.js +3 -0
- package/lib/v2/nextapple/maintainer.js +3 -0
- package/lib/v2/nextapple/radar.js +13 -0
- package/lib/v2/nextapple/realtime.js +44 -0
- package/lib/v2/nextapple/router.js +3 -0
- package/lib/v2/nga/post.js +64 -9
- package/lib/v2/nga/radar.js +31 -48
- package/lib/v2/nikkei-asia/index.js +1 -1
- package/lib/v2/nintendo/direct.js +31 -0
- package/lib/v2/nintendo/eshop_cn.js +44 -0
- package/lib/v2/nintendo/eshop_hk.js +79 -0
- package/lib/v2/nintendo/eshop_jp.js +34 -0
- package/lib/v2/nintendo/eshop_us.js +32 -0
- package/lib/v2/nintendo/maintainer.js +7 -0
- package/lib/v2/nintendo/news.js +23 -0
- package/lib/v2/nintendo/news_china.js +35 -0
- package/lib/v2/nintendo/radar.js +70 -0
- package/lib/v2/nintendo/router.js +10 -0
- package/lib/{routes → v2}/nintendo/system-update.js +2 -2
- package/lib/v2/nintendo/templates/direct.art +6 -0
- package/lib/v2/nintendo/templates/eshop_cn.art +21 -0
- package/lib/v2/nintendo/templates/eshop_hk.art +61 -0
- package/lib/v2/nintendo/templates/eshop_jp.art +3 -0
- package/lib/v2/nintendo/templates/eshop_us.art +24 -0
- package/lib/{routes → v2}/nintendo/utils.js +35 -51
- package/lib/v2/nju/exchangesys.js +46 -0
- package/lib/v2/nju/hosptial.js +41 -0
- package/lib/v2/nju/itsc.js +46 -0
- package/lib/v2/nju/jw.js +43 -29
- package/lib/v2/nju/maintainer.js +4 -1
- package/lib/v2/nju/radar.js +48 -9
- package/lib/v2/nju/router.js +3 -0
- package/lib/v2/njxzc/home.js +66 -0
- package/lib/v2/njxzc/maintainer.js +3 -0
- package/lib/v2/njxzc/radar.js +13 -0
- package/lib/v2/njxzc/router.js +4 -0
- package/lib/v2/nmbxd1/forum.js +58 -0
- package/lib/v2/nmbxd1/maintainer.js +3 -0
- package/lib/v2/nmbxd1/radar.js +13 -0
- package/lib/v2/nmbxd1/router.js +3 -0
- package/lib/v2/nmbxd1/templates/description.art +65 -0
- package/lib/v2/nmtv/column.js +53 -0
- package/lib/v2/nmtv/maintainer.js +3 -0
- package/lib/v2/nmtv/radar.js +13 -0
- package/lib/v2/nmtv/router.js +3 -0
- package/lib/v2/nmtv/templates/description.art +9 -0
- package/lib/v2/nua/dc.js +63 -0
- package/lib/v2/nua/gra.js +9 -44
- package/lib/v2/nua/index.js +22 -0
- package/lib/v2/nua/lib.js +39 -0
- package/lib/v2/nua/maintainer.js +4 -0
- package/lib/v2/nua/radar.js +32 -0
- package/lib/v2/nua/router.js +4 -0
- package/lib/v2/nua/sxw.js +22 -0
- package/lib/v2/nua/utils.js +75 -0
- package/lib/v2/nuaa/college/cae.js +79 -0
- package/lib/v2/nuaa/college/cs.js +78 -0
- package/lib/v2/nuaa/jwc/jwc.js +21 -27
- package/lib/v2/nuaa/maintainer.js +4 -3
- package/lib/v2/nuaa/radar.js +6 -0
- package/lib/v2/nuaa/router.js +3 -2
- package/lib/v2/nuaa/utils/pypasswaf.js +3 -4
- package/lib/v2/nuaa/yjsy/yjsy.js +60 -41
- package/lib/v2/nyaa/main.js +16 -23
- package/lib/v2/nyaa/maintainer.js +7 -4
- package/lib/v2/nyaa/radar.js +27 -29
- package/lib/v2/nyaa/router.js +4 -2
- package/lib/v2/odaily/post.js +15 -20
- package/lib/v2/odaily/utils.js +1 -1
- package/lib/v2/oreno3d/main.js +104 -41
- package/lib/v2/oreno3d/maintainer.js +5 -5
- package/lib/v2/oreno3d/router.js +5 -5
- package/lib/v2/paradigm/maintainer.js +3 -0
- package/lib/v2/paradigm/radar.js +13 -0
- package/lib/v2/paradigm/router.js +3 -0
- package/lib/v2/paradigm/writing.js +44 -0
- package/lib/v2/picuki/maintainer.js +1 -1
- package/lib/v2/picuki/profile.js +24 -10
- package/lib/v2/picuki/templates/video.art +3 -0
- package/lib/v2/picuki/utils.js +21 -0
- package/lib/{routes → v2}/pixiv/api/getBookmarks.js +1 -3
- package/lib/{routes → v2}/pixiv/api/getIllustFollows.js +1 -3
- package/lib/{routes → v2}/pixiv/api/getIllusts.js +1 -3
- package/lib/{routes → v2}/pixiv/api/getRanking.js +2 -4
- package/lib/{routes → v2}/pixiv/api/getUserDetail.js +1 -3
- package/lib/{routes → v2}/pixiv/api/searchIllust.js +1 -3
- package/lib/{routes → v2}/pixiv/api/searchPopularIllust.js +1 -3
- package/lib/{routes → v2}/pixiv/bookmarks.js +4 -3
- package/lib/{routes → v2}/pixiv/constants.js +0 -0
- package/lib/{routes → v2}/pixiv/illustfollow.js +5 -4
- package/lib/v2/pixiv/maintainer.js +8 -0
- package/lib/v2/pixiv/novels.js +35 -0
- package/lib/{routes → v2}/pixiv/pixiv-got.js +1 -1
- package/lib/v2/pixiv/radar.js +43 -0
- package/lib/{routes → v2}/pixiv/ranking.js +7 -3
- package/lib/v2/pixiv/router.js +8 -0
- package/lib/{routes → v2}/pixiv/search.js +4 -3
- package/lib/v2/pixiv/token.js +86 -0
- package/lib/{routes → v2}/pixiv/user.js +4 -3
- package/lib/{routes → v2}/pixiv/utils.js +0 -0
- package/lib/v2/producthunt/templates/descImg.art +2 -2
- package/lib/v2/producthunt/today.js +8 -5
- package/lib/v2/pts/index.js +4 -1
- package/lib/v2/qianzhan/column.js +50 -0
- package/lib/v2/qianzhan/maintainer.js +4 -0
- package/lib/v2/qianzhan/radar.js +26 -0
- package/lib/v2/qianzhan/rank.js +40 -0
- package/lib/v2/qianzhan/router.js +4 -0
- package/lib/v2/qidian/author.js +41 -0
- package/lib/{routes → v2}/qidian/chapter.js +8 -14
- package/lib/{routes → v2}/qidian/forum.js +1 -3
- package/lib/{routes → v2}/qidian/free-next.js +1 -4
- package/lib/{routes → v2}/qidian/free.js +3 -5
- package/lib/v2/qidian/maintainer.js +7 -0
- package/lib/v2/qidian/radar.js +41 -0
- package/lib/v2/qidian/router.js +7 -0
- package/lib/v2/qidian/templates/description.art +5 -0
- package/lib/{routes → v2}/qingting/channel.js +6 -10
- package/lib/v2/qingting/maintainer.js +4 -0
- package/lib/v2/qingting/podcast.js +77 -0
- package/lib/v2/qingting/radar.js +19 -0
- package/lib/v2/qingting/router.js +4 -0
- package/lib/v2/qipamaijia/index.js +7 -1
- package/lib/v2/qipamaijia/maintainer.js +1 -1
- package/lib/v2/qlu/maintainer.js +3 -0
- package/lib/v2/qlu/notice.js +54 -0
- package/lib/v2/qlu/radar.js +13 -0
- package/lib/v2/qlu/router.js +3 -0
- package/lib/v2/qweather/now.js +1 -2
- package/lib/v2/radio/album.js +106 -0
- package/lib/v2/radio/index.js +25 -18
- package/lib/v2/radio/maintainer.js +2 -0
- package/lib/v2/radio/radar.js +15 -3
- package/lib/v2/radio/router.js +2 -0
- package/lib/v2/radio/templates/description.art +7 -4
- package/lib/v2/radio/zhibo.js +73 -0
- package/lib/v2/rarehistoricalphotos/index.js +28 -0
- package/lib/v2/rarehistoricalphotos/maintainer.js +3 -0
- package/lib/v2/rarehistoricalphotos/radar.js +13 -0
- package/lib/v2/rarehistoricalphotos/router.js +3 -0
- package/lib/v2/reactnewsletter/maintainer.js +4 -0
- package/lib/v2/reactnewsletter/radar.js +13 -0
- package/lib/v2/reactnewsletter/reactnewsletter.js +25 -0
- package/lib/v2/reactnewsletter/router.js +3 -0
- package/lib/v2/remnote/changelog.js +33 -0
- package/lib/v2/remnote/maintainer.js +3 -0
- package/lib/v2/remnote/radar.js +13 -0
- package/lib/v2/remnote/router.js +3 -0
- package/lib/v2/researchgate/maintainer.js +3 -0
- package/lib/v2/researchgate/publications.js +70 -0
- package/lib/v2/researchgate/radar.js +13 -0
- package/lib/v2/researchgate/router.js +3 -0
- package/lib/v2/reuters/common.js +21 -8
- package/lib/v2/reuters/investigates.js +1 -1
- package/lib/v2/reuters/templates/description.art +44 -0
- package/lib/v2/ruancan/index.js +13 -8
- package/lib/v2/saraba1st/digest.js +79 -0
- package/lib/v2/saraba1st/maintainer.js +4 -0
- package/lib/v2/saraba1st/radar.js +25 -0
- package/lib/v2/saraba1st/router.js +4 -0
- package/lib/v2/saraba1st/templates/digest.art +5 -0
- package/lib/v2/saraba1st/thread.js +63 -0
- package/lib/v2/science/cover.js +69 -0
- package/lib/v2/science/current.js +42 -0
- package/lib/v2/science/early.js +33 -0
- package/lib/v2/science/maintainer.js +5 -0
- package/lib/v2/science/radar.js +25 -0
- package/lib/v2/science/router.js +5 -0
- package/lib/v2/science/templates/article.art +2 -0
- package/lib/v2/science/templates/cover.art +2 -0
- package/lib/v2/science/utils.js +64 -0
- package/lib/v2/sciencedirect/journal.js +1 -1
- package/lib/{routes → v2}/scmp/index.js +7 -8
- package/lib/v2/scmp/maintainer.js +3 -0
- package/lib/v2/scmp/radar.js +13 -0
- package/lib/v2/scmp/router.js +3 -0
- package/lib/v2/sctv/maintainer.js +3 -0
- package/lib/v2/sctv/programme.js +80 -0
- package/lib/v2/sctv/radar.js +13 -0
- package/lib/v2/sctv/router.js +3 -0
- package/lib/v2/sctv/templates/description.art +3 -0
- package/lib/{routes → v2}/secrss/author.js +4 -2
- package/lib/{routes → v2}/secrss/category.js +8 -7
- package/lib/v2/secrss/maintainer.js +4 -0
- package/lib/v2/secrss/radar.js +19 -0
- package/lib/v2/secrss/router.js +4 -0
- package/lib/v2/shmtu/jwc.js +57 -0
- package/lib/v2/shmtu/maintainer.js +5 -0
- package/lib/v2/shmtu/portal.js +81 -0
- package/lib/v2/shmtu/radar.js +29 -0
- package/lib/v2/shmtu/router.js +5 -0
- package/lib/v2/shmtu/templates/portal.art +30 -0
- package/lib/v2/shmtu/www.js +58 -0
- package/lib/v2/sigsac/ccs.js +57 -0
- package/lib/v2/sigsac/maintainer.js +3 -0
- package/lib/v2/sigsac/radar.js +13 -0
- package/lib/v2/sigsac/router.js +3 -0
- package/lib/v2/simpleinfo/index.js +50 -0
- package/lib/v2/simpleinfo/maintainer.js +3 -0
- package/lib/v2/simpleinfo/radar.js +19 -0
- package/lib/v2/simpleinfo/router.js +3 -0
- package/lib/v2/simpleinfo/templates/description.art +6 -0
- package/lib/v2/smzdm/article.js +43 -0
- package/lib/v2/smzdm/baoliao.js +43 -0
- package/lib/v2/smzdm/haowen.js +48 -0
- package/lib/v2/smzdm/haowen_fenlei.js +50 -0
- package/lib/v2/smzdm/keyword.js +42 -0
- package/lib/v2/smzdm/maintainer.js +8 -0
- package/lib/v2/smzdm/radar.js +48 -0
- package/lib/{routes → v2}/smzdm/ranking.js +20 -3
- package/lib/v2/smzdm/router.js +8 -0
- package/lib/v2/sputniknews/index.js +2 -1
- package/lib/v2/sse/convert.js +39 -0
- package/lib/v2/sse/disclosure.js +46 -0
- package/lib/v2/sse/inquire.js +45 -0
- package/lib/v2/sse/lawandrules.js +43 -0
- package/lib/v2/sse/maintainer.js +7 -0
- package/lib/v2/sse/radar.js +41 -0
- package/lib/v2/sse/renewal.js +57 -0
- package/lib/v2/sse/router.js +7 -0
- package/lib/v2/sse/templates/inquire.art +7 -0
- package/lib/v2/sse/templates/renewal.art +13 -0
- package/lib/v2/stheadline/maintainer.js +3 -0
- package/lib/v2/stheadline/radar.js +13 -0
- package/lib/v2/stheadline/router.js +3 -0
- package/lib/v2/stheadline/std/realtime.js +46 -0
- package/lib/v2/swpu/cjxy.js +53 -0
- package/lib/v2/swpu/is.js +53 -0
- package/lib/v2/swpu/maintainer.js +2 -0
- package/lib/v2/swpu/radar.js +12 -0
- package/lib/v2/swpu/router.js +2 -0
- package/lib/v2/taoguba/blog.js +28 -3
- package/lib/v2/taoguba/index.js +29 -14
- package/lib/v2/taptap/changelog.js +11 -10
- package/lib/v2/taptap/maintainer.js +3 -1
- package/lib/v2/taptap/radar.js +17 -0
- package/lib/v2/taptap/review.js +83 -21
- package/lib/v2/taptap/router.js +4 -1
- package/lib/v2/taptap/topic.js +4 -4
- package/lib/v2/taptap/utils.js +8 -7
- package/lib/v2/techflowpost/express.js +33 -0
- package/lib/v2/techflowpost/index.js +30 -0
- package/lib/v2/techflowpost/maintainer.js +4 -0
- package/lib/v2/{techflow520 → techflowpost}/radar.js +6 -6
- package/lib/v2/techflowpost/router.js +5 -0
- package/lib/v2/telegram/channel.js +54 -38
- package/lib/v2/tencent/maintainer.js +2 -0
- package/lib/v2/tencent/news/coronavirus/data.js +71 -0
- package/lib/v2/tencent/news/coronavirus/total.js +34 -0
- package/lib/v2/tencent/news/coronavirus/utils.js +17 -0
- package/lib/v2/tencent/radar.js +8 -0
- package/lib/v2/tencent/router.js +2 -0
- package/lib/v2/tencent/templates/coronavirus/chinaTotal.art +6 -0
- package/lib/v2/tencent/templates/coronavirus/data.art +4 -0
- package/lib/v2/tesla/maintainer.js +3 -0
- package/lib/v2/tesla/price/get-price.js +25 -0
- package/lib/v2/tesla/price/index.js +41 -0
- package/lib/v2/tesla/radar.js +13 -0
- package/lib/v2/tesla/router.js +3 -0
- package/lib/v2/test/index.js +48 -0
- package/lib/v2/thecatcity/index.js +48 -0
- package/lib/v2/thecatcity/maintainer.js +3 -0
- package/lib/v2/thecatcity/radar.js +13 -0
- package/lib/v2/thecatcity/router.js +3 -0
- package/lib/v2/thecatcity/termsMap.js +30 -0
- package/lib/v2/theinitium/full.js +169 -0
- package/lib/v2/theinitium/maintainer.js +6 -0
- package/lib/v2/theinitium/radar.js +25 -0
- package/lib/v2/theinitium/router.js +3 -0
- package/lib/v2/thepaper/channel.js +11 -6
- package/lib/v2/thepaper/featured.js +9 -5
- package/lib/v2/thepaper/list.js +12 -6
- package/lib/v2/thepaper/maintainer.js +3 -3
- package/lib/v2/thepaper/radar.js +2 -2
- package/lib/v2/thepaper/templates/image_detail.art +6 -0
- package/lib/v2/thepaper/templates/video_detail.art +13 -0
- package/lib/v2/thepaper/utils.js +79 -42
- package/lib/v2/theverge/index.js +98 -0
- package/lib/v2/theverge/maintainer.js +3 -0
- package/lib/v2/theverge/radar.js +13 -0
- package/lib/v2/theverge/router.js +3 -0
- package/lib/v2/thwiki/index.js +32 -0
- package/lib/v2/thwiki/maintainer.js +3 -0
- package/lib/v2/thwiki/radar.js +13 -0
- package/lib/v2/thwiki/router.js +3 -0
- package/lib/v2/tiktok/user.js +1 -1
- package/lib/v2/tingshuitz/changsha.js +43 -0
- package/lib/v2/tingshuitz/maintainer.js +1 -0
- package/lib/v2/tingshuitz/radar.js +10 -0
- package/lib/v2/tingshuitz/router.js +1 -0
- package/lib/v2/trow/portal.js +13 -3
- package/lib/v2/twitter/web-api/twitter-api.js +19 -15
- package/lib/v2/twitter/web-api/twitter-got.js +2 -2
- package/lib/v2/twreporter/category.js +17 -8
- package/lib/v2/uber/blog.js +59 -0
- package/lib/v2/uber/maintainer.js +3 -0
- package/lib/v2/uber/radar.js +13 -0
- package/lib/v2/uber/router.js +3 -0
- package/lib/v2/udn/breaking-news.js +85 -0
- package/lib/v2/udn/global/index.js +67 -0
- package/lib/v2/udn/global/tag.js +51 -0
- package/lib/v2/udn/maintainer.js +5 -0
- package/lib/v2/udn/radar.js +27 -0
- package/lib/v2/udn/router.js +5 -0
- package/lib/v2/udn/templates/figure.art +4 -0
- package/lib/v2/unusualwhales/maintainer.js +3 -0
- package/lib/v2/unusualwhales/news.js +24 -0
- package/lib/v2/unusualwhales/radar.js +13 -0
- package/lib/v2/unusualwhales/router.js +3 -0
- package/lib/v2/usenix/maintainer.js +3 -0
- package/lib/v2/usenix/radar.js +13 -0
- package/lib/v2/usenix/router.js +3 -0
- package/lib/v2/usenix/usenix.js +63 -0
- package/lib/v2/usepanda/index.js +26 -0
- package/lib/v2/usepanda/maintainer.js +3 -0
- package/lib/v2/usepanda/radar.js +11 -0
- package/lib/v2/usepanda/router.js +3 -0
- package/lib/v2/uw/gix/news.js +67 -0
- package/lib/v2/uw/maintainer.js +3 -0
- package/lib/v2/uw/radar.js +13 -0
- package/lib/v2/uw/router.js +3 -0
- package/lib/v2/verse/articles.js +42 -0
- package/lib/v2/verse/maintainer.js +3 -0
- package/lib/v2/verse/radar.js +13 -0
- package/lib/v2/verse/router.js +3 -0
- package/lib/v2/vom/featured.js +50 -0
- package/lib/v2/vom/maintainer.js +3 -0
- package/lib/v2/vom/radar.js +13 -0
- package/lib/v2/vom/router.js +3 -0
- package/lib/v2/wallstreetcn/live.js +7 -1
- package/lib/v2/wallstreetcn/news.js +8 -6
- package/lib/v2/wallstreetcn/templates/description.art +11 -0
- package/lib/v2/warthunder/news.js +3 -1
- package/lib/v2/web3caff/index.js +63 -0
- package/lib/v2/web3caff/maintainer.js +3 -0
- package/lib/v2/web3caff/radar.js +13 -0
- package/lib/v2/web3caff/router.js +3 -0
- package/lib/v2/wechat/feeddd.js +1 -0
- package/lib/{routes → v2}/weibo/keyword.js +2 -2
- package/lib/v2/weibo/maintainer.js +8 -0
- package/lib/v2/weibo/oasis/user.js +20 -0
- package/lib/v2/weibo/radar.js +48 -0
- package/lib/v2/weibo/router.js +8 -0
- package/lib/{routes → v2}/weibo/search/hot.js +2 -0
- package/lib/{routes → v2}/weibo/super_index.js +2 -2
- package/lib/{routes → v2}/weibo/timeline.js +2 -2
- package/lib/{routes → v2}/weibo/user.js +2 -2
- package/lib/{routes → v2}/weibo/utils.js +50 -14
- package/lib/v2/wise/maintainer.js +3 -0
- package/lib/v2/wise/pair.js +65 -0
- package/lib/v2/wise/radar.js +11 -0
- package/lib/v2/wise/router.js +3 -0
- package/lib/v2/wise/templates/description.art +17 -0
- package/lib/v2/worldjournal/index.js +60 -0
- package/lib/v2/worldjournal/maintainer.js +3 -0
- package/lib/v2/worldjournal/radar.js +13 -0
- package/lib/v2/worldjournal/router.js +3 -0
- package/lib/v2/xjtu/dyyy/index.js +44 -0
- package/lib/v2/xjtu/maintainer.js +1 -0
- package/lib/v2/xjtu/radar.js +8 -0
- package/lib/v2/xjtu/router.js +1 -0
- package/lib/v2/xmnn/epaper.js +85 -0
- package/lib/v2/xmnn/maintainer.js +3 -0
- package/lib/v2/xmnn/radar.js +13 -0
- package/lib/v2/xmnn/router.js +3 -0
- package/lib/v2/xueqiu/maintainer.js +1 -0
- package/lib/v2/xueqiu/radar.js +6 -0
- package/lib/v2/xueqiu/router.js +1 -0
- package/lib/v2/xueqiu/today.js +65 -0
- package/lib/v2/xwlb/index.js +40 -0
- package/lib/v2/xwlb/maintainer.js +4 -0
- package/lib/v2/xwlb/radar.js +13 -0
- package/lib/v2/xwlb/router.js +4 -0
- package/lib/v2/xys/maintainer.js +3 -0
- package/lib/v2/xys/new.js +74 -0
- package/lib/v2/xys/radar.js +13 -0
- package/lib/v2/xys/router.js +3 -0
- package/lib/v2/xys/templates/desc.art +3 -0
- package/lib/v2/ymgal/article.js +61 -0
- package/lib/v2/ymgal/game.js +41 -0
- package/lib/v2/ymgal/maintainer.js +4 -0
- package/lib/v2/ymgal/radar.js +31 -0
- package/lib/v2/ymgal/router.js +4 -0
- package/lib/v2/ymgal/templates/description.art +7 -0
- package/lib/v2/yoasobi-music/info.js +68 -0
- package/lib/v2/yoasobi-music/jsonpHelper.js +19 -0
- package/lib/v2/yoasobi-music/live.js +52 -0
- package/lib/v2/yoasobi-music/maintainer.js +5 -0
- package/lib/v2/yoasobi-music/media.js +59 -0
- package/lib/v2/yoasobi-music/radar.js +31 -0
- package/lib/v2/yoasobi-music/router.js +5 -0
- package/lib/v2/yoasobi-music/templates/info.art +7 -0
- package/lib/v2/yoasobi-music/templates/live.art +12 -0
- package/lib/v2/yoasobi-music/templates/media.art +2 -0
- package/lib/v2/youtube/custom.js +45 -0
- package/lib/v2/youtube/radar.js +6 -0
- package/lib/v2/youtube/router.js +1 -0
- package/lib/v2/yxdown/maintainer.js +4 -0
- package/lib/{routes → v2}/yxdown/news.js +11 -8
- package/lib/v2/yxdown/radar.js +19 -0
- package/lib/{routes → v2}/yxdown/recommend.js +11 -8
- package/lib/v2/yxdown/router.js +4 -0
- package/lib/v2/yxdown/utils.js +17 -0
- package/lib/v2/zaobao/maintainer.js +1 -1
- package/lib/{routes → v2}/zcool/discover.js +29 -17
- package/lib/{routes → v2}/zcool/locations.js +0 -0
- package/lib/v2/zcool/maintainer.js +7 -0
- package/lib/v2/zcool/radar.js +55 -0
- package/lib/v2/zcool/router.js +5 -0
- package/lib/v2/zcool/templates/description.art +8 -0
- package/lib/v2/zcool/templates/work.art +11 -0
- package/lib/v2/zcool/top.js +51 -0
- package/lib/v2/zcool/user.js +48 -0
- package/lib/v2/zcool/utils.js +14 -0
- package/lib/v2/zhihu/activities.js +5 -9
- package/lib/v2/zhihu/daily.js +25 -0
- package/lib/v2/zhihu/execlib/x-zse-96_v3.js +122 -0
- package/lib/v2/zhihu/pin/utils.js +49 -41
- package/lib/v2/zhihu/posts.js +25 -17
- package/lib/v2/zhihu/question.js +3 -3
- package/lib/v2/zhihu/utils.js +10 -1
- package/lib/v2/zhitongcaijing/index.js +118 -0
- package/lib/v2/zhitongcaijing/maintainer.js +3 -0
- package/lib/v2/zhitongcaijing/radar.js +17 -0
- package/lib/v2/zhitongcaijing/router.js +3 -0
- package/lib/v2/zhitongcaijing/templates/description.art +6 -0
- package/lib/v2/zju/grs/index.js +11 -10
- package/lib/v2/zju/radar.js +5 -5
- package/lib/v2/zodgame/forum.js +54 -0
- package/lib/v2/zodgame/maintainer.js +3 -0
- package/lib/v2/zodgame/radar.js +18 -0
- package/lib/v2/zodgame/router.js +3 -0
- package/lib/v2/zodgame/templates/forum.art +1 -0
- package/package.json +45 -33
- package/lib/routes/adnmb/index.js +0 -69
- package/lib/routes/aljazeera/news.js +0 -38
- package/lib/routes/aqk/category.js +0 -22
- package/lib/routes/bangumi/calendar/_base.js +0 -43
- package/lib/routes/bangumi/group/reply.js +0 -36
- package/lib/routes/bangumi/group/topic.js +0 -26
- package/lib/routes/bangumi/subject/ep.js +0 -26
- package/lib/routes/blogs/foreverblog.js +0 -33
- package/lib/routes/ccdi/scdc.js +0 -51
- package/lib/routes/dcard/section.js +0 -47
- package/lib/routes/dcard/utils.js +0 -54
- package/lib/routes/dedao/knowledge.js +0 -78
- package/lib/routes/deepmind/blog.js +0 -43
- package/lib/routes/docschina/jsweekly.js +0 -47
- package/lib/routes/erbingapp/news.js +0 -51
- package/lib/routes/gelonghui/keyword.js +0 -36
- package/lib/routes/gelonghui/subject.js +0 -42
- package/lib/routes/gelonghui/user.js +0 -46
- package/lib/routes/gov/jiangsu/eea.js +0 -84
- package/lib/routes/gov/zhengce/govall.js +0 -59
- package/lib/routes/gov/zhengce/wenjian.js +0 -53
- package/lib/routes/gov/zhengce/zuixin.js +0 -42
- package/lib/routes/initium/full.js +0 -188
- package/lib/routes/kuaibao/index.js +0 -33
- package/lib/routes/langlive/room.js +0 -33
- package/lib/routes/logseq/changelog.js +0 -42
- package/lib/routes/luogu/contest.js +0 -28
- package/lib/routes/luogu/daily.js +0 -53
- package/lib/routes/luogu/userFeed.js +0 -38
- package/lib/routes/mckinsey/index.js +0 -49
- package/lib/routes/mhgui/comic.js +0 -99
- package/lib/routes/mofcom/article.js +0 -54
- package/lib/routes/nautilus/topics.js +0 -45
- package/lib/routes/nintendo/direct.js +0 -34
- package/lib/routes/nintendo/eshop_cn.js +0 -51
- package/lib/routes/nintendo/eshop_hk.js +0 -26
- package/lib/routes/nintendo/eshop_jp.js +0 -20
- package/lib/routes/nintendo/eshop_us.js +0 -36
- package/lib/routes/nintendo/news.js +0 -25
- package/lib/routes/nintendo/news_china.js +0 -41
- package/lib/routes/novel/shuquge.js +0 -63
- package/lib/routes/pixiv/token.js +0 -74
- package/lib/routes/researchgate/publications.js +0 -60
- package/lib/routes/saraba1st/thread.js +0 -45
- package/lib/routes/sciencemag/cover.js +0 -56
- package/lib/routes/sciencemag/current.js +0 -123
- package/lib/routes/sciencemag/early.js +0 -97
- package/lib/routes/smzdm/article.js +0 -57
- package/lib/routes/smzdm/baoliao.js +0 -55
- package/lib/routes/smzdm/haowen.js +0 -60
- package/lib/routes/smzdm/haowen_fenlei.js +0 -63
- package/lib/routes/smzdm/keyword.js +0 -39
- package/lib/routes/sse/convert.js +0 -32
- package/lib/routes/sse/disclosure.js +0 -34
- package/lib/routes/sse/inquire.js +0 -31
- package/lib/routes/sse/renewal.js +0 -61
- package/lib/routes/tieba/forum.js +0 -88
- package/lib/routes/tieba/user.js +0 -36
- package/lib/routes/transferwise/pair.js +0 -64
- package/lib/routes/twmanhuagui/comic.js +0 -99
- package/lib/routes/udn/global.js +0 -61
- package/lib/routes/universities/ecnuyjs/ecnuyjs.js +0 -23
- package/lib/routes/universities/hit/jwc.js +0 -53
- package/lib/routes/universities/hit/today.js +0 -85
- package/lib/routes/universities/hitwh/today.js +0 -46
- package/lib/routes/universities/shmtu/jwc.js +0 -75
- package/lib/routes/universities/shmtu/www.js +0 -61
- package/lib/routes/verge/index.js +0 -88
- package/lib/routes/weibo/oasis/user.js +0 -17
- package/lib/routes/xwlb/index.js +0 -40
- package/lib/routes/yuanshen/index.js +0 -70
- package/lib/routes/zcool/top.js +0 -75
- package/lib/routes/zcool/user.js +0 -58
- package/lib/v2/acm-ecnu/maintainer.js +0 -3
- package/lib/v2/acm-ecnu/radar.js +0 -19
- package/lib/v2/acm-ecnu/router.js +0 -3
- package/lib/v2/bilibili/collection.js +0 -34
- package/lib/v2/cnbeta/index.js +0 -16
- package/lib/v2/dongqiudi/daily.js +0 -47
- package/lib/v2/hellogithub/article.js +0 -47
- package/lib/v2/hellogithub/month.js +0 -42
- package/lib/v2/hellogithub/ranking.js +0 -39
- package/lib/v2/heu/job/bigemploy.js +0 -42
- package/lib/v2/nuaa/cs/index.js +0 -87
- package/lib/v2/radio/radio.js +0 -50
- package/lib/v2/techflow520/index.js +0 -34
- package/lib/v2/techflow520/newsflash.js +0 -32
- package/lib/v2/zhihu/execlib/g_encrypt.js +0 -407
- package/lib/v2/zhihu/execlib/jsencrypt.js +0 -379
package/lib/routes/bbc/index.js
CHANGED
package/lib/routes/cell/cover.js
CHANGED
|
@@ -7,10 +7,7 @@ module.exports = async (ctx) => {
|
|
|
7
7
|
url: 'https://idol.sankakucomplex.com/post/atom',
|
|
8
8
|
});
|
|
9
9
|
|
|
10
|
-
const $ = cheerio.load(response.data
|
|
11
|
-
normalizeWhitespace: true,
|
|
12
|
-
xmlMode: true,
|
|
13
|
-
});
|
|
10
|
+
const $ = cheerio.load(response.data);
|
|
14
11
|
|
|
15
12
|
ctx.state.data = {
|
|
16
13
|
title: 'Posts | Idol Complex - Idol & Cosplay Images',
|
package/lib/routes/v2ex/post.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
const got = require('@/utils/got');
|
|
2
2
|
const cheerio = require('cheerio');
|
|
3
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
3
4
|
|
|
4
5
|
module.exports = async (ctx) => {
|
|
5
6
|
const postid = ctx.params.postid;
|
|
@@ -29,8 +30,10 @@ module.exports = async (ctx) => {
|
|
|
29
30
|
guid: post.attr('id'),
|
|
30
31
|
link: `${pageUrl}#${post.attr('id')}`,
|
|
31
32
|
author: post.find('.dark').first().text(),
|
|
33
|
+
pubDate: parseDate(post.find('.ago').attr('title')),
|
|
32
34
|
};
|
|
33
35
|
})
|
|
34
36
|
.reverse(),
|
|
37
|
+
allowEmpty: true,
|
|
35
38
|
};
|
|
36
39
|
};
|
|
@@ -1,14 +1,10 @@
|
|
|
1
1
|
const got = require('@/utils/got');
|
|
2
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
2
3
|
|
|
3
4
|
module.exports = async (ctx) => {
|
|
4
5
|
const type = ctx.params.type;
|
|
5
6
|
|
|
6
|
-
const
|
|
7
|
-
method: 'get',
|
|
8
|
-
url: `https://www.v2ex.com/api/topics/${type}.json`,
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
const data = response.data;
|
|
7
|
+
const { data } = await got(`https://www.v2ex.com/api/topics/${type}.json`);
|
|
12
8
|
|
|
13
9
|
let title;
|
|
14
10
|
if (type === 'hot') {
|
|
@@ -25,10 +21,10 @@ module.exports = async (ctx) => {
|
|
|
25
21
|
title: item.title,
|
|
26
22
|
description: `${item.member.username}: ${item.content_rendered}`,
|
|
27
23
|
content: { text: item.content, html: item.content_rendered },
|
|
28
|
-
pubDate:
|
|
29
|
-
guid: item.id,
|
|
24
|
+
pubDate: parseDate(item.created, 'X'),
|
|
30
25
|
link: item.url,
|
|
31
26
|
author: item.member.username,
|
|
27
|
+
comments: item.replies,
|
|
32
28
|
})),
|
|
33
29
|
};
|
|
34
30
|
};
|
package/lib/utils/parse-date.js
CHANGED
|
@@ -70,19 +70,19 @@ const patterns = [
|
|
|
70
70
|
},
|
|
71
71
|
{
|
|
72
72
|
unit: 'days',
|
|
73
|
-
regExp: /(\d+)(?:天|日|
|
|
73
|
+
regExp: /(\d+)(?:天|日|d(?:ay)?(?:s)?)/,
|
|
74
74
|
},
|
|
75
75
|
{
|
|
76
76
|
unit: 'hours',
|
|
77
|
-
regExp: /(\d+)(?:(?:个|個)?(?:(?:小)?时|時|点|點)|h(?:ou)?r(?:s)?)/,
|
|
77
|
+
regExp: /(\d+)(?:(?:个|個)?(?:(?:小)?时|時|点|點)|h(?:(?:ou)?r)?(?:s)?)/,
|
|
78
78
|
},
|
|
79
79
|
{
|
|
80
80
|
unit: 'minutes',
|
|
81
|
-
regExp: /(\d+)(?:分(?:钟|鐘)?|
|
|
81
|
+
regExp: /(\d+)(?:分(?:钟|鐘)?|m(?:in(?:ute)?)?(?:s)?)/,
|
|
82
82
|
},
|
|
83
83
|
{
|
|
84
84
|
unit: 'seconds',
|
|
85
|
-
regExp: /(\d+)(?:秒(?:钟|鐘)?|
|
|
85
|
+
regExp: /(\d+)(?:秒(?:钟|鐘)?|s(?:ec(?:ond)?)?(?:s)?)/,
|
|
86
86
|
},
|
|
87
87
|
];
|
|
88
88
|
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Get Cookie-header-style cookie string from a puppeteer-style cookie array
|
|
3
|
+
*
|
|
4
|
+
* @param {import('puppeteer').Protocol.Network.CookieParam[]} cookies Puppeteer-style cookie array
|
|
5
|
+
* @param {RegExp | string} domainFilter Filter cookies by domain or RegExp
|
|
6
|
+
* @return {string} Cookie-header-style cookie string (e.g. "foobar; foo=bar; baz=qux")
|
|
7
|
+
*/
|
|
8
|
+
const parseCookieArray = (cookies, domainFilter = null) => {
|
|
9
|
+
if (typeof domainFilter === 'string') {
|
|
10
|
+
const dotDomain = '.' + domainFilter;
|
|
11
|
+
cookies = cookies.filter(({ domain }) => domain === domainFilter || domain.endsWith(dotDomain));
|
|
12
|
+
} else if (domainFilter && domainFilter.test !== undefined) {
|
|
13
|
+
cookies = cookies.filter(({ domain }) => domainFilter.test(domain));
|
|
14
|
+
}
|
|
15
|
+
// {name: '', value: 'foobar'} => 'foobar' // https://stackoverflow.com/questions/42531198/cookie-without-a-name
|
|
16
|
+
// {name: 'foo', value: 'bar'} => 'foo=bar'
|
|
17
|
+
return cookies.map(({ name, value }) => (name ? `${name}=${value}` : value)).join('; ');
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Construct a puppeteer-style cookie array from a Cookie-header-style cookie string
|
|
22
|
+
*
|
|
23
|
+
* @param {string} cookieStr Cookie-header-style cookie string (e.g. "foobar; foo=bar; baz=qux")
|
|
24
|
+
* @param {string} domain Domain to set for each cookie
|
|
25
|
+
* @return {import('puppeteer').Protocol.Network.CookieParam[]} Puppeteer-style cookie array
|
|
26
|
+
*/
|
|
27
|
+
const constructCookieArray = (cookieStr, domain) =>
|
|
28
|
+
cookieStr.split('; ').map((item) => {
|
|
29
|
+
const [name, value] = item.split('=');
|
|
30
|
+
return value === undefined ? { name: '', value: name, domain } : { name, value, domain };
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Set cookies for a page
|
|
35
|
+
*
|
|
36
|
+
* @param {import('puppeteer').Page} page Puppeteer Page object
|
|
37
|
+
* @param {string} cookieStr Cookie-header-style cookie string (e.g. "foobar; foo=bar; baz=qux")
|
|
38
|
+
* @param {string} domain Domain to set for each cookie
|
|
39
|
+
* @return {Promise<void>}
|
|
40
|
+
*/
|
|
41
|
+
const setCookies = async (page, cookieStr, domain) => {
|
|
42
|
+
const cookies = constructCookieArray(cookieStr, domain);
|
|
43
|
+
await page.setCookie(...cookies);
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Get Cookie-header-style cookie string from a page
|
|
48
|
+
*
|
|
49
|
+
* @param {import('puppeteer').Page} page Puppeteer Page object
|
|
50
|
+
* @param {RegExp | string} domainFilter Filter cookies by domain or RegExp
|
|
51
|
+
* @return {Promise<string>} Cookie-header-style cookie string
|
|
52
|
+
*/
|
|
53
|
+
const getCookies = async (page, domainFilter = null) => {
|
|
54
|
+
const cookies = await page.cookies();
|
|
55
|
+
return parseCookieArray(cookies, domainFilter);
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
module.exports = {
|
|
59
|
+
parseCookieArray,
|
|
60
|
+
constructCookieArray,
|
|
61
|
+
setCookies,
|
|
62
|
+
getCookies,
|
|
63
|
+
};
|
package/lib/utils/puppeteer.js
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
const config = require('@/config').value;
|
|
2
|
+
const { proxyUri, proxyUrlHandler } = require('./unify-proxy');
|
|
2
3
|
let puppeteer = require('puppeteer');
|
|
4
|
+
const proxyChain = require('proxy-chain');
|
|
5
|
+
const logger = require('./logger');
|
|
3
6
|
|
|
4
7
|
const options = {
|
|
5
8
|
args: ['--no-sandbox', '--disable-setuid-sandbox', '--disable-infobars', '--window-position=0,0', '--ignore-certificate-errors', '--ignore-certificate-errors-spki-list', `--user-agent=${config.ua}`],
|
|
@@ -41,6 +44,19 @@ module.exports = async (extraOptions = {}) => {
|
|
|
41
44
|
puppeteer.use(require('puppeteer-extra-plugin-stealth')());
|
|
42
45
|
}
|
|
43
46
|
let browser;
|
|
47
|
+
if (proxyUri) {
|
|
48
|
+
if (proxyUrlHandler.username || proxyUrlHandler.password) {
|
|
49
|
+
// only proxies with authentication need to be anonymized
|
|
50
|
+
if (proxyUrlHandler.protocol === 'http:') {
|
|
51
|
+
options.args.push(`--proxy-server=${await proxyChain.anonymizeProxy(proxyUri)}`);
|
|
52
|
+
} else {
|
|
53
|
+
logger.warn('SOCKS/HTTPS proxy with authentication is not supported by puppeteer, continue without proxy');
|
|
54
|
+
}
|
|
55
|
+
} else {
|
|
56
|
+
// Chromium cannot recognize socks5h and socks4a, so we need to trim their postfixes
|
|
57
|
+
options.args.push(`--proxy-server=${proxyUri.replace('socks5h://', 'socks5://').replace('socks4a://', 'socks4://')}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
44
60
|
if (config.puppeteerWSEndpoint) {
|
|
45
61
|
browser = await puppeteer.connect({
|
|
46
62
|
browserWSEndpoint: config.puppeteerWSEndpoint,
|
package/lib/utils/render.js
CHANGED
|
@@ -2,6 +2,51 @@ const art = require('art-template');
|
|
|
2
2
|
|
|
3
3
|
// We may add more control over it later
|
|
4
4
|
|
|
5
|
+
/**
|
|
6
|
+
* This function should be used by RSSHub middleware only.
|
|
7
|
+
* @param {object} data ctx.state.data
|
|
8
|
+
* @returns `JSON.stringify`-ed [JSON Feed](https://www.jsonfeed.org/)
|
|
9
|
+
*/
|
|
10
|
+
const json = (data) => {
|
|
11
|
+
const jsonFeed = {
|
|
12
|
+
version: 'https://jsonfeed.org/version/1.1',
|
|
13
|
+
title: data.title || 'RSSHub',
|
|
14
|
+
home_page_url: data.link || 'https://docs.rsshub.app',
|
|
15
|
+
feed_url: data.feedLink,
|
|
16
|
+
description: `${data.description || data.title} - Made with love by RSSHub(https://github.com/DIYgod/RSSHub)`,
|
|
17
|
+
icon: data.image,
|
|
18
|
+
authors: typeof data.author === 'string' ? [{ name: data.author }] : data.author,
|
|
19
|
+
language: data.language || 'zh-cn',
|
|
20
|
+
items: data.item.map((item) => ({
|
|
21
|
+
id: item.guid || item.id || item.link,
|
|
22
|
+
url: item.link,
|
|
23
|
+
title: item.title,
|
|
24
|
+
content_html: (item.content && item.content.html) || item.description || item.title,
|
|
25
|
+
content_text: item.content && item.content.text,
|
|
26
|
+
image: item.image,
|
|
27
|
+
banner_image: item.banner,
|
|
28
|
+
date_published: item.pubDate,
|
|
29
|
+
date_modified: item.updated,
|
|
30
|
+
authors: typeof item.author === 'string' ? [{ name: item.author }] : item.author,
|
|
31
|
+
tags: typeof item.category === 'string' ? [item.category] : item.category,
|
|
32
|
+
language: item.language,
|
|
33
|
+
attachments: item.enclosure_url
|
|
34
|
+
? [
|
|
35
|
+
{
|
|
36
|
+
url: item.enclosure_url,
|
|
37
|
+
mime_type: item.enclosure_type,
|
|
38
|
+
title: item.enclosure_title,
|
|
39
|
+
size_in_bytes: item.enclosure_length,
|
|
40
|
+
duration_in_seconds: item.itunes_duration,
|
|
41
|
+
},
|
|
42
|
+
]
|
|
43
|
+
: undefined,
|
|
44
|
+
})),
|
|
45
|
+
};
|
|
46
|
+
return JSON.stringify(jsonFeed, null, 4);
|
|
47
|
+
};
|
|
48
|
+
|
|
5
49
|
module.exports = {
|
|
6
50
|
art,
|
|
51
|
+
json,
|
|
7
52
|
};
|
|
@@ -1,121 +1,65 @@
|
|
|
1
1
|
const config = require('@/config').value;
|
|
2
|
+
const { proxyUri, proxyObj, proxyUrlHandler } = require('./unify-proxy');
|
|
2
3
|
const logger = require('./logger');
|
|
3
4
|
const http = require('http');
|
|
4
5
|
const https = require('https');
|
|
5
6
|
|
|
6
|
-
let tunnel;
|
|
7
|
-
let HttpsProxyAgent;
|
|
8
|
-
let SocksProxyAgent;
|
|
9
|
-
|
|
10
7
|
let agent = null;
|
|
11
|
-
if (
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
proxy = new SocksProxyAgent(config.proxyUri);
|
|
19
|
-
} else {
|
|
20
|
-
throw 'Unknown proxy-uri format';
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
agent = {
|
|
24
|
-
http: proxy,
|
|
25
|
-
https: proxy,
|
|
26
|
-
};
|
|
27
|
-
} else if (config.proxy && config.proxy.protocol && config.proxy.host && config.proxy.port) {
|
|
28
|
-
agent = {};
|
|
29
|
-
const proxyUrl = `${config.proxy.protocol}://${config.proxy.host}:${config.proxy.port}`;
|
|
30
|
-
|
|
31
|
-
switch (config.proxy.protocol) {
|
|
32
|
-
case 'socks':
|
|
33
|
-
SocksProxyAgent = SocksProxyAgent || require('socks-proxy-agent').SocksProxyAgent;
|
|
34
|
-
agent.http = new SocksProxyAgent(proxyUrl);
|
|
35
|
-
agent.https = new SocksProxyAgent(proxyUrl);
|
|
36
|
-
break;
|
|
37
|
-
case 'http':
|
|
38
|
-
tunnel = tunnel || require('tunnel');
|
|
39
|
-
process.env.NODE_TLS_REJECT_UNAUTHORIZED = 0;
|
|
40
|
-
agent.http = tunnel.httpOverHttp({
|
|
41
|
-
proxy: {
|
|
42
|
-
host: config.proxy.host,
|
|
43
|
-
port: parseInt(config.proxy.port),
|
|
44
|
-
},
|
|
45
|
-
});
|
|
46
|
-
agent.https = tunnel.httpsOverHttp({
|
|
47
|
-
proxy: {
|
|
48
|
-
host: config.proxy.host,
|
|
49
|
-
port: parseInt(config.proxy.port),
|
|
50
|
-
},
|
|
51
|
-
});
|
|
52
|
-
break;
|
|
53
|
-
case 'https':
|
|
54
|
-
tunnel = tunnel || require('tunnel');
|
|
55
|
-
agent.http = tunnel.httpOverHttps({
|
|
56
|
-
proxy: {
|
|
57
|
-
host: config.proxy.host,
|
|
58
|
-
port: parseInt(config.proxy.port),
|
|
59
|
-
},
|
|
60
|
-
});
|
|
61
|
-
agent.https = tunnel.httpsOverHttps({
|
|
62
|
-
proxy: {
|
|
63
|
-
host: config.proxy.host,
|
|
64
|
-
port: parseInt(config.proxy.port),
|
|
65
|
-
},
|
|
66
|
-
});
|
|
67
|
-
break;
|
|
8
|
+
if (proxyUri) {
|
|
9
|
+
if (proxyUri.startsWith('http')) {
|
|
10
|
+
const HttpsProxyAgent = require('https-proxy-agent');
|
|
11
|
+
agent = new HttpsProxyAgent(proxyUri);
|
|
12
|
+
} else if (proxyUri.startsWith('socks')) {
|
|
13
|
+
const SocksProxyAgent = require('socks-proxy-agent').SocksProxyAgent;
|
|
14
|
+
agent = new SocksProxyAgent(proxyUri);
|
|
68
15
|
}
|
|
69
16
|
}
|
|
70
17
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
try {
|
|
76
|
-
agentResult = agent[(options.protocol || url.match(/(https?:)/)[1]).slice(0, -1)];
|
|
77
|
-
} catch (error) {
|
|
78
|
-
agentResult = null;
|
|
79
|
-
}
|
|
80
|
-
options.agent = agentResult;
|
|
18
|
+
let proxyWrapper = () => false;
|
|
19
|
+
if (agent) {
|
|
20
|
+
const proxyRegex = new RegExp(proxyObj.url_regex);
|
|
21
|
+
const protocolMatch = (protocolLike) => protocolLike && protocolLike.toLowerCase().startsWith('http');
|
|
81
22
|
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
23
|
+
proxyWrapper = (url, options, urlHandler) => {
|
|
24
|
+
if (proxyRegex.test(url)) {
|
|
25
|
+
if ((protocolMatch(options.protocol) || protocolMatch(url)) && (!urlHandler || urlHandler.host !== proxyUrlHandler.host)) {
|
|
26
|
+
options.agent = agent;
|
|
27
|
+
if (proxyObj.auth) {
|
|
28
|
+
options.headers['Proxy-Authorization'] = `Basic ${proxyObj.auth}`;
|
|
29
|
+
}
|
|
30
|
+
return true;
|
|
85
31
|
}
|
|
86
|
-
options.headers['Proxy-Authorization'] = `Basic ${config.proxy.auth}`;
|
|
87
32
|
}
|
|
88
|
-
|
|
89
|
-
}
|
|
90
|
-
|
|
33
|
+
return false;
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
const requestWrapper = (url, options) => {
|
|
38
|
+
let urlHandler;
|
|
39
|
+
try {
|
|
40
|
+
urlHandler = new URL(url);
|
|
41
|
+
} catch (error) {
|
|
42
|
+
// ignore
|
|
91
43
|
}
|
|
44
|
+
options.headers = options.headers || {};
|
|
45
|
+
const headersLowerCaseKeys = Object.keys(options.headers).map((key) => key.toLowerCase());
|
|
46
|
+
|
|
47
|
+
proxyWrapper(url, options, urlHandler) ? logger.info(`Proxy for ${url}`) : logger.debug(`Requesting ${url}`);
|
|
92
48
|
|
|
93
49
|
// ua
|
|
94
|
-
|
|
95
|
-
for (const header in options.headers) {
|
|
96
|
-
if (header.toLowerCase() === 'user-agent') {
|
|
97
|
-
hasUA = true;
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
if (!hasUA) {
|
|
101
|
-
if (!options.headers) {
|
|
102
|
-
options.headers = {};
|
|
103
|
-
}
|
|
50
|
+
if (!headersLowerCaseKeys.includes('user-agent')) {
|
|
104
51
|
options.headers['user-agent'] = config.ua;
|
|
105
52
|
}
|
|
106
53
|
|
|
107
|
-
|
|
108
|
-
const urlHandler = new URL(url);
|
|
54
|
+
if (urlHandler) {
|
|
109
55
|
// referer
|
|
110
|
-
if (!
|
|
56
|
+
if (!headersLowerCaseKeys.includes('referer')) {
|
|
111
57
|
options.headers.referer = urlHandler.origin;
|
|
112
58
|
}
|
|
113
59
|
// host
|
|
114
|
-
if (!
|
|
60
|
+
if (!headersLowerCaseKeys.includes('host')) {
|
|
115
61
|
options.headers.host = urlHandler.host;
|
|
116
62
|
}
|
|
117
|
-
} catch (e) {
|
|
118
|
-
// do nothing
|
|
119
63
|
}
|
|
120
64
|
};
|
|
121
65
|
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
const config = require('@/config').value;
|
|
2
|
+
const logger = require('./logger');
|
|
3
|
+
|
|
4
|
+
const defaultProtocol = 'http';
|
|
5
|
+
const possibleProtocol = ['http', 'https', 'socks', 'socks4', 'socks4a', 'socks5', 'socks5h'];
|
|
6
|
+
|
|
7
|
+
const unifyProxy = (proxyUri, proxyObj) => {
|
|
8
|
+
proxyObj = proxyObj || {};
|
|
9
|
+
const [oriProxyUri, oriProxyObj] = [proxyUri, proxyObj];
|
|
10
|
+
proxyObj = { ...proxyObj };
|
|
11
|
+
|
|
12
|
+
let proxyUrlHandler;
|
|
13
|
+
|
|
14
|
+
// PROXY_URI
|
|
15
|
+
if (proxyUri && typeof proxyUri === 'string') {
|
|
16
|
+
if (!proxyUri.includes('://')) {
|
|
17
|
+
logger.warn(`PROXY_URI contains no protocol, assuming ${defaultProtocol}`);
|
|
18
|
+
proxyUri = `${defaultProtocol}://${proxyUri}`;
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
proxyUrlHandler = new URL(proxyUri);
|
|
22
|
+
} catch (e) {
|
|
23
|
+
logger.error(`Parse PROXY_URI error: ${e.stack}`);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// PROXY_{PROTOCOL,HOST,PORT}
|
|
28
|
+
if (proxyObj.protocol || proxyObj.host || proxyObj.port) {
|
|
29
|
+
if (proxyUrlHandler) {
|
|
30
|
+
logger.warn('PROXY_URI is set, ignoring PROXY_{PROTOCOL,HOST,PORT}');
|
|
31
|
+
} else if (proxyObj.host) {
|
|
32
|
+
let tempProxyStr = proxyObj.host;
|
|
33
|
+
|
|
34
|
+
if (tempProxyStr.includes('://')) {
|
|
35
|
+
logger.warn('PROXY_HOST contains protocol, ignoring PROXY_PROTOCOL');
|
|
36
|
+
} else if (!proxyObj.protocol) {
|
|
37
|
+
logger.warn(`PROXY_PROTOCOL is not set, assuming '${defaultProtocol}'`);
|
|
38
|
+
tempProxyStr = `${defaultProtocol}://${tempProxyStr}`;
|
|
39
|
+
} else {
|
|
40
|
+
tempProxyStr = `${proxyObj.protocol}://${tempProxyStr}`;
|
|
41
|
+
}
|
|
42
|
+
try {
|
|
43
|
+
proxyUrlHandler = new URL(tempProxyStr);
|
|
44
|
+
if (proxyUrlHandler.port && proxyObj.port) {
|
|
45
|
+
logger.warn('PROXY_HOST contains port, ignoring PROXY_PORT');
|
|
46
|
+
} else if (proxyObj.port) {
|
|
47
|
+
if (!parseInt(proxyObj.port)) {
|
|
48
|
+
logger.warn(`PROXY_PORT is not a number, ignoring`);
|
|
49
|
+
} else {
|
|
50
|
+
proxyUrlHandler.port = proxyObj.port;
|
|
51
|
+
}
|
|
52
|
+
} else {
|
|
53
|
+
logger.warn('PROXY_PORT is not set, leaving proxy agent to determine');
|
|
54
|
+
}
|
|
55
|
+
} catch (e) {
|
|
56
|
+
logger.error(`Parse PROXY_HOST error: ${e.stack}`);
|
|
57
|
+
}
|
|
58
|
+
} else {
|
|
59
|
+
logger.warn('Either PROXY_{PROTOCOL,PORT} is set, but PROXY_HOST is missing, ignoring');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// PROXY_AUTH
|
|
64
|
+
if (proxyObj.auth && proxyUrlHandler) {
|
|
65
|
+
let promptProxyUri = false;
|
|
66
|
+
if (proxyUrlHandler.username || proxyUrlHandler.password) {
|
|
67
|
+
logger.warn('PROXY_URI contains username and/or password, ignoring PROXY_AUTH');
|
|
68
|
+
proxyObj.auth = undefined;
|
|
69
|
+
} else if (!['http:', 'https:'].includes(proxyUrlHandler.protocol)) {
|
|
70
|
+
logger.warn(`PROXY_AUTH is only supported by HTTP(S) proxies, but got ${proxyUrlHandler.protocol}, ignoring`);
|
|
71
|
+
proxyObj.auth = undefined;
|
|
72
|
+
promptProxyUri = true;
|
|
73
|
+
} else {
|
|
74
|
+
logger.info('PROXY_AUTH is set and will be used for requests from Node.js. However, requests from puppeteer will not use it');
|
|
75
|
+
promptProxyUri = true;
|
|
76
|
+
}
|
|
77
|
+
if (promptProxyUri) {
|
|
78
|
+
logger.info('To get rid of this, set PROXY_URI like protocol://username:password@host:port and clear PROXY_{AUTH,PROTOCOL,HOST,PORT}');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// is proxy enabled and valid?
|
|
83
|
+
let isProxyValid = false;
|
|
84
|
+
if (proxyUrlHandler) {
|
|
85
|
+
const protocol = proxyUrlHandler.protocol.replace(':', '');
|
|
86
|
+
if (possibleProtocol.includes(protocol)) {
|
|
87
|
+
if (protocol !== 'http' && (proxyUrlHandler.username || proxyUrlHandler.password)) {
|
|
88
|
+
logger.warn("PROXY_URI is an HTTPS/SOCKS proxy with authentication, which is not supported by puppeteer (ignore if you don't need it)");
|
|
89
|
+
logger.info('To get rid of this, consider using an HTTP proxy instead');
|
|
90
|
+
}
|
|
91
|
+
proxyObj.protocol = protocol;
|
|
92
|
+
proxyObj.host = proxyUrlHandler.hostname;
|
|
93
|
+
proxyObj.port = parseInt(proxyUrlHandler.port) || undefined;
|
|
94
|
+
// trailing slash will cause puppeteer to throw net::ERR_NO_SUPPORTED_PROXIES, trim it
|
|
95
|
+
proxyUri = proxyUrlHandler.href.endsWith('/') ? proxyUrlHandler.href.slice(0, -1) : proxyUrlHandler.href;
|
|
96
|
+
isProxyValid = true;
|
|
97
|
+
} else {
|
|
98
|
+
logger.error(`Unsupported proxy protocol: ${protocol}, expect one of ${possibleProtocol.join(', ')}`);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
if (!isProxyValid) {
|
|
102
|
+
if ((oriProxyUri && typeof oriProxyUri === 'string') || oriProxyObj.protocol || oriProxyObj.host || oriProxyObj.port || oriProxyObj.auth) {
|
|
103
|
+
logger.error('Proxy is disabled due to misconfiguration');
|
|
104
|
+
}
|
|
105
|
+
proxyObj.protocol = proxyObj.host = proxyObj.port = proxyObj.auth = undefined;
|
|
106
|
+
proxyUri = null;
|
|
107
|
+
proxyUrlHandler = null;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
return { proxyUri, proxyObj, proxyUrlHandler };
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
module.exports = {
|
|
114
|
+
unifyProxy,
|
|
115
|
+
...unifyProxy(config.proxyUri, config.proxy),
|
|
116
|
+
};
|
package/lib/utils/wechat-mp.js
CHANGED
package/lib/v2/18comic/utils.js
CHANGED
|
@@ -24,7 +24,7 @@ module.exports = {
|
|
|
24
24
|
|
|
25
25
|
return {
|
|
26
26
|
title: item.text().trim(),
|
|
27
|
-
link: `${rootUrl}${item.prev().
|
|
27
|
+
link: `${rootUrl}${item.prev().find('a').attr('href')}`,
|
|
28
28
|
};
|
|
29
29
|
});
|
|
30
30
|
|
|
@@ -52,7 +52,7 @@ module.exports = {
|
|
|
52
52
|
.join(', ');
|
|
53
53
|
item.description = `<p>${content('#intro-block .p-t-5').text()}</p><img src="${content('.img_zoom_img img')
|
|
54
54
|
.toArray()
|
|
55
|
-
.map((image) => content(image).attr('
|
|
55
|
+
.map((image) => content(image).attr('data-original'))
|
|
56
56
|
.join('"><img src="')}">`;
|
|
57
57
|
|
|
58
58
|
return item;
|
package/lib/v2/35photo/genre.js
CHANGED
|
@@ -4,6 +4,7 @@ module.exports = async (ctx) => {
|
|
|
4
4
|
const id = ctx.params.id;
|
|
5
5
|
|
|
6
6
|
const currentUrl = `${rootUrl}/genre_${id}`;
|
|
7
|
+
const apiUrl = `${rootUrl}/show_block.php?type=getNextPageData&page=genre&community_id=${id}`;
|
|
7
8
|
|
|
8
|
-
ctx.state.data = await ProcessItems(currentUrl);
|
|
9
|
+
ctx.state.data = await ProcessItems(currentUrl, apiUrl);
|
|
9
10
|
};
|
package/lib/v2/35photo/utils.js
CHANGED
|
@@ -5,13 +5,28 @@ const rootUrl = 'https://35photo.pro';
|
|
|
5
5
|
|
|
6
6
|
module.exports = {
|
|
7
7
|
rootUrl,
|
|
8
|
-
ProcessItems: async (currentUrl) => {
|
|
9
|
-
|
|
8
|
+
ProcessItems: async (currentUrl, apiUrl) => {
|
|
9
|
+
let $, response;
|
|
10
|
+
|
|
11
|
+
response = await got({
|
|
10
12
|
method: 'get',
|
|
11
13
|
url: currentUrl,
|
|
12
14
|
});
|
|
13
15
|
|
|
14
|
-
const
|
|
16
|
+
const data = response.data;
|
|
17
|
+
|
|
18
|
+
$ = cheerio.load(data);
|
|
19
|
+
|
|
20
|
+
const title = $('h1').text();
|
|
21
|
+
|
|
22
|
+
if (apiUrl) {
|
|
23
|
+
response = await got({
|
|
24
|
+
method: 'get',
|
|
25
|
+
url: `${apiUrl}&lastId=${$('div.countLike').last().attr('photo-id')}`,
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
$ = cheerio.load(data + response.data.data);
|
|
29
|
+
}
|
|
15
30
|
|
|
16
31
|
const items = $('.item')
|
|
17
32
|
.toArray()
|
|
@@ -34,7 +49,7 @@ module.exports = {
|
|
|
34
49
|
});
|
|
35
50
|
|
|
36
51
|
return {
|
|
37
|
-
title: `${
|
|
52
|
+
title: `${title} - 35PHOTO`,
|
|
38
53
|
link: currentUrl,
|
|
39
54
|
item: items,
|
|
40
55
|
};
|