rsshub 1.0.0-master.fb2a407 → 1.0.0-master.fc5a2f6
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 +1 -0
- package/lib/config.js +15 -2
- package/lib/middleware/anti-hotlink.js +40 -14
- package/lib/middleware/cache/redis.js +7 -2
- package/lib/middleware/onerror.js +2 -1
- package/lib/middleware/parameter.js +11 -3
- package/lib/radar-rules.js +0 -382
- package/lib/router.js +193 -227
- package/lib/routes/index.js +1 -1
- package/lib/routes/mastodon/utils.js +14 -14
- package/lib/routes/tencent/wechat/miniprogram/framework.js +4 -2
- package/lib/routes/twitter/api_fallback_common.js +17 -0
- package/lib/routes/twitter/developer-api/search.js +3 -3
- package/lib/routes/twitter/developer-api/user.js +2 -2
- package/lib/routes/twitter/followings.js +11 -13
- package/lib/routes/twitter/keyword.js +3 -14
- package/lib/routes/twitter/likes.js +2 -2
- package/lib/routes/twitter/list.js +4 -4
- package/lib/routes/twitter/trends.js +5 -4
- package/lib/routes/twitter/user.js +2 -13
- package/lib/routes/twitter/utils.js +77 -74
- package/lib/routes/weibo/user.js +28 -27
- package/lib/utils/cf-email.js +36 -0
- package/lib/utils/parse-date.js +4 -2
- package/lib/utils/puppeteer.js +42 -3
- package/lib/utils/rand-user-agent.js +29 -0
- package/lib/utils/request-wrapper.js +5 -6
- package/lib/utils/wechat-mp.js +55 -3
- package/lib/v2/7mmtv/index.js +86 -0
- package/lib/v2/7mmtv/maintainer.js +4 -0
- package/lib/v2/7mmtv/radar.js +19 -0
- package/lib/v2/7mmtv/router.js +3 -0
- package/lib/v2/7mmtv/templates/description.art +11 -0
- package/lib/v2/91porn/index.js +58 -0
- package/lib/v2/91porn/maintainer.js +3 -0
- package/lib/v2/91porn/radar.js +13 -0
- package/lib/v2/91porn/router.js +3 -0
- package/lib/v2/91porn/templates/index.art +1 -0
- package/lib/v2/9to5/maintainer.js +3 -0
- package/lib/v2/9to5/radar.js +35 -0
- package/lib/v2/9to5/router.js +3 -0
- package/lib/{routes → v2}/9to5/subsite.js +20 -17
- package/lib/{routes → v2}/9to5/utils.js +4 -1
- package/lib/v2/abskoop/index.js +15 -10
- package/lib/v2/abskoop/nsfw.js +52 -0
- package/lib/v2/abskoop/router.js +1 -0
- package/lib/v2/agirls/index.js +6 -0
- package/lib/{routes → v2}/aliyun/database_month.js +8 -13
- package/lib/{routes → v2}/aliyun/developer/group.js +6 -1
- package/lib/v2/aliyun/maintainer.js +5 -0
- package/lib/{routes → v2}/aliyun/notice.js +13 -21
- package/lib/v2/aliyun/radar.js +32 -0
- package/lib/v2/aliyun/router.js +5 -0
- package/lib/v2/ally/maintainer.js +3 -0
- package/lib/v2/ally/radar.js +13 -0
- package/lib/v2/ally/rail.js +109 -0
- package/lib/v2/ally/router.js +3 -0
- package/lib/v2/apple/exchange_repair.js +1 -1
- package/lib/v2/arknights/announce.js +55 -0
- package/lib/{routes → v2}/arknights/japan.js +2 -1
- package/lib/v2/arknights/maintainer.js +5 -0
- package/lib/{routes → v2}/arknights/news.js +6 -5
- package/lib/v2/arknights/radar.js +40 -0
- package/lib/v2/arknights/router.js +8 -0
- package/lib/{routes → v2}/asiantolick/index.js +20 -17
- package/lib/v2/asiantolick/maintainer.js +6 -0
- package/lib/v2/asiantolick/radar.js +31 -0
- package/lib/v2/asiantolick/router.js +3 -0
- package/lib/v2/asiantolick/templates/description.art +3 -0
- package/lib/v2/behance/maintainer.js +3 -0
- package/lib/v2/behance/radar.js +26 -0
- package/lib/v2/behance/router.js +3 -0
- package/lib/v2/behance/user.js +67 -0
- package/lib/v2/bilibili/article.js +37 -15
- package/lib/v2/bilibili/page.js +2 -3
- package/lib/v2/bilibili/video.js +1 -0
- package/lib/v2/bjx/huanbao.js +78 -0
- package/lib/v2/bjx/maintainer.js +4 -0
- package/lib/v2/bjx/radar.js +21 -0
- package/lib/v2/bjx/router.js +4 -0
- package/lib/v2/bjx/types.js +33 -0
- package/lib/v2/c114/maintainer.js +3 -0
- package/lib/v2/c114/radar.js +13 -0
- package/lib/v2/c114/roll.js +57 -0
- package/lib/v2/c114/router.js +3 -0
- package/lib/v2/caareviews/book.js +14 -0
- package/lib/v2/caareviews/essay.js +14 -0
- package/lib/v2/caareviews/exhibition.js +14 -0
- package/lib/v2/caareviews/maintainer.js +5 -0
- package/lib/v2/caareviews/radar.js +25 -0
- package/lib/v2/caareviews/router.js +5 -0
- package/lib/v2/caareviews/templates/utils.art +2 -0
- package/lib/v2/caareviews/utils.js +49 -0
- package/lib/v2/cankaoxiaoxi/index.js +81 -0
- package/lib/v2/cankaoxiaoxi/maintainer.js +3 -0
- package/lib/v2/cankaoxiaoxi/radar.js +61 -0
- package/lib/v2/cankaoxiaoxi/router.js +3 -0
- package/lib/{routes → v2}/cctv/category.js +1 -1
- package/lib/{routes → v2}/cctv/jx.js +6 -1
- package/lib/{routes → v2}/cctv/lm.js +1 -1
- package/lib/v2/cctv/maintainer.js +7 -0
- package/lib/v2/cctv/radar.js +41 -0
- package/lib/v2/cctv/router.js +7 -0
- package/lib/{routes → v2}/cctv/special.js +6 -4
- package/lib/{routes → v2}/cctv/utils/mzzlbg.js +8 -6
- package/lib/{routes → v2}/cctv/utils/news.js +25 -22
- package/lib/{routes → v2}/cctv/utils/xinwen1j1.js +20 -17
- package/lib/v2/cctv/xwlb.js +50 -0
- package/lib/v2/chinacef/experts.js +38 -0
- package/lib/v2/chinacef/hot.js +38 -0
- package/lib/v2/chinacef/index.js +39 -0
- package/lib/v2/chinacef/maintainer.js +5 -0
- package/lib/v2/chinacef/radar.js +25 -0
- package/lib/v2/chinacef/router.js +5 -0
- package/lib/v2/{wechat → chinacef}/templates/description.art +0 -0
- package/lib/v2/chinacef/utils.js +55 -0
- package/lib/v2/chinafactcheck/index.js +38 -0
- package/lib/v2/chinafactcheck/maintainer.js +3 -0
- package/lib/v2/chinafactcheck/radar.js +13 -0
- package/lib/v2/chinafactcheck/router.js +3 -0
- package/lib/v2/chinafactcheck/templates/description.art +1 -0
- package/lib/v2/chinafactcheck/utils.js +60 -0
- package/lib/v2/chinanews/index.js +66 -0
- package/lib/v2/chinanews/maintainer.js +3 -0
- package/lib/v2/chinanews/radar.js +13 -0
- package/lib/v2/chinanews/router.js +3 -0
- package/lib/v2/chinathinktanks/maintainer.js +3 -0
- package/lib/v2/chinathinktanks/radar.js +13 -0
- package/lib/v2/chinathinktanks/router.js +3 -0
- package/lib/v2/chinathinktanks/viewpoint.js +53 -0
- package/lib/v2/chinaventure/index.js +63 -0
- package/lib/v2/chinaventure/maintainer.js +3 -0
- package/lib/v2/chinaventure/radar.js +13 -0
- package/lib/v2/chinaventure/router.js +3 -0
- package/lib/v2/cn-healthcare/index.js +31 -0
- package/lib/v2/cn-healthcare/maintainer.js +3 -0
- package/lib/v2/cn-healthcare/radar.js +13 -0
- package/lib/v2/cn-healthcare/router.js +3 -0
- package/lib/v2/cnbeta/index.js +2 -1
- package/lib/v2/cnbeta/utils.js +1 -0
- package/lib/v2/cncf/index.js +43 -0
- package/lib/v2/cncf/maintainer.js +3 -0
- package/lib/v2/cncf/radar.js +31 -0
- package/lib/v2/cncf/reports.js +38 -0
- package/lib/v2/cncf/router.js +4 -0
- package/lib/v2/cntheory/maintainer.js +3 -0
- package/lib/v2/cntheory/paper.js +93 -0
- package/lib/v2/cntheory/radar.js +13 -0
- package/lib/v2/cntheory/router.js +3 -0
- package/lib/v2/cntheory/templates/description.art +2 -0
- package/lib/v2/coomer/artist.js +9 -0
- package/lib/v2/coomer/maintainer.js +4 -0
- package/lib/v2/coomer/posts.js +7 -0
- package/lib/v2/coomer/radar.js +19 -0
- package/lib/v2/coomer/router.js +4 -0
- package/lib/v2/coomer/utils.js +53 -0
- package/lib/v2/csu/cse.js +33 -0
- package/lib/v2/csu/fetch_article.js +12 -0
- package/lib/{routes/universities → v2}/csu/job.js +0 -0
- package/lib/v2/csu/maintainer.js +3 -0
- package/lib/v2/csu/radar.js +13 -0
- package/lib/v2/csu/router.js +4 -0
- package/lib/v2/dapenti/maintainer.js +4 -0
- package/lib/v2/dapenti/radar.js +27 -0
- package/lib/v2/dapenti/router.js +4 -0
- package/lib/{routes → v2}/dapenti/subject.js +1 -1
- package/lib/{routes → v2}/dapenti/tugua.js +1 -1
- package/lib/v2/dapenti/utils.js +75 -0
- package/lib/v2/diandong/ddh.js +51 -0
- package/lib/v2/diandong/maintainer.js +4 -0
- package/lib/v2/diandong/news.js +50 -0
- package/lib/v2/diandong/radar.js +19 -0
- package/lib/v2/diandong/router.js +4 -0
- package/lib/{routes → v2}/dongqiudi/daily.js +10 -13
- package/lib/v2/dongqiudi/maintainer.js +8 -0
- package/lib/{routes → v2}/dongqiudi/player_news.js +0 -0
- package/lib/v2/dongqiudi/radar.js +45 -0
- package/lib/{routes → v2}/dongqiudi/result.js +2 -1
- package/lib/v2/dongqiudi/router.js +8 -0
- package/lib/{routes → v2}/dongqiudi/special.js +0 -0
- package/lib/{routes → v2}/dongqiudi/team_news.js +0 -0
- package/lib/{routes → v2}/dongqiudi/top_news.js +12 -15
- package/lib/{routes → v2}/dongqiudi/utils.js +44 -33
- package/lib/v2/douyin/hashtag.js +129 -0
- package/lib/v2/douyin/maintainer.js +3 -0
- package/lib/v2/douyin/radar.js +19 -0
- package/lib/v2/douyin/router.js +4 -0
- package/lib/v2/douyin/templates/cover.art +15 -0
- package/lib/v2/douyin/templates/desc.art +3 -0
- package/lib/v2/douyin/templates/embed.art +13 -0
- package/lib/v2/douyin/templates/iframe.art +14 -0
- package/lib/v2/douyin/user.js +130 -0
- package/lib/{routes → v2}/dx2025/index.js +0 -0
- package/lib/v2/dx2025/maintainer.js +3 -0
- package/lib/v2/dx2025/radar.js +19 -0
- package/lib/v2/dx2025/router.js +3 -0
- package/lib/v2/e-hentai/radar.js +21 -3
- package/lib/v2/eagle/blog.js +47 -0
- package/lib/{routes → v2}/eagle/changelog.js +3 -1
- package/lib/v2/eagle/maintainer.js +4 -0
- package/lib/v2/eagle/radar.js +101 -0
- package/lib/v2/eagle/router.js +4 -0
- package/lib/{routes → v2}/earthquake/ceic.js +3 -1
- package/lib/{routes → v2}/earthquake/index.js +5 -3
- package/lib/v2/earthquake/maintainer.js +4 -0
- package/lib/v2/earthquake/radar.js +24 -0
- package/lib/v2/earthquake/router.js +4 -0
- package/lib/{routes/the-economist → v2/economist}/download.js +0 -0
- package/lib/v2/economist/espresso.js +50 -0
- package/lib/v2/economist/full.js +42 -0
- package/lib/v2/economist/gre-vocabulary.js +19 -0
- package/lib/v2/economist/maintainer.js +6 -0
- package/lib/v2/economist/radar.js +27 -0
- package/lib/v2/economist/router.js +6 -0
- package/lib/{routes → v2}/ehentai/ehapi.js +50 -21
- package/lib/{routes → v2}/ehentai/favorites.js +4 -2
- package/lib/v2/ehentai/maintainer.js +5 -0
- package/lib/v2/ehentai/router.js +5 -0
- package/lib/{routes → v2}/ehentai/search.js +5 -3
- package/lib/{routes → v2}/ehentai/tag.js +4 -2
- package/lib/v2/elasticsearch-cn/index.js +57 -0
- package/lib/v2/elasticsearch-cn/maintainer.js +3 -0
- package/lib/v2/elasticsearch-cn/radar.js +13 -0
- package/lib/v2/elasticsearch-cn/router.js +3 -0
- package/lib/v2/elsevier/templates/description.art +2 -0
- package/lib/v2/embassy/index.js +60 -0
- package/lib/v2/embassy/maintainer.js +3 -0
- package/lib/v2/embassy/radar.js +258 -0
- package/lib/v2/embassy/router.js +3 -0
- package/lib/{routes → v2}/embassy/supportedList.js +5 -5
- package/lib/v2/epicgames/index.js +66 -68
- package/lib/v2/epicgames/maintainer.js +1 -1
- package/lib/v2/epicgames/router.js +1 -1
- package/lib/v2/epicgames/templates/description.art +2 -0
- package/lib/v2/feng/forum.js +42 -0
- package/lib/v2/feng/radar.js +13 -0
- package/lib/v2/feng/router.js +3 -0
- package/lib/v2/feng/templates/deleted.art +2 -0
- package/lib/v2/feng/templates/img.art +6 -0
- package/lib/v2/feng/utils.js +80 -0
- package/lib/v2/firefox/index.js +7 -2
- package/lib/v2/fortunechina/index.js +1 -1
- package/lib/v2/fx-markets/channel.js +56 -0
- package/lib/v2/fx-markets/maintainer.js +3 -0
- package/lib/v2/fx-markets/radar.js +31 -0
- package/lib/v2/fx-markets/router.js +3 -0
- package/lib/v2/gcores/category.js +5 -1
- package/lib/v2/gcores/tag.js +5 -1
- package/lib/v2/getitfree/index.js +54 -0
- package/lib/v2/getitfree/maintainer.js +3 -0
- package/lib/v2/getitfree/radar.js +13 -0
- package/lib/v2/getitfree/router.js +3 -0
- package/lib/v2/gf-cn/news.js +1 -1
- package/lib/v2/gitee/maintainer.js +6 -0
- package/lib/v2/gitee/radar.js +31 -0
- package/lib/v2/gitee/repos/commits.js +40 -0
- package/lib/v2/gitee/repos/events.js +66 -0
- package/lib/v2/gitee/repos/releases.js +33 -0
- package/lib/v2/gitee/router.js +6 -0
- package/lib/v2/gitee/users/events.js +84 -0
- package/lib/v2/github/comments.js +7 -0
- package/lib/v2/gitpod/blog.js +8 -0
- package/lib/v2/gov/customs/list.js +76 -0
- package/lib/v2/gov/customs/utils.js +17 -0
- package/lib/v2/gov/hebei/czt.js +53 -0
- package/lib/v2/gov/immiau/news.js +43 -0
- package/lib/v2/gov/maintainer.js +19 -11
- package/lib/v2/gov/miit/wjgs.js +50 -41
- package/lib/v2/gov/miit/zcjd.js +50 -41
- package/lib/v2/gov/moe/moe.js +89 -0
- package/lib/v2/gov/nrta/news.js +63 -0
- package/lib/v2/gov/radar.js +79 -0
- package/lib/v2/gov/router.js +19 -12
- package/lib/v2/gov/sichuan/deyang/govpulicinfo.js +1 -1
- package/lib/v2/guancha/index.js +1 -1
- package/lib/v2/gumroad/index.js +35 -0
- package/lib/v2/gumroad/maintainer.js +3 -0
- package/lib/v2/gumroad/radar.js +17 -0
- package/lib/v2/gumroad/router.js +3 -0
- package/lib/v2/gumroad/templates/products.art +7 -0
- package/lib/{routes/guokr/calendar.js → v2/guokr/channel.js} +2 -2
- package/lib/v2/guokr/maintainer.js +4 -0
- package/lib/v2/guokr/radar.js +19 -0
- package/lib/v2/guokr/router.js +4 -0
- package/lib/{routes → v2}/guokr/scientific.js +3 -3
- package/lib/v2/hkej/index.js +9 -15
- package/lib/v2/hkepc/index.js +8 -0
- package/lib/v2/hket/index.js +10 -2
- package/lib/v2/huangz/index.js +29 -0
- package/lib/v2/huangz/maintainer.js +3 -0
- package/lib/v2/huangz/radar.js +13 -0
- package/lib/v2/huangz/router.js +3 -0
- package/lib/v2/huanqiu/index.js +65 -0
- package/lib/v2/huanqiu/maintainer.js +3 -0
- package/lib/v2/huanqiu/radar.js +13 -0
- package/lib/v2/huanqiu/router.js +3 -0
- package/lib/{routes → v2}/huxiu/article.js +1 -1
- package/lib/{routes → v2}/huxiu/author.js +18 -6
- package/lib/{routes → v2}/huxiu/collection.js +1 -2
- package/lib/v2/huxiu/maintainer.js +7 -0
- package/lib/v2/huxiu/radar.js +35 -0
- package/lib/v2/huxiu/router.js +7 -0
- package/lib/{routes → v2}/huxiu/search.js +0 -0
- package/lib/{routes → v2}/huxiu/tag.js +0 -0
- package/lib/{routes → v2}/huxiu/utils.js +3 -4
- package/lib/v2/ieee/templates/description.art +2 -0
- package/lib/v2/ielts/index.js +28 -27
- package/lib/v2/iguoguo/index.js +75 -0
- package/lib/v2/iguoguo/maintainer.js +3 -0
- package/lib/v2/iguoguo/radar.js +11 -0
- package/lib/v2/iguoguo/router.js +3 -0
- package/lib/v2/itch/devlog.js +62 -0
- package/lib/v2/itch/index.js +56 -0
- package/lib/v2/itch/maintainer.js +5 -0
- package/lib/v2/itch/posts.js +41 -0
- package/lib/v2/itch/radar.js +28 -0
- package/lib/v2/itch/router.js +5 -0
- package/lib/v2/itch/templates/description.art +4 -0
- package/lib/v2/jasa/templates/description.art +2 -0
- package/lib/v2/javdb/utils.js +4 -4
- package/lib/v2/jd/maintainer.js +3 -0
- package/lib/v2/jd/price.js +42 -0
- package/lib/v2/jd/radar.js +13 -0
- package/lib/v2/jd/router.js +3 -0
- package/lib/v2/jd/templates/description.art +3 -0
- package/lib/v2/jike/maintainer.js +5 -0
- package/lib/v2/jike/radar.js +34 -0
- package/lib/v2/jike/router.js +5 -0
- package/lib/v2/jike/topic.js +42 -0
- package/lib/v2/jike/topicText.js +21 -0
- package/lib/{routes → v2}/jike/user.js +9 -9
- package/lib/{routes/jike/common.js → v2/jike/utils.js} +91 -31
- package/lib/{routes → v2}/juejin/books.js +2 -1
- package/lib/{routes → v2}/juejin/category.js +1 -1
- package/lib/{routes → v2}/juejin/collection.js +0 -0
- package/lib/{routes → v2}/juejin/column.js +0 -0
- package/lib/{routes → v2}/juejin/favorites.js +0 -0
- package/lib/v2/juejin/maintainer.js +13 -0
- package/lib/v2/juejin/news.js +25 -0
- package/lib/{routes → v2}/juejin/pins.js +3 -2
- package/lib/{routes → v2}/juejin/posts.js +0 -0
- package/lib/v2/juejin/radar.js +61 -0
- package/lib/v2/juejin/router.js +13 -0
- package/lib/{routes → v2}/juejin/shares.js +0 -0
- package/lib/{routes → v2}/juejin/tag.js +0 -0
- package/lib/{routes → v2}/juejin/trending.js +0 -0
- package/lib/{routes → v2}/juejin/utils.js +15 -7
- package/lib/v2/kcna/maintainer.js +3 -0
- package/lib/v2/kcna/news.js +81 -0
- package/lib/v2/kcna/radar.js +61 -0
- package/lib/v2/kcna/router.js +3 -0
- package/lib/v2/kcna/templates/news.art +9 -0
- package/lib/v2/kcna/utils.js +64 -0
- package/lib/v2/laohu8/maintainer.js +3 -0
- package/lib/v2/laohu8/personal.js +32 -0
- package/lib/v2/laohu8/radar.js +13 -0
- package/lib/v2/laohu8/router.js +3 -0
- package/lib/v2/lever/index.js +28 -0
- package/lib/v2/lever/maintainer.js +3 -0
- package/lib/v2/lever/radar.js +13 -0
- package/lib/v2/lever/router.js +3 -0
- package/lib/v2/lfsyd/templates/video.art +1 -0
- package/lib/v2/lfsyd/utils.js +10 -0
- package/lib/v2/mihoyo/bbs.js +1 -0
- package/lib/v2/mihoyo/radar.js +2 -2
- package/lib/v2/mobilism/forums.js +75 -0
- package/lib/v2/mobilism/maintainer.js +4 -0
- package/lib/v2/mobilism/portal.js +54 -0
- package/lib/v2/mobilism/radar.js +23 -0
- package/lib/v2/mobilism/router.js +4 -0
- package/lib/{routes → v2}/mp4er/index.js +1 -1
- package/lib/v2/mp4er/maintainer.js +3 -0
- package/lib/v2/mp4er/radar.js +13 -0
- package/lib/v2/mp4er/router.js +3 -0
- package/lib/v2/mysql/maintainer.js +3 -0
- package/lib/v2/mysql/radar.js +13 -0
- package/lib/v2/mysql/release.js +55 -0
- package/lib/v2/mysql/router.js +3 -0
- package/lib/v2/nature/cover.js +77 -0
- package/lib/v2/nature/highlight.js +22 -0
- package/lib/v2/nature/maintainer.js +8 -0
- package/lib/v2/nature/news-and-comment.js +37 -0
- package/lib/v2/nature/news.js +30 -0
- package/lib/v2/nature/radar.js +37 -0
- package/lib/v2/nature/research.js +39 -0
- package/lib/v2/nature/router.js +8 -0
- package/lib/v2/nature/siteindex.js +48 -0
- package/lib/v2/nature/utils.js +980 -0
- package/lib/v2/news/whxw.js +2 -2
- package/lib/v2/nhk/news.js +41 -0
- package/lib/{routes → v2}/nhk/news_web_easy.js +20 -20
- package/lib/v2/nhk/radar.js +19 -0
- package/lib/v2/nhk/router.js +4 -0
- package/lib/v2/nhk/templates/news.art +5 -0
- package/lib/v2/njit/jwc.js +92 -0
- package/lib/v2/njit/maintainer.js +4 -0
- package/lib/v2/njit/radar.js +21 -0
- package/lib/v2/njit/router.js +4 -0
- package/lib/v2/njit/tzgg.js +74 -0
- package/lib/v2/njust/cwc.js +39 -0
- package/lib/v2/njust/dgxg.js +40 -0
- package/lib/v2/njust/eo.js +50 -0
- package/lib/v2/njust/eoe.js +39 -0
- package/lib/v2/njust/gs.js +41 -0
- package/lib/v2/njust/jwc.js +41 -0
- package/lib/v2/njust/maintainer.js +8 -0
- package/lib/v2/njust/radar.js +110 -0
- package/lib/v2/njust/router.js +8 -0
- package/lib/v2/njust/utils.js +31 -0
- package/lib/v2/npm/package.js +1 -1
- package/lib/v2/npm/router.js +1 -1
- package/lib/v2/orcid/index.js +1 -1
- package/lib/v2/orcid/templates/description.art +2 -2
- package/lib/v2/panewslab/{column.js → author.js} +11 -23
- package/lib/v2/panewslab/index.js +24 -17
- package/lib/v2/panewslab/maintainer.js +3 -1
- package/lib/v2/panewslab/news.js +28 -0
- package/lib/v2/panewslab/radar.js +2 -2
- package/lib/v2/panewslab/router.js +4 -2
- package/lib/v2/panewslab/topic.js +7 -14
- package/lib/v2/people/index.js +1 -1
- package/lib/v2/pianyuan/app.js +34 -0
- package/lib/v2/pianyuan/maintainer.js +4 -0
- package/lib/v2/pianyuan/radar.js +13 -0
- package/lib/v2/pianyuan/router.js +4 -0
- package/lib/v2/pianyuan/search.js +45 -0
- package/lib/v2/pianyuan/utils.js +88 -0
- package/lib/v2/pincong/hot.js +28 -0
- package/lib/{routes → v2}/pincong/index.js +6 -12
- package/lib/v2/pincong/maintainer.js +5 -0
- package/lib/v2/pincong/radar.js +35 -0
- package/lib/v2/pincong/router.js +5 -0
- package/lib/v2/pincong/topic.js +25 -0
- package/lib/v2/pincong/utils.js +16 -0
- package/lib/{routes/universities → v2}/pku/bbs/hot.js +5 -10
- package/lib/{routes/universities → v2}/pku/cls/lecture.js +5 -7
- package/lib/v2/pku/eecs.js +64 -0
- package/lib/v2/pku/maintainer.js +7 -0
- package/lib/v2/pku/nsd.js +69 -0
- package/lib/v2/pku/pkuyjs.js +29 -0
- package/lib/v2/pku/radar.js +117 -0
- package/lib/v2/pku/rccp/mzyt.js +23 -0
- package/lib/v2/pku/router.js +7 -0
- package/lib/v2/pku/scc/recruit.js +58 -0
- package/lib/v2/pku/utils.js +15 -0
- package/lib/v2/playno1/av.js +41 -0
- package/lib/v2/playno1/maintainer.js +4 -0
- package/lib/v2/playno1/radar.js +21 -0
- package/lib/v2/playno1/router.js +4 -0
- package/lib/v2/playno1/st.js +36 -0
- package/lib/v2/playno1/utils.js +32 -0
- package/lib/v2/pmthinking/index.js +61 -0
- package/lib/v2/pmthinking/maintainer.js +3 -0
- package/lib/v2/pmthinking/radar.js +13 -0
- package/lib/v2/pmthinking/router.js +3 -0
- package/lib/v2/pmthinking/templates/description.art +4 -0
- package/lib/v2/qbittorrent/news.js +6 -0
- package/lib/v2/qipamaijia/index.js +26 -0
- package/lib/v2/qipamaijia/maintainer.js +3 -0
- package/lib/v2/qipamaijia/radar.js +13 -0
- package/lib/v2/qipamaijia/router.js +3 -0
- package/lib/v2/radio/index.js +48 -0
- package/lib/v2/radio/maintainer.js +3 -0
- package/lib/v2/radio/radar.js +13 -0
- package/lib/{routes → v2}/radio/radio.js +0 -0
- package/lib/v2/radio/router.js +3 -0
- package/lib/v2/radio/templates/description.art +5 -0
- package/lib/v2/reuters/common.js +54 -0
- package/lib/v2/reuters/investigates.js +39 -0
- package/lib/v2/reuters/maintainer.js +6 -0
- package/lib/v2/reuters/migration_prompt.js +3 -0
- package/lib/v2/reuters/radar.js +19 -0
- package/lib/v2/reuters/router.js +6 -0
- package/lib/v2/sciencedirect/journal.js +8 -1
- package/lib/{routes → v2}/sciencenet/blog.js +17 -12
- package/lib/v2/sciencenet/maintainer.js +4 -0
- package/lib/v2/sciencenet/radar.js +19 -0
- package/lib/v2/sciencenet/router.js +4 -0
- package/lib/v2/sciencenet/user.js +65 -0
- package/lib/v2/sdu/cmse.js +59 -0
- package/lib/v2/sdu/cs.js +57 -0
- package/lib/v2/sdu/data.js +110 -0
- package/lib/v2/sdu/epe.js +55 -0
- package/lib/v2/sdu/extractor/index.js +15 -0
- package/lib/v2/sdu/extractor/sdrj.js +21 -0
- package/lib/v2/sdu/extractor/view.js +21 -0
- package/lib/v2/sdu/extractor/wh/jwc.js +24 -0
- package/lib/v2/sdu/extractor/wh/news.js +21 -0
- package/lib/v2/sdu/maintainer.js +9 -0
- package/lib/v2/sdu/mech.js +60 -0
- package/lib/v2/sdu/radar.js +159 -0
- package/lib/v2/sdu/router.js +9 -0
- package/lib/v2/sdu/sc.js +61 -0
- package/lib/v2/sdu/wh/jwc.js +42 -0
- package/lib/v2/sdu/wh/news.js +38 -0
- package/lib/v2/sis001/forum.js +62 -0
- package/lib/v2/sis001/maintainer.js +3 -0
- package/lib/v2/sis001/radar.js +13 -0
- package/lib/v2/sis001/router.js +3 -0
- package/lib/{routes → v2}/sobooks/date.js +1 -1
- package/lib/{routes → v2}/sobooks/index.js +1 -1
- package/lib/v2/sobooks/maintainer.js +5 -0
- package/lib/v2/sobooks/radar.js +25 -0
- package/lib/v2/sobooks/router.js +5 -0
- package/lib/{routes → v2}/sobooks/tag.js +1 -1
- package/lib/{routes → v2}/sobooks/utils.js +3 -2
- package/lib/{routes → v2}/sspai/activity.js +2 -1
- package/lib/{routes → v2}/sspai/author.js +15 -21
- package/lib/{routes → v2}/sspai/column.js +16 -20
- package/lib/v2/sspai/index.js +37 -0
- package/lib/v2/sspai/maintainer.js +13 -0
- package/lib/v2/sspai/matrix.js +38 -0
- package/lib/v2/sspai/radar.js +75 -0
- package/lib/v2/sspai/router.js +13 -0
- package/lib/{routes → v2}/sspai/series.js +2 -2
- package/lib/v2/sspai/seriesUpdate.js +36 -0
- package/lib/{routes → v2}/sspai/shortcutsGallery.js +3 -2
- package/lib/{routes → v2}/sspai/tag.js +15 -19
- package/lib/{routes → v2}/sspai/topic.js +15 -18
- package/lib/{routes → v2}/sspai/topics.js +12 -16
- package/lib/v2/syosetu/chapter.js +61 -0
- package/lib/v2/syosetu/maintainer.js +3 -0
- package/lib/v2/syosetu/radar.js +21 -0
- package/lib/v2/syosetu/router.js +1 -0
- package/lib/v2/szse/inquire.js +41 -0
- package/lib/v2/szse/maintainer.js +3 -0
- package/lib/{routes → v2}/szse/notice.js +0 -0
- package/lib/v2/szse/projectdynamic.js +90 -0
- package/lib/v2/szse/radar.js +21 -1
- package/lib/v2/szse/router.js +3 -0
- package/lib/v2/szse/rule.js +3 -3
- package/lib/v2/szse/templates/description.art +19 -0
- package/lib/v2/szse/templates/inquire.art +6 -0
- package/lib/{routes → v2}/taptap/changelog.js +2 -1
- package/lib/v2/taptap/maintainer.js +5 -0
- package/lib/v2/taptap/radar.js +25 -0
- package/lib/v2/taptap/review.js +69 -0
- package/lib/v2/taptap/router.js +5 -0
- package/lib/v2/taptap/templates/videoPost.art +2 -0
- package/lib/v2/taptap/topic.js +79 -0
- package/lib/v2/taptap/utils.js +48 -0
- package/lib/v2/test/index.js +8 -1
- package/lib/v2/thecover/channel.js +66 -0
- package/lib/v2/thecover/maintainer.js +3 -0
- package/lib/v2/thecover/radar.js +13 -0
- package/lib/v2/thecover/router.js +3 -0
- package/lib/v2/tiktok/maintainer.js +3 -0
- package/lib/v2/tiktok/radar.js +13 -0
- package/lib/v2/tiktok/router.js +3 -0
- package/lib/v2/tiktok/templates/user.art +3 -0
- package/lib/v2/tiktok/user.js +66 -0
- package/lib/v2/tingshuitz/dalian.js +29 -0
- package/lib/{routes → v2}/tingshuitz/dongguan.js +2 -1
- package/lib/{routes → v2}/tingshuitz/guangzhou.js +0 -0
- package/lib/{routes → v2}/tingshuitz/hangzhou.js +0 -0
- package/lib/v2/tingshuitz/maintainer.js +11 -0
- package/lib/{routes → v2}/tingshuitz/nanjing.js +9 -11
- package/lib/v2/tingshuitz/radar.js +68 -0
- package/lib/v2/tingshuitz/router.js +11 -0
- package/lib/v2/tingshuitz/wuhan.js +32 -0
- package/lib/{routes → v2}/tingshuitz/xian.js +1 -1
- package/lib/{routes → v2}/tingshuitz/xiaoshan.js +0 -0
- package/lib/{routes → v2}/tingshuitz/yangjiang.js +6 -8
- package/lib/v2/uraaka-joshi/maintainer.js +4 -0
- package/lib/v2/uraaka-joshi/radar.js +19 -0
- package/lib/v2/uraaka-joshi/router.js +4 -0
- package/lib/v2/uraaka-joshi/uraaka-joshi-user.js +89 -0
- package/lib/v2/uraaka-joshi/uraaka-joshi.js +71 -0
- package/lib/v2/ustc/eeis.js +59 -0
- package/lib/v2/ustc/gs.js +59 -0
- package/lib/v2/ustc/index.js +79 -0
- package/lib/{routes/universities → v2}/ustc/job.js +6 -5
- package/lib/{routes/universities/ustc/jwc/index.js → v2/ustc/jwc.js} +23 -26
- package/lib/v2/ustc/maintainer.js +8 -0
- package/lib/v2/ustc/radar.js +53 -0
- package/lib/v2/ustc/router.js +8 -0
- package/lib/v2/ustc/sist.js +59 -0
- package/lib/v2/usts/jwch.js +56 -0
- package/lib/v2/usts/maintainer.js +3 -0
- package/lib/v2/usts/radar.js +25 -0
- package/lib/v2/usts/router.js +3 -0
- package/lib/v2/vimeo/templates/description.art +4 -4
- package/lib/v2/wallpaperhub/index.js +28 -0
- package/lib/v2/wallpaperhub/maintainer.js +3 -0
- package/lib/v2/wallpaperhub/radar.js +13 -0
- package/lib/v2/wallpaperhub/router.js +3 -0
- package/lib/v2/wallpaperhub/templates/description.art +1 -0
- package/lib/{routes/tencent → v2}/wechat/announce.js +3 -2
- package/lib/{routes/tencent → v2}/wechat/ce.js +0 -0
- package/lib/v2/wechat/data258.js +137 -0
- package/lib/{routes/tencent → v2}/wechat/ershcimi.js +0 -0
- package/lib/{routes/tencent → v2}/wechat/feeds.js +0 -0
- package/lib/v2/wechat/maintainer.js +11 -0
- package/lib/{routes/tencent → v2}/wechat/mp.js +0 -0
- package/lib/{routes/tencent → v2}/wechat/msgalbum.js +0 -0
- package/lib/v2/wechat/radar.js +76 -1
- package/lib/v2/wechat/router.js +11 -0
- package/lib/{routes/tencent → v2}/wechat/tgchannel.js +0 -0
- package/lib/{routes/tencent → v2}/wechat/uread.js +0 -0
- package/lib/{routes/tencent → v2}/wechat/wemp.js +0 -0
- package/lib/{routes/tencent → v2}/wechat/wxnmh.js +0 -0
- package/lib/{routes → v2}/xiaohongshu/board.js +8 -6
- package/lib/v2/xiaohongshu/maintainer.js +4 -0
- package/lib/v2/xiaohongshu/radar.js +25 -0
- package/lib/v2/xiaohongshu/router.js +4 -0
- package/lib/{routes → v2}/xiaohongshu/user.js +9 -11
- package/lib/v2/xiaohongshu/util.js +28 -0
- package/lib/v2/xiaozhuanlan/column.js +52 -0
- package/lib/v2/xiaozhuanlan/maintainer.js +3 -0
- package/lib/v2/xiaozhuanlan/radar.js +13 -0
- package/lib/v2/xiaozhuanlan/router.js +3 -0
- package/lib/v2/xidian/jwc.js +54 -0
- package/lib/v2/xidian/maintainer.js +3 -0
- package/lib/v2/xidian/radar.js +13 -0
- package/lib/v2/xidian/router.js +3 -0
- package/lib/v2/xueqiu/user.js +3 -2
- package/lib/v2/yomiuri/maintainer.js +3 -0
- package/lib/{routes → v2}/yomiuri/news.js +8 -23
- package/lib/v2/yomiuri/radar.js +13 -0
- package/lib/v2/yomiuri/router.js +3 -0
- package/lib/{routes → v2}/youtube/channel.js +9 -5
- package/lib/v2/youtube/maintainer.js +6 -0
- package/lib/{routes → v2}/youtube/playlist.js +6 -10
- package/lib/v2/youtube/radar.js +31 -0
- package/lib/v2/youtube/router.js +6 -0
- package/lib/v2/youtube/subscriptions.js +56 -0
- package/lib/v2/youtube/templates/description.art +7 -0
- package/lib/{routes → v2}/youtube/user.js +4 -5
- package/lib/v2/youtube/utils.js +141 -0
- package/lib/v2/youzhiyouxing/maintainer.js +1 -1
- package/lib/v2/youzhiyouxing/materials.js +32 -22
- package/lib/v2/youzhiyouxing/radar.js +6 -6
- package/lib/v2/youzhiyouxing/router.js +1 -1
- package/lib/v2/yunspe/maintainer.js +3 -0
- package/lib/v2/yunspe/newsflash.js +42 -0
- package/lib/v2/yunspe/radar.js +13 -0
- package/lib/v2/yunspe/router.js +3 -0
- package/lib/v2/yyets/article.js +45 -0
- package/lib/v2/yyets/maintainer.js +4 -0
- package/lib/v2/yyets/radar.js +19 -0
- package/lib/v2/yyets/router.js +4 -0
- package/lib/v2/yyets/today.js +37 -0
- package/lib/{routes → v2}/yystv/category.js +8 -8
- package/lib/{routes → v2}/yystv/docs.js +2 -2
- package/lib/v2/yystv/maintainer.js +4 -0
- package/lib/v2/yystv/radar.js +49 -0
- package/lib/v2/yystv/router.js +4 -0
- package/lib/v2/zaobao/util.js +16 -4
- package/lib/{routes → v2}/zhihu/activities.js +38 -1
- package/lib/{routes → v2}/zhihu/answers.js +2 -1
- package/lib/{routes → v2}/zhihu/bookstore/newest.js +0 -0
- package/lib/{routes → v2}/zhihu/collection.js +2 -1
- package/lib/{routes → v2}/zhihu/daily.js +0 -0
- package/lib/{routes → v2}/zhihu/daily_section.js +5 -11
- package/lib/v2/zhihu/execlib/g_encrypt.js +407 -0
- package/lib/{routes → v2}/zhihu/execlib/jsencrypt.js +0 -1
- package/lib/{routes → v2}/zhihu/hot.js +1 -1
- package/lib/{routes → v2}/zhihu/hotlist.js +3 -3
- package/lib/v2/zhihu/maintainer.js +19 -0
- package/lib/{routes → v2}/zhihu/pin/daily.js +0 -0
- package/lib/{routes → v2}/zhihu/pin/hotlist.js +0 -0
- package/lib/{routes → v2}/zhihu/pin/people.js +0 -0
- package/lib/{routes → v2}/zhihu/pin/utils.js +3 -1
- package/lib/{routes → v2}/zhihu/posts.js +1 -1
- package/lib/v2/zhihu/question.js +78 -0
- package/lib/v2/zhihu/radar.js +107 -0
- package/lib/v2/zhihu/router.js +19 -0
- package/lib/{routes → v2}/zhihu/timeline.js +3 -2
- package/lib/{routes → v2}/zhihu/topic.js +0 -0
- package/lib/{routes → v2}/zhihu/utils.js +0 -0
- package/lib/{routes → v2}/zhihu/weekly.js +2 -3
- package/lib/{routes → v2}/zhihu/zhuanlan.js +6 -5
- package/lib/{routes/universities → v2}/zju/career/index.js +14 -13
- package/lib/{routes/universities → v2}/zju/cst/custom.js +2 -1
- package/lib/{routes/universities → v2}/zju/cst/index.js +20 -24
- package/lib/v2/zju/grs/index.js +43 -0
- package/lib/v2/zju/list.js +66 -0
- package/lib/v2/zju/maintainer.js +8 -0
- package/lib/v2/zju/physics/index.js +52 -0
- package/lib/v2/zju/radar.js +139 -0
- package/lib/v2/zju/router.js +8 -0
- package/lib/v2/zotero/maintainer.js +3 -0
- package/lib/v2/zotero/radar.js +13 -0
- package/lib/v2/zotero/router.js +3 -0
- package/lib/v2/zotero/versions.js +36 -0
- package/lib/v2/zuel/maintainer.js +3 -0
- package/lib/v2/zuel/notice.js +52 -0
- package/lib/v2/zuel/radar.js +13 -0
- package/lib/v2/zuel/router.js +3 -0
- package/lib/v2/zyshow/index.js +46 -0
- package/lib/v2/zyshow/maintainer.js +3 -0
- package/lib/v2/zyshow/radar.js +17 -0
- package/lib/v2/zyshow/router.js +3 -0
- package/lib/v2/zyshow/templates/description.art +16 -0
- package/lib/views/atom.art +13 -1
- package/lib/views/welcome.art +4 -1
- package/package.json +39 -32
- package/lib/routes/behance/index.js +0 -58
- package/lib/routes/bjx/huanbao.js +0 -78
- package/lib/routes/cctv/xwlb.js +0 -48
- package/lib/routes/dapenti/utils.js +0 -73
- package/lib/routes/dwnews/rank.js +0 -42
- package/lib/routes/dwnews/utils.js +0 -65
- package/lib/routes/dwnews/yaowen.js +0 -73
- package/lib/routes/embassy/index.js +0 -64
- package/lib/routes/gov/customs/list.js +0 -77
- package/lib/routes/gov/moe/moe.js +0 -84
- package/lib/routes/jike/topic.js +0 -65
- package/lib/routes/jike/topicText.js +0 -42
- package/lib/routes/mobilism/release.js +0 -42
- package/lib/routes/nature/cover.js +0 -90
- package/lib/routes/nature/highlight.js +0 -57
- package/lib/routes/nature/news-and-comment.js +0 -78
- package/lib/routes/nature/news.js +0 -51
- package/lib/routes/nature/research.js +0 -184
- package/lib/routes/pianyuan/app.js +0 -49
- package/lib/routes/pincong/hot.js +0 -33
- package/lib/routes/pincong/topic.js +0 -32
- package/lib/routes/reuters/channel.js +0 -155
- package/lib/routes/reuters/theWire.js +0 -45
- package/lib/routes/reuters/utils.js +0 -72
- package/lib/routes/rrys/review.js +0 -30
- package/lib/routes/sspai/matrix.js +0 -44
- package/lib/routes/szse/inquire.js +0 -87
- package/lib/routes/szse/projectdynamic.js +0 -103
- package/lib/routes/taptap/review.js +0 -39
- package/lib/routes/taptap/topic.js +0 -85
- package/lib/routes/tencent/wechat/_README +0 -1
- package/lib/routes/the-economist/full.js +0 -48
- package/lib/routes/the-economist/gre-vocabulary.js +0 -27
- package/lib/routes/tingshuitz/dalian.js +0 -34
- package/lib/routes/tingshuitz/wuhan.js +0 -34
- package/lib/routes/universities/njust/cwc/index.js +0 -37
- package/lib/routes/universities/njust/eo/index.js +0 -41
- package/lib/routes/universities/njust/eo/util.js +0 -28
- package/lib/routes/universities/njust/gs/index.js +0 -33
- package/lib/routes/universities/njust/jwc/index.js +0 -39
- package/lib/routes/universities/pku/eecs.js +0 -41
- package/lib/routes/universities/pku/pkuyjs.js +0 -23
- package/lib/routes/universities/pku/rccp/mzyt.js +0 -33
- package/lib/routes/universities/sdu/cmse.js +0 -55
- package/lib/routes/universities/sdu/cs.js +0 -55
- package/lib/routes/universities/sdu/epe.js +0 -54
- package/lib/routes/universities/sdu/mech.js +0 -58
- package/lib/routes/universities/sdu/sc.js +0 -56
- package/lib/routes/universities/ustc/index.js +0 -93
- package/lib/routes/universities/xidian/jwc.js +0 -70
- package/lib/routes/universities/zju/grs/index.js +0 -44
- package/lib/routes/universities/zju/list.js +0 -78
- package/lib/routes/universities/zju/physics/index.js +0 -55
- package/lib/routes/uraaka-joshi/uraaka-joshi-user.js +0 -28
- package/lib/routes/uraaka-joshi/uraaka-joshi.js +0 -30
- package/lib/routes/waijiedanao/article.js +0 -78
- package/lib/routes/wallpaperhub/index.js +0 -22
- package/lib/routes/xiaohongshu/util.js +0 -18
- package/lib/routes/youtube/utils.js +0 -90
- package/lib/routes/yyets/todayfilelist.js +0 -34
- package/lib/routes/zhihu/question.js +0 -38
- package/lib/routes/zyshow/index.js +0 -42
- package/lib/v2/epicgames/supportedList.js +0 -23
- package/lib/v2/panewslab/newsflash.js +0 -35
- package/lib/v2/wechat/templates/image.art +0 -1
package/lib/routes/index.js
CHANGED
|
@@ -7,7 +7,7 @@ let gitHash;
|
|
|
7
7
|
try {
|
|
8
8
|
gitHash = require('git-rev-sync').short();
|
|
9
9
|
} catch (e) {
|
|
10
|
-
gitHash = (process.env.HEROKU_SLUG_COMMIT && process.env.HEROKU_SLUG_COMMIT.slice(0, 7)) || (process.env.
|
|
10
|
+
gitHash = (process.env.HEROKU_SLUG_COMMIT && process.env.HEROKU_SLUG_COMMIT.slice(0, 7)) || (process.env.VERCEL_GIT_COMMIT_SHA && process.env.VERCEL_GIT_COMMIT_SHA.slice(0, 7)) || 'unknown';
|
|
11
11
|
}
|
|
12
12
|
|
|
13
13
|
module.exports = async (ctx) => {
|
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
const got = require('@/utils/got');
|
|
2
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
2
3
|
|
|
3
4
|
const parseStatuses = (data) =>
|
|
4
5
|
data.map((item) => {
|
|
6
|
+
// docs on: https://docs.joinmastodon.org/entities/status/
|
|
7
|
+
|
|
8
|
+
const accountRepostedBy = item.reblog ? item.account : null;
|
|
9
|
+
item = item.reblog ? item.reblog : item;
|
|
10
|
+
|
|
5
11
|
const content = item.content ? item.content.replace(/<span.*?>|<\/span.*?>/gm, '') : '';
|
|
6
12
|
const contentRemovedHtml = content.replace(/<(?:.|\n)*?>/gm, '\n');
|
|
7
13
|
|
|
@@ -26,25 +32,19 @@ const parseStatuses = (data) =>
|
|
|
26
32
|
})
|
|
27
33
|
.join('');
|
|
28
34
|
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
media = mediaParse(item.reblog.media_attachments);
|
|
35
|
-
} else {
|
|
36
|
-
author = `${item.account.display_name} (@${item.account.acct})`;
|
|
37
|
-
link = item.url;
|
|
38
|
-
titleAuthor = `@${item.account.username}`;
|
|
39
|
-
media = mediaParse(item.media_attachments);
|
|
40
|
-
}
|
|
35
|
+
const author = `${item.account.display_name} (@${item.account.acct})`;
|
|
36
|
+
const link = item.url;
|
|
37
|
+
const media = mediaParse(item.media_attachments);
|
|
38
|
+
|
|
39
|
+
const titleAuthor = accountRepostedBy ? `Re @${accountRepostedBy.username}` : `@${item.account.username}`;
|
|
41
40
|
const titleText = item.sensitive === true ? `(CW) ${item.spoiler_text}` : contentRemovedHtml;
|
|
41
|
+
const title = `${titleAuthor}: "${titleText}"`;
|
|
42
42
|
|
|
43
43
|
return {
|
|
44
|
-
title
|
|
44
|
+
title,
|
|
45
45
|
author,
|
|
46
46
|
description: item.spoiler_text + '<hr />' + content + media,
|
|
47
|
-
pubDate:
|
|
47
|
+
pubDate: parseDate(item.created_at),
|
|
48
48
|
link,
|
|
49
49
|
guid: item.uri,
|
|
50
50
|
};
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
const got = require('@/utils/got');
|
|
2
2
|
const cheerio = require('cheerio');
|
|
3
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
4
|
+
const timezone = require('@/utils/timezone');
|
|
3
5
|
|
|
4
6
|
module.exports = async (ctx) => {
|
|
5
7
|
const link = `https://developers.weixin.qq.com/miniprogram/dev/framework/release/`;
|
|
@@ -16,14 +18,14 @@ module.exports = async (ctx) => {
|
|
|
16
18
|
ctx.state.data = {
|
|
17
19
|
title: name,
|
|
18
20
|
link,
|
|
19
|
-
item: $('#docContent .content
|
|
21
|
+
item: $('#docContent .content h2')
|
|
20
22
|
.map((_, item) => {
|
|
21
23
|
item = $(item);
|
|
22
24
|
const title = item.text().replace(/[\s|#]/g, '');
|
|
23
25
|
return {
|
|
24
26
|
title,
|
|
25
27
|
description: item.next().html(),
|
|
26
|
-
pubDate:
|
|
28
|
+
pubDate: timezone(parseDate(new RegExp(/\d{4}-\d{2}-\d{2}/).exec(title)), +8),
|
|
27
29
|
link: link + item.find('a.header-anchor').attr('href'),
|
|
28
30
|
};
|
|
29
31
|
})
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
const config = require('@/config').value;
|
|
2
|
+
const logger = require('@/utils/logger');
|
|
3
|
+
const utils = require('@/routes/twitter/utils');
|
|
4
|
+
|
|
5
|
+
module.exports = async (ctx, devApiImpl, webApiImpl) => {
|
|
6
|
+
const { force_web_api } = utils.parseRouteParams(ctx.params.routeParams);
|
|
7
|
+
|
|
8
|
+
if (!force_web_api && config.twitter && config.twitter.consumer_key && config.twitter.consumer_secret) {
|
|
9
|
+
try {
|
|
10
|
+
await devApiImpl(ctx);
|
|
11
|
+
return;
|
|
12
|
+
} catch (e) {
|
|
13
|
+
logger.error(`Fallback to Twitter web API due to developer API error:\n${e.stack}`);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
await webApiImpl(ctx);
|
|
17
|
+
};
|
|
@@ -2,14 +2,14 @@ const utils = require('../utils');
|
|
|
2
2
|
|
|
3
3
|
module.exports = async (ctx) => {
|
|
4
4
|
const keyword = ctx.params.keyword;
|
|
5
|
-
const limit = ctx.params.limit
|
|
6
|
-
const
|
|
5
|
+
const limit = ctx.params.limit ?? 50;
|
|
6
|
+
const client = await utils.getAppClient();
|
|
7
|
+
const data = await client.v1.get('search/tweets.json', {
|
|
7
8
|
q: keyword,
|
|
8
9
|
count: limit,
|
|
9
10
|
tweet_mode: 'extended',
|
|
10
11
|
result_type: 'recent',
|
|
11
12
|
});
|
|
12
|
-
const data = result.data;
|
|
13
13
|
|
|
14
14
|
ctx.state.data = {
|
|
15
15
|
title: `Twitter Keyword - ${keyword}`,
|
|
@@ -5,14 +5,14 @@ module.exports = async (ctx) => {
|
|
|
5
5
|
|
|
6
6
|
// For compatibility
|
|
7
7
|
const { exclude_replies, include_rts, count } = utils.parseRouteParams(ctx.params.routeParams);
|
|
8
|
-
const
|
|
8
|
+
const client = await utils.getAppClient();
|
|
9
|
+
const data = await client.v1.get('statuses/user_timeline.json', {
|
|
9
10
|
screen_name: id,
|
|
10
11
|
tweet_mode: 'extended',
|
|
11
12
|
exclude_replies,
|
|
12
13
|
include_rts,
|
|
13
14
|
count,
|
|
14
15
|
});
|
|
15
|
-
const data = result.data;
|
|
16
16
|
const userInfo = data[0].user;
|
|
17
17
|
|
|
18
18
|
const profileImageUrl = userInfo.profile_image_url || userInfo.profile_image_url_https;
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
const querystring = require('querystring');
|
|
2
1
|
const utils = require('./utils');
|
|
3
2
|
const config = require('@/config').value;
|
|
4
3
|
const T = {};
|
|
5
|
-
const
|
|
4
|
+
const { TwitterApi } = require('twitter-api-v2');
|
|
6
5
|
const { fallback, queryToBoolean } = require('@/utils/readable-social');
|
|
7
6
|
|
|
8
7
|
module.exports = async (ctx) => {
|
|
@@ -12,22 +11,21 @@ module.exports = async (ctx) => {
|
|
|
12
11
|
throw Error(`lacking twitter token for user ${id}`);
|
|
13
12
|
} else if (!T[id]) {
|
|
14
13
|
const token = cookie.split(',');
|
|
15
|
-
T[id] = new
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
});
|
|
14
|
+
T[id] = new TwitterApi({
|
|
15
|
+
appKey: token[0],
|
|
16
|
+
appSecret: token[1],
|
|
17
|
+
accessToken: token[2],
|
|
18
|
+
accessSecret: token[3],
|
|
19
|
+
}).readOnly;
|
|
21
20
|
}
|
|
22
21
|
|
|
23
|
-
const
|
|
22
|
+
const data = await T[id].v1.get('statuses/home_timeline.json', {
|
|
24
23
|
tweet_mode: 'extended',
|
|
25
24
|
count: 100,
|
|
26
25
|
});
|
|
27
|
-
const data = result.data;
|
|
28
26
|
|
|
29
27
|
// undefined and strings like "exclude_rts_replies" is also safely parsed, so no if branch is needed
|
|
30
|
-
const routeParams =
|
|
28
|
+
const routeParams = new URLSearchParams(ctx.params.routeParams);
|
|
31
29
|
|
|
32
30
|
ctx.state.data = {
|
|
33
31
|
title: `${id} 的 Twitter 关注时间线`,
|
|
@@ -38,8 +36,8 @@ module.exports = async (ctx) => {
|
|
|
38
36
|
data,
|
|
39
37
|
},
|
|
40
38
|
{
|
|
41
|
-
showAuthorInTitle: fallback(undefined, queryToBoolean(routeParams.showAuthorInTitle), true),
|
|
42
|
-
showAuthorInDesc: fallback(undefined, queryToBoolean(routeParams.showAuthorInDesc), true),
|
|
39
|
+
showAuthorInTitle: fallback(undefined, queryToBoolean(routeParams.get('showAuthorInTitle')), true),
|
|
40
|
+
showAuthorInDesc: fallback(undefined, queryToBoolean(routeParams.get('showAuthorInDesc')), true),
|
|
43
41
|
}
|
|
44
42
|
),
|
|
45
43
|
};
|
|
@@ -1,16 +1,5 @@
|
|
|
1
|
-
const config = require('@/config').value;
|
|
2
|
-
const webApiImpl = require('./web-api/search');
|
|
3
1
|
const devApiImpl = require('./developer-api/search');
|
|
4
|
-
const
|
|
2
|
+
const webApiImpl = require('./web-api/search');
|
|
3
|
+
const apiFallback = require('./api_fallback_common');
|
|
5
4
|
|
|
6
|
-
module.exports =
|
|
7
|
-
if (config.twitter && config.twitter.consumer_key && config.twitter.consumer_secret) {
|
|
8
|
-
try {
|
|
9
|
-
await devApiImpl(ctx);
|
|
10
|
-
return;
|
|
11
|
-
} catch (e) {
|
|
12
|
-
logger.error(`Fallback to Twitter web API due to developer API error:\n${e.stack}`);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
await webApiImpl(ctx);
|
|
16
|
-
};
|
|
5
|
+
module.exports = (ctx) => apiFallback(ctx, devApiImpl, webApiImpl);
|
|
@@ -6,11 +6,11 @@ module.exports = async (ctx) => {
|
|
|
6
6
|
throw 'Twitter RSS is disabled due to the lack of <a href="https://docs.rsshub.app/install/#pei-zhi-bu-fen-rss-mo-kuai-pei-zhi">relevant config</a>';
|
|
7
7
|
}
|
|
8
8
|
const id = ctx.params.id;
|
|
9
|
-
const
|
|
9
|
+
const client = await utils.getAppClient();
|
|
10
|
+
const data = await client.v1.get('favorites/list.json', {
|
|
10
11
|
screen_name: id,
|
|
11
12
|
tweet_mode: 'extended',
|
|
12
13
|
});
|
|
13
|
-
const data = result.data;
|
|
14
14
|
|
|
15
15
|
ctx.state.data = {
|
|
16
16
|
title: `Twitter Likes - ${id}`,
|
|
@@ -6,14 +6,15 @@ module.exports = async (ctx) => {
|
|
|
6
6
|
throw 'Twitter RSS is disabled due to the lack of <a href="https://docs.rsshub.app/install/#pei-zhi-bu-fen-rss-mo-kuai-pei-zhi">relevant config</a>';
|
|
7
7
|
}
|
|
8
8
|
const { id, name } = ctx.params;
|
|
9
|
+
const client = await utils.getAppClient();
|
|
9
10
|
|
|
10
11
|
const list_data = await ctx.cache.tryGet(`twitter_lists_list_screen_name:${id}`, async () => {
|
|
11
|
-
const
|
|
12
|
+
const data = await client.v1.get('lists/list.json', {
|
|
12
13
|
screen_name: id,
|
|
13
14
|
});
|
|
14
15
|
|
|
15
16
|
const cached_lists = {};
|
|
16
|
-
|
|
17
|
+
data.forEach((e) => {
|
|
17
18
|
cached_lists[e.name] = { id: e.id_str, slug: e.slug };
|
|
18
19
|
});
|
|
19
20
|
|
|
@@ -21,12 +22,11 @@ module.exports = async (ctx) => {
|
|
|
21
22
|
});
|
|
22
23
|
const cur_list = list_data[name];
|
|
23
24
|
|
|
24
|
-
const
|
|
25
|
+
const data = await client.v1.get('lists/statuses.json', {
|
|
25
26
|
list_id: cur_list.id,
|
|
26
27
|
slug: cur_list.slug,
|
|
27
28
|
tweet_mode: 'extended',
|
|
28
29
|
});
|
|
29
|
-
const data = result.data;
|
|
30
30
|
|
|
31
31
|
ctx.state.data = {
|
|
32
32
|
title: `Twitter List - ${id}/${name}`,
|
|
@@ -5,12 +5,13 @@ module.exports = async (ctx) => {
|
|
|
5
5
|
if (!config.twitter || !config.twitter.consumer_key || !config.twitter.consumer_secret) {
|
|
6
6
|
throw 'Twitter RSS is disabled due to the lack of <a href="https://docs.rsshub.app/install/#pei-zhi-bu-fen-rss-mo-kuai-pei-zhi">relevant config</a>';
|
|
7
7
|
}
|
|
8
|
-
const woeid = ctx.params.woeid
|
|
9
|
-
const
|
|
10
|
-
const
|
|
8
|
+
const woeid = ctx.params.woeid ?? 1; // Global information is available by using 1 as the WOEID
|
|
9
|
+
const client = await utils.getAppClient();
|
|
10
|
+
const data = await client.v1.get('trends/place.json', { id: woeid });
|
|
11
|
+
const [{ trends }] = data;
|
|
11
12
|
|
|
12
13
|
ctx.state.data = {
|
|
13
|
-
title: `Twitter Trends on ${
|
|
14
|
+
title: `Twitter Trends on ${data[0].locations[0].name}`,
|
|
14
15
|
link: `https://twitter.com/i/trends`,
|
|
15
16
|
item: trends
|
|
16
17
|
.filter((t) => !t.promoted_content)
|
|
@@ -1,16 +1,5 @@
|
|
|
1
|
-
const config = require('@/config').value;
|
|
2
1
|
const devApiImpl = require('./developer-api/user');
|
|
3
2
|
const webApiImpl = require('./web-api/user');
|
|
4
|
-
const
|
|
3
|
+
const apiFallback = require('./api_fallback_common');
|
|
5
4
|
|
|
6
|
-
module.exports =
|
|
7
|
-
if (config.twitter && config.twitter.consumer_key && config.twitter.consumer_secret) {
|
|
8
|
-
try {
|
|
9
|
-
await devApiImpl(ctx);
|
|
10
|
-
return;
|
|
11
|
-
} catch (e) {
|
|
12
|
-
logger.error(`Fallback to Twitter web API due to developer API error:\n${e.stack}`);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
await webApiImpl(ctx);
|
|
16
|
-
};
|
|
5
|
+
module.exports = (ctx) => apiFallback(ctx, devApiImpl, webApiImpl);
|
|
@@ -1,30 +1,61 @@
|
|
|
1
|
-
const querystring = require('querystring');
|
|
2
1
|
const URL = require('url');
|
|
3
2
|
const config = require('@/config').value;
|
|
4
|
-
const
|
|
3
|
+
const { TwitterApi } = require('twitter-api-v2');
|
|
5
4
|
const { fallback, queryToBoolean, queryToInteger } = require('@/utils/readable-social');
|
|
5
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
6
|
+
|
|
7
|
+
const getQueryParams = (url) => URL.parse(url, true).query;
|
|
8
|
+
const getOriginalImg = (url) => {
|
|
9
|
+
// https://greasyfork.org/zh-CN/scripts/2312-resize-image-on-open-image-in-new-tab/code#n150
|
|
10
|
+
let m = null;
|
|
11
|
+
if ((m = url.match(/^(https?:\/\/\w+\.twimg\.com\/media\/[^/:]+)\.(jpg|jpeg|gif|png|bmp|webp)(:\w+)?$/i))) {
|
|
12
|
+
let format = m[2];
|
|
13
|
+
if (m[2] === 'jpeg') {
|
|
14
|
+
format = 'jpg';
|
|
15
|
+
}
|
|
16
|
+
return `${m[1]}?format=${format}&name=orig`;
|
|
17
|
+
} else if ((m = url.match(/^(https?:\/\/\w+\.twimg\.com\/.+)(\?.+)$/i))) {
|
|
18
|
+
const pars = getQueryParams(url);
|
|
19
|
+
if (!pars.format || !pars.name) {
|
|
20
|
+
return url;
|
|
21
|
+
}
|
|
22
|
+
if (pars.name === 'orig') {
|
|
23
|
+
return url;
|
|
24
|
+
}
|
|
25
|
+
return m[1] + '?format=' + pars.format + '&name=orig';
|
|
26
|
+
} else {
|
|
27
|
+
return url;
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
const replaceBreak = (text) => text.replace(/<br><br>|<br>/g, ' ');
|
|
31
|
+
const formatText = (text) =>
|
|
32
|
+
text
|
|
33
|
+
.replace(/https:\/\/t\.co(.*)/g, '')
|
|
34
|
+
.trim()
|
|
35
|
+
.replace(/\n/g, '<br>');
|
|
36
|
+
const formatTextToPlain = (text) => text.replace(/https:\/\/t\.co(.*)/g, '').trim();
|
|
6
37
|
|
|
7
38
|
const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
8
39
|
// undefined and strings like "exclude_rts_replies" is also safely parsed, so no if branch is needed
|
|
9
|
-
const routeParams =
|
|
40
|
+
const routeParams = new URLSearchParams(ctx.params.routeParams);
|
|
10
41
|
|
|
11
42
|
const mergedParams = {
|
|
12
|
-
readable: fallback(params.readable, queryToBoolean(routeParams.readable), false),
|
|
13
|
-
authorNameBold: fallback(params.authorNameBold, queryToBoolean(routeParams.authorNameBold), false),
|
|
14
|
-
showAuthorInTitle: fallback(params.showAuthorInTitle, queryToBoolean(routeParams.showAuthorInTitle), false),
|
|
15
|
-
showAuthorInDesc: fallback(params.showAuthorInDesc, queryToBoolean(routeParams.showAuthorInDesc), false),
|
|
16
|
-
showQuotedAuthorAvatarInDesc: fallback(params.showQuotedAuthorAvatarInDesc, queryToBoolean(routeParams.showQuotedAuthorAvatarInDesc), false),
|
|
17
|
-
showAuthorAvatarInDesc: fallback(params.showAuthorAvatarInDesc, queryToBoolean(routeParams.showAuthorAvatarInDesc), false),
|
|
18
|
-
showEmojiForRetweetAndReply: fallback(params.showEmojiForRetweetAndReply, queryToBoolean(routeParams.showEmojiForRetweetAndReply), false),
|
|
19
|
-
showRetweetTextInTitle: fallback(params.showRetweetTextInTitle, queryToBoolean(routeParams.showRetweetTextInTitle), true),
|
|
20
|
-
addLinkForPics: fallback(params.addLinkForPics, queryToBoolean(routeParams.addLinkForPics), false),
|
|
21
|
-
showTimestampInDescription: fallback(params.showTimestampInDescription, queryToBoolean(routeParams.showTimestampInDescription), false),
|
|
22
|
-
showQuotedInTitle: fallback(params.showQuotedInTitle, queryToBoolean(routeParams.showQuotedInTitle), false),
|
|
23
|
-
|
|
24
|
-
widthOfPics: fallback(params.widthOfPics, queryToInteger(routeParams.widthOfPics), -1),
|
|
25
|
-
heightOfPics: fallback(params.heightOfPics, queryToInteger(routeParams.heightOfPics), -1),
|
|
26
|
-
sizeOfAuthorAvatar: fallback(params.sizeOfAuthorAvatar, queryToInteger(routeParams.sizeOfAuthorAvatar), 48),
|
|
27
|
-
sizeOfQuotedAuthorAvatar: fallback(params.sizeOfQuotedAuthorAvatar, queryToInteger(routeParams.sizeOfQuotedAuthorAvatar), 24),
|
|
43
|
+
readable: fallback(params.readable, queryToBoolean(routeParams.get('readable')), false),
|
|
44
|
+
authorNameBold: fallback(params.authorNameBold, queryToBoolean(routeParams.get('authorNameBold')), false),
|
|
45
|
+
showAuthorInTitle: fallback(params.showAuthorInTitle, queryToBoolean(routeParams.get('showAuthorInTitle')), false),
|
|
46
|
+
showAuthorInDesc: fallback(params.showAuthorInDesc, queryToBoolean(routeParams.get('showAuthorInDesc')), false),
|
|
47
|
+
showQuotedAuthorAvatarInDesc: fallback(params.showQuotedAuthorAvatarInDesc, queryToBoolean(routeParams.get('showQuotedAuthorAvatarInDesc')), false),
|
|
48
|
+
showAuthorAvatarInDesc: fallback(params.showAuthorAvatarInDesc, queryToBoolean(routeParams.get('showAuthorAvatarInDesc')), false),
|
|
49
|
+
showEmojiForRetweetAndReply: fallback(params.showEmojiForRetweetAndReply, queryToBoolean(routeParams.get('showEmojiForRetweetAndReply')), false),
|
|
50
|
+
showRetweetTextInTitle: fallback(params.showRetweetTextInTitle, queryToBoolean(routeParams.get('showRetweetTextInTitle')), true),
|
|
51
|
+
addLinkForPics: fallback(params.addLinkForPics, queryToBoolean(routeParams.get('addLinkForPics')), false),
|
|
52
|
+
showTimestampInDescription: fallback(params.showTimestampInDescription, queryToBoolean(routeParams.get('showTimestampInDescription')), false),
|
|
53
|
+
showQuotedInTitle: fallback(params.showQuotedInTitle, queryToBoolean(routeParams.get('showQuotedInTitle')), false),
|
|
54
|
+
|
|
55
|
+
widthOfPics: fallback(params.widthOfPics, queryToInteger(routeParams.get('widthOfPics')), -1),
|
|
56
|
+
heightOfPics: fallback(params.heightOfPics, queryToInteger(routeParams.get('heightOfPics')), -1),
|
|
57
|
+
sizeOfAuthorAvatar: fallback(params.sizeOfAuthorAvatar, queryToInteger(routeParams.get('sizeOfAuthorAvatar')), 48),
|
|
58
|
+
sizeOfQuotedAuthorAvatar: fallback(params.sizeOfQuotedAuthorAvatar, queryToInteger(routeParams.get('sizeOfQuotedAuthorAvatar')), 24),
|
|
28
59
|
};
|
|
29
60
|
|
|
30
61
|
params = mergedParams;
|
|
@@ -48,37 +79,6 @@ const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
|
48
79
|
sizeOfQuotedAuthorAvatar,
|
|
49
80
|
} = params;
|
|
50
81
|
|
|
51
|
-
const getQueryParams = (url) => URL.parse(url, true).query;
|
|
52
|
-
const getOriginalImg = (url) => {
|
|
53
|
-
// https://greasyfork.org/zh-CN/scripts/2312-resize-image-on-open-image-in-new-tab/code#n150
|
|
54
|
-
let m = null;
|
|
55
|
-
if ((m = url.match(/^(https?:\/\/\w+\.twimg\.com\/media\/[^/:]+)\.(jpg|jpeg|gif|png|bmp|webp)(:\w+)?$/i))) {
|
|
56
|
-
let format = m[2];
|
|
57
|
-
if (m[2] === 'jpeg') {
|
|
58
|
-
format = 'jpg';
|
|
59
|
-
}
|
|
60
|
-
return `${m[1]}?format=${format}&name=orig`;
|
|
61
|
-
} else if ((m = url.match(/^(https?:\/\/\w+\.twimg\.com\/.+)(\?.+)$/i))) {
|
|
62
|
-
const pars = getQueryParams(url);
|
|
63
|
-
if (!pars.format || !pars.name) {
|
|
64
|
-
return url;
|
|
65
|
-
}
|
|
66
|
-
if (pars.name === 'orig') {
|
|
67
|
-
return url;
|
|
68
|
-
}
|
|
69
|
-
return m[1] + '?format=' + pars.format + '&name=orig';
|
|
70
|
-
} else {
|
|
71
|
-
return url;
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
|
|
75
|
-
const replaceBreak = (text) => text.replace(/<br><br>|<br>/g, ' ');
|
|
76
|
-
const formatText = (text) =>
|
|
77
|
-
text
|
|
78
|
-
.replace(/https:\/\/t\.co(.*)/g, '')
|
|
79
|
-
.trim()
|
|
80
|
-
.replace(/\n/g, '<br>');
|
|
81
|
-
const formatTextToPlain = (text) => text.replace(/https:\/\/t\.co(.*)/g, '').trim();
|
|
82
82
|
const formatVideo = (media, extraAttrs = '') => {
|
|
83
83
|
let content = '';
|
|
84
84
|
const video = media.video_info.variants.reduce((video, item) => {
|
|
@@ -146,6 +146,7 @@ const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
|
146
146
|
}
|
|
147
147
|
return img;
|
|
148
148
|
};
|
|
149
|
+
|
|
149
150
|
const generatePicsPrefix = (item) => {
|
|
150
151
|
// When author avatar is shown, generate invisible <img> for inner images at the beginning of HTML
|
|
151
152
|
// to please some RSS readers
|
|
@@ -170,6 +171,7 @@ const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
|
170
171
|
});
|
|
171
172
|
return picsPrefix;
|
|
172
173
|
};
|
|
174
|
+
|
|
173
175
|
const formatUrl = (item) => {
|
|
174
176
|
let url = '';
|
|
175
177
|
item.entities.urls &&
|
|
@@ -246,7 +248,7 @@ const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
|
246
248
|
quote += `<br><small>Link: <a href='https://twitter.com/${author.screen_name}/status/${quoteData.id_str}' target='_blank' rel='noopener noreferrer'>https://twitter.com/${author.screen_name}/status/${quoteData.id_str}</a></small>`;
|
|
247
249
|
}
|
|
248
250
|
if (showTimestampInDescription) {
|
|
249
|
-
quote += '<br><small>' +
|
|
251
|
+
quote += '<br><small>' + parseDate(quoteData.created_at);
|
|
250
252
|
quote += `</small>`;
|
|
251
253
|
if (readable) {
|
|
252
254
|
quote += `<br clear='both' /><div style='clear: both'></div>`;
|
|
@@ -368,7 +370,7 @@ const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
|
368
370
|
}
|
|
369
371
|
|
|
370
372
|
if (showTimestampInDescription) {
|
|
371
|
-
description += `<small>${
|
|
373
|
+
description += `<small>${parseDate(item.created_at)}</small>`;
|
|
372
374
|
}
|
|
373
375
|
|
|
374
376
|
const authorName = originalItem.user.name;
|
|
@@ -376,13 +378,14 @@ const ProcessFeed = (ctx, { data = [] }, params = {}) => {
|
|
|
376
378
|
title,
|
|
377
379
|
author: authorName,
|
|
378
380
|
description,
|
|
379
|
-
pubDate:
|
|
381
|
+
pubDate: parseDate(item.created_at),
|
|
380
382
|
link: `https://twitter.com/${item.user.screen_name}/status/${item.id_str}`,
|
|
381
383
|
};
|
|
382
384
|
});
|
|
383
385
|
};
|
|
384
386
|
|
|
385
|
-
let
|
|
387
|
+
let getAppClient = () => null;
|
|
388
|
+
|
|
386
389
|
if (config.twitter.consumer_key && config.twitter.consumer_secret) {
|
|
387
390
|
const consumer_keys = config.twitter.consumer_key.split(',');
|
|
388
391
|
const consumer_secrets = config.twitter.consumer_secret.split(',');
|
|
@@ -390,27 +393,26 @@ if (config.twitter.consumer_key && config.twitter.consumer_secret) {
|
|
|
390
393
|
let count = 0;
|
|
391
394
|
let index = -1;
|
|
392
395
|
|
|
393
|
-
consumer_keys.forEach((consumer_key,
|
|
394
|
-
const consumer_secret = consumer_secrets[
|
|
396
|
+
consumer_keys.forEach((consumer_key, i) => {
|
|
397
|
+
const consumer_secret = consumer_secrets[i];
|
|
395
398
|
if (consumer_key && consumer_secret) {
|
|
396
|
-
T[
|
|
397
|
-
consumer_key,
|
|
398
|
-
consumer_secret,
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
count = index + 1;
|
|
399
|
+
T[i] = new TwitterApi({
|
|
400
|
+
appKey: consumer_key,
|
|
401
|
+
appSecret: consumer_secret,
|
|
402
|
+
}).readOnly;
|
|
403
|
+
count = i + 1;
|
|
402
404
|
}
|
|
403
405
|
});
|
|
404
406
|
|
|
405
|
-
|
|
407
|
+
getAppClient = () => {
|
|
406
408
|
index++;
|
|
407
|
-
return T[index % count];
|
|
409
|
+
return T[index % count].appLogin();
|
|
408
410
|
};
|
|
409
411
|
}
|
|
410
412
|
|
|
411
|
-
|
|
412
|
-
let exclude_replies, include_rts;
|
|
413
|
-
let
|
|
413
|
+
const parseRouteParams = (routeParams) => {
|
|
414
|
+
let count, exclude_replies, include_rts;
|
|
415
|
+
let force_web_api = false;
|
|
414
416
|
if (routeParams === 'exclude_rts_replies' || routeParams === 'exclude_replies_rts') {
|
|
415
417
|
exclude_replies = true;
|
|
416
418
|
include_rts = false;
|
|
@@ -421,16 +423,17 @@ function parseRouteParams(routeParams) {
|
|
|
421
423
|
exclude_replies = false;
|
|
422
424
|
include_rts = false;
|
|
423
425
|
} else {
|
|
424
|
-
const parsed =
|
|
425
|
-
count = fallback(undefined, queryToInteger(parsed.count), undefined);
|
|
426
|
-
exclude_replies = fallback(undefined, queryToBoolean(parsed.excludeReplies), false);
|
|
427
|
-
include_rts = fallback(undefined, queryToBoolean(parsed.includeRts), true);
|
|
426
|
+
const parsed = new URLSearchParams(routeParams);
|
|
427
|
+
count = fallback(undefined, queryToInteger(parsed.get('count')), undefined);
|
|
428
|
+
exclude_replies = fallback(undefined, queryToBoolean(parsed.get('excludeReplies')), false);
|
|
429
|
+
include_rts = fallback(undefined, queryToBoolean(parsed.get('includeRts')), true);
|
|
430
|
+
force_web_api = fallback(undefined, queryToBoolean(parsed.get('forceWebApi')), false);
|
|
428
431
|
}
|
|
429
|
-
return { count, exclude_replies, include_rts };
|
|
430
|
-
}
|
|
432
|
+
return { count, exclude_replies, include_rts, force_web_api };
|
|
433
|
+
};
|
|
431
434
|
|
|
432
435
|
module.exports = {
|
|
433
436
|
ProcessFeed,
|
|
434
|
-
|
|
437
|
+
getAppClient,
|
|
435
438
|
parseRouteParams,
|
|
436
439
|
};
|
package/lib/routes/weibo/user.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const querystring = require('
|
|
1
|
+
const querystring = require('query-string');
|
|
2
2
|
const got = require('@/utils/got');
|
|
3
3
|
const weiboUtils = require('./utils');
|
|
4
4
|
const config = require('@/config').value;
|
|
@@ -62,22 +62,14 @@ module.exports = async (ctx) => {
|
|
|
62
62
|
false
|
|
63
63
|
);
|
|
64
64
|
|
|
65
|
-
let earliestDate;
|
|
66
|
-
|
|
67
65
|
const resultItem = await Promise.all(
|
|
68
66
|
cards
|
|
69
|
-
.
|
|
67
|
+
.filter((item) => item.mblog)
|
|
70
68
|
.map(async (item) => {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
if (!item.mblog) {
|
|
78
|
-
return; // drop
|
|
79
|
-
}
|
|
80
|
-
|
|
69
|
+
// TODO: unify cache key and let weiboUtils.getShowData() handle the cache? It seems safe to do so.
|
|
70
|
+
// Need more investigation, pending for now since the current version works fine.
|
|
71
|
+
// TODO: getShowData() on demand? The API seems to return most things we need since 2022/05/21.
|
|
72
|
+
// Need more investigation, pending for now since the current version works fine.
|
|
81
73
|
const key = 'weibo:user:' + item.mblog.bid;
|
|
82
74
|
const data = await ctx.cache.tryGet(key, () => weiboUtils.getShowData(uid, item.mblog.bid));
|
|
83
75
|
|
|
@@ -92,20 +84,10 @@ module.exports = async (ctx) => {
|
|
|
92
84
|
item.mblog.created_at = timezone(item.mblog.created_at, +8);
|
|
93
85
|
}
|
|
94
86
|
|
|
95
|
-
// drop too old pinned weibo, otherwise preserve it
|
|
96
|
-
if (!item.mblog.title || item.mblog.title.text !== '置顶') {
|
|
97
|
-
if (!earliestDate || (item.mblog.created_at && earliestDate > item.mblog.created_at)) {
|
|
98
|
-
earliestDate = item.mblog.created_at;
|
|
99
|
-
}
|
|
100
|
-
} else {
|
|
101
|
-
if (earliestDate && item.mblog.created_at && earliestDate > item.mblog.created_at) {
|
|
102
|
-
return;
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
|
|
106
87
|
// 转发的长微博处理
|
|
107
88
|
const retweet = item.mblog.retweeted_status;
|
|
108
89
|
if (retweet && retweet.isLongText) {
|
|
90
|
+
// TODO: unify cache key and ...
|
|
109
91
|
const retweetData = await ctx.cache.tryGet(`weibo:retweeted:${retweet.user.id}:${retweet.bid}`, () => weiboUtils.getShowData(retweet.user.id, retweet.bid));
|
|
110
92
|
if (retweetData !== undefined && retweetData.text) {
|
|
111
93
|
item.mblog.retweeted_status.text = retweetData.text;
|
|
@@ -153,11 +135,30 @@ module.exports = async (ctx) => {
|
|
|
153
135
|
})
|
|
154
136
|
);
|
|
155
137
|
|
|
138
|
+
// remove pinned weibo if it is too old (older than all rest weibo).
|
|
139
|
+
// if pinned weibo exists, it will always be the first item and the total item count will be 11 (otherwise 10).
|
|
140
|
+
// if < 11, either there is no pinned weibo or the user sent < 11 weibo in total, no need to remove anything.
|
|
141
|
+
// there is still another characteristic of a pinned weibo: card.profile_type_id.startsWith('proweibotop'),
|
|
142
|
+
// but it can be changed in the future, so here we do not rely on it.
|
|
143
|
+
if (
|
|
144
|
+
resultItem.length >= 11 &&
|
|
145
|
+
resultItem[0].pubDate &&
|
|
146
|
+
resultItem[0].pubDate <
|
|
147
|
+
Math.min(
|
|
148
|
+
...resultItem
|
|
149
|
+
.slice(1)
|
|
150
|
+
.map((item) => item.pubDate)
|
|
151
|
+
.filter((item) => item)
|
|
152
|
+
)
|
|
153
|
+
) {
|
|
154
|
+
resultItem.shift();
|
|
155
|
+
}
|
|
156
|
+
|
|
156
157
|
ctx.state.data = {
|
|
157
158
|
title: `${name}的微博`,
|
|
158
|
-
link: `
|
|
159
|
+
link: `https://weibo.com/${uid}/`,
|
|
159
160
|
description,
|
|
160
161
|
image: profileImageUrl,
|
|
161
|
-
item: resultItem
|
|
162
|
+
item: resultItem,
|
|
162
163
|
};
|
|
163
164
|
};
|