rsshub 1.0.0-master.fc5a2f6 → 1.0.0-master.fc648b5
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/lib/config.js +4 -0
- package/lib/middleware/anti-hotlink.js +90 -22
- package/lib/middleware/parameter.js +65 -32
- package/lib/middleware/templates/iframe.art +14 -0
- package/lib/radar-rules.js +0 -92
- package/lib/router.js +22 -22
- package/lib/routes/agefans/update.js +1 -1
- package/lib/routes/novel/biqugeinfo.js +2 -2
- package/lib/routes/universities/uestc/sice.js +12 -33
- package/lib/routes/weibo/user.js +10 -19
- package/lib/v2/19lou/index.js +74 -0
- package/lib/v2/19lou/maintainer.js +3 -0
- package/lib/v2/19lou/radar.js +29 -0
- package/lib/v2/19lou/router.js +3 -0
- package/lib/v2/36kr/router.js +1 -1
- package/lib/v2/36kr/user.js +47 -22
- package/lib/v2/acfun/article.js +100 -0
- package/lib/{routes → v2}/acfun/bangumi.js +7 -7
- package/lib/v2/acfun/maintainer.js +5 -0
- package/lib/v2/acfun/radar.js +25 -0
- package/lib/v2/acfun/router.js +5 -0
- package/lib/v2/acfun/video.js +45 -0
- package/lib/v2/agora0/index.js +54 -0
- package/lib/v2/agora0/maintainer.js +3 -0
- package/lib/v2/agora0/radar.js +13 -0
- package/lib/v2/agora0/router.js +3 -0
- package/lib/v2/apnews/maintainer.js +3 -0
- package/lib/v2/apnews/radar.js +13 -0
- package/lib/v2/apnews/router.js +3 -0
- package/lib/v2/apnews/templates/description.art +14 -0
- package/lib/v2/apnews/topics.js +44 -0
- package/lib/v2/appleinsider/index.js +59 -0
- package/lib/v2/appleinsider/maintainer.js +3 -0
- package/lib/v2/appleinsider/radar.js +13 -0
- package/lib/v2/appleinsider/router.js +3 -0
- package/lib/v2/cbnweek/index.js +46 -0
- package/lib/v2/cbnweek/maintainer.js +3 -0
- package/lib/v2/cbnweek/radar.js +13 -0
- package/lib/v2/cbnweek/router.js +3 -0
- package/lib/v2/ccac/news.js +12 -3
- package/lib/v2/cde/index.js +2 -2
- package/lib/v2/cde/maintainer.js +1 -0
- package/lib/v2/cde/radar.js +22 -4
- package/lib/v2/cde/router.js +1 -0
- package/lib/v2/cde/templates/xxgk/breakthroughCure.art +18 -0
- package/lib/v2/cde/templates/xxgk/cliniCal.art +16 -0
- package/lib/v2/cde/templates/xxgk/priorityApproval.art +18 -0
- package/lib/v2/cde/utils.js +2 -2
- package/lib/v2/cde/xxgk.js +73 -0
- package/lib/v2/chinadegrees/maintainer.js +3 -0
- package/lib/v2/chinadegrees/province.js +66 -0
- package/lib/v2/chinadegrees/radar.js +13 -0
- package/lib/v2/chinadegrees/router.js +3 -0
- package/lib/v2/chinadegrees/templates/description.art +4 -0
- package/lib/v2/cnjxol/index.js +94 -0
- package/lib/v2/cnjxol/maintainer.js +4 -0
- package/lib/v2/cnjxol/radar.js +19 -0
- package/lib/v2/cnjxol/router.js +3 -0
- package/lib/v2/cnjxol/templates/description.art +2 -0
- package/lib/v2/cscse/maintainer.js +3 -0
- package/lib/v2/cscse/radar.js +13 -0
- package/lib/v2/cscse/router.js +3 -0
- package/lib/v2/cscse/tzgg.js +54 -0
- package/lib/v2/dgjyw/index.js +67 -0
- package/lib/v2/dgjyw/maintainer.js +3 -0
- package/lib/v2/dgjyw/radar.js +13 -0
- package/lib/v2/dgjyw/router.js +3 -0
- package/lib/v2/domp4/detail.js +67 -0
- package/lib/v2/domp4/latest.js +31 -0
- package/lib/v2/domp4/maintainer.js +4 -0
- package/lib/v2/domp4/radar.js +25 -0
- package/lib/v2/domp4/router.js +4 -0
- package/lib/v2/domp4/utils.js +72 -0
- package/lib/v2/douyin/hashtag.js +5 -43
- package/lib/v2/douyin/live.js +68 -0
- package/lib/v2/douyin/maintainer.js +2 -0
- package/lib/v2/douyin/radar.js +8 -0
- package/lib/v2/douyin/router.js +1 -0
- package/lib/v2/douyin/user.js +5 -43
- package/lib/v2/douyin/utils.js +50 -0
- package/lib/v2/economist/full.js +6 -4
- package/lib/v2/elsevier/issue.js +62 -0
- package/lib/v2/elsevier/journal.js +72 -0
- package/lib/v2/elsevier/maintainer.js +2 -2
- package/lib/v2/elsevier/radar.js +5 -5
- package/lib/v2/elsevier/router.js +4 -2
- package/lib/v2/elsevier/templates/description.art +5 -5
- package/lib/v2/gov/beijing/jw/tzgg.js +58 -0
- package/lib/v2/gov/customs/list.js +21 -17
- package/lib/v2/gov/customs/utils.js +9 -5
- package/lib/v2/gov/maintainer.js +3 -0
- package/lib/v2/gov/nmpa/generic.js +76 -0
- package/lib/v2/gov/pbc/goutongjiaoliu.js +20 -15
- package/lib/v2/gov/pbc/tradeAnnouncement.js +18 -14
- package/lib/v2/gov/radar.js +57 -27
- package/lib/v2/gov/router.js +3 -0
- package/lib/v2/gov/xuzhou/hrss.js +54 -0
- package/lib/v2/hackertalk/index.js +23 -0
- package/lib/v2/hackertalk/maintainer.js +3 -0
- package/lib/v2/hackertalk/radar.js +13 -0
- package/lib/v2/hackertalk/router.js +3 -0
- package/lib/v2/hashnode/blog.js +62 -0
- package/lib/v2/hashnode/maintainer.js +3 -0
- package/lib/v2/hashnode/radar.js +13 -0
- package/lib/v2/hashnode/router.js +3 -0
- package/lib/v2/hashnode/templates/description.art +2 -0
- package/lib/v2/hdu/cs/{index.js → notice.js} +1 -4
- package/lib/v2/hdu/cs/pg.js +54 -0
- package/lib/v2/hdu/maintainer.js +1 -0
- package/lib/v2/hdu/radar.js +6 -0
- package/lib/v2/hdu/router.js +2 -1
- package/lib/v2/heu/gx/list.js +2 -2
- package/lib/v2/heu/job/list.js +2 -2
- package/lib/v2/heu/uae/list.js +2 -2
- package/lib/v2/heu/yjsy/list.js +2 -2
- package/lib/v2/hk01/channel.js +40 -0
- package/lib/{routes → v2}/hk01/hot.js +2 -1
- package/lib/v2/hk01/issue.js +41 -0
- package/lib/v2/hk01/maintainer.js +7 -0
- package/lib/v2/hk01/radar.js +37 -0
- package/lib/v2/hk01/router.js +7 -0
- package/lib/{routes → v2}/hk01/tag.js +2 -1
- package/lib/{routes → v2}/hk01/zone.js +3 -2
- package/lib/v2/hotukdeals/index.js +1 -1
- package/lib/v2/ieee/journal.js +78 -0
- package/lib/v2/ieee/maintainer.js +2 -2
- package/lib/v2/ieee/radar.js +4 -4
- package/lib/v2/ieee/{latestdate.js → recent.js} +34 -42
- package/lib/v2/ieee/router.js +4 -2
- package/lib/v2/ieee/templates/description.art +5 -5
- package/lib/v2/ielts/index.js +7 -2
- package/lib/v2/keep/maintainer.js +3 -0
- package/lib/v2/keep/radar.js +13 -0
- package/lib/v2/keep/router.js +3 -0
- package/lib/v2/keep/templates/user.art +16 -0
- package/lib/{routes → v2}/keep/user.js +14 -4
- package/lib/v2/mdpi/journal.js +65 -0
- package/lib/v2/mdpi/maintainer.js +3 -0
- package/lib/v2/mdpi/radar.js +13 -0
- package/lib/v2/mdpi/router.js +3 -0
- package/lib/v2/mdpi/templates/description.art +12 -0
- package/lib/v2/mindmeister/example.js +44 -0
- package/lib/v2/mindmeister/maintainer.js +3 -0
- package/lib/v2/mindmeister/radar.js +13 -0
- package/lib/v2/mindmeister/router.js +3 -0
- package/lib/v2/mindmeister/templates/image.art +1 -0
- package/lib/v2/mirror/index.js +34 -0
- package/lib/v2/mirror/maintainer.js +3 -0
- package/lib/v2/mirror/radar.js +17 -0
- package/lib/v2/mirror/router.js +3 -0
- package/lib/v2/nbd/radar.js +2 -2
- package/lib/v2/ncwu/maintainer.js +3 -0
- package/lib/v2/ncwu/notice.js +27 -0
- package/lib/v2/ncwu/radar.js +13 -0
- package/lib/v2/ncwu/router.js +3 -0
- package/lib/v2/netease/exclusive.js +148 -0
- package/lib/v2/netease/maintainer.js +1 -0
- package/lib/v2/netease/radar.js +8 -0
- package/lib/v2/netease/router.js +1 -0
- package/lib/v2/netease/templates/exclusive.art +11 -0
- package/lib/v2/nju/rczp.js +34 -24
- package/lib/v2/njust/utils.js +4 -0
- package/lib/v2/nuaa/utils/pypasswaf.js +4 -5
- package/lib/v2/nyaa/maintainer.js +4 -0
- package/lib/v2/nyaa/radar.js +32 -0
- package/lib/v2/nyaa/router.js +4 -0
- package/lib/{routes → v2}/nyaa/search.js +4 -2
- package/lib/v2/nytimes/daily_briefing_chinese.js +47 -41
- package/lib/v2/nytimes/index.js +3 -3
- package/lib/v2/nytimes/maintainer.js +1 -1
- package/lib/v2/nytimes/templates/image.art +3 -0
- package/lib/v2/nytimes/utils.js +7 -1
- package/lib/v2/oceanengine/arithmeticIndex.js +145 -0
- package/lib/v2/oceanengine/maintainer.js +3 -0
- package/lib/v2/oceanengine/radar.js +13 -0
- package/lib/v2/oceanengine/router.js +3 -0
- package/lib/v2/oceanengine/templates/content.art +14 -0
- package/lib/v2/openwrt/maintainer.js +3 -0
- package/lib/v2/openwrt/radar.js +13 -0
- package/lib/v2/openwrt/releases.js +25 -0
- package/lib/v2/openwrt/router.js +3 -0
- package/lib/v2/pincong/utils.js +7 -1
- package/lib/v2/pku/maintainer.js +3 -0
- package/lib/v2/pku/radar.js +20 -0
- package/lib/v2/pku/router.js +3 -0
- package/lib/v2/pku/ss/admission.js +53 -0
- package/lib/v2/pku/ss/notice.js +53 -0
- package/lib/v2/pku/ss/pg_admin.js +53 -0
- package/lib/v2/prestige-av/maintainer.js +3 -0
- package/lib/v2/prestige-av/radar.js +18 -0
- package/lib/v2/prestige-av/router.js +3 -0
- package/lib/{routes → v2}/prestige-av/series.js +8 -5
- package/lib/v2/qq/kg/cache.js +28 -0
- package/lib/v2/qq/kg/reply.js +21 -0
- package/lib/v2/qq/kg/user.js +50 -0
- package/lib/v2/qq/maintainer.js +2 -0
- package/lib/v2/qq/radar.js +14 -0
- package/lib/v2/qq/router.js +2 -0
- package/lib/v2/samsung/maintainer.js +3 -0
- package/lib/v2/samsung/radar.js +13 -0
- package/lib/v2/samsung/research/blog.js +49 -0
- package/lib/v2/samsung/router.js +3 -0
- package/lib/v2/{jasa/latest.js → scitation/journal.js} +24 -27
- package/lib/v2/scitation/maintainer.js +4 -0
- package/lib/v2/scitation/radar.js +19 -0
- package/lib/v2/scitation/router.js +4 -0
- package/lib/v2/scitation/section.js +90 -0
- package/lib/v2/scitation/templates/description.art +11 -0
- package/lib/v2/shuiguopai/index.js +76 -0
- package/lib/v2/shuiguopai/maintainer.js +3 -0
- package/lib/v2/shuiguopai/radar.js +13 -0
- package/lib/v2/shuiguopai/router.js +3 -0
- package/lib/v2/shuiguopai/templates/description.art +6 -0
- package/lib/v2/springer/journal.js +72 -0
- package/lib/v2/springer/maintainer.js +3 -0
- package/lib/v2/springer/radar.js +13 -0
- package/lib/v2/springer/router.js +3 -0
- package/lib/v2/springer/templates/description.art +12 -0
- package/lib/v2/supchina/index.js +67 -0
- package/lib/v2/supchina/maintainer.js +4 -0
- package/lib/v2/supchina/podcasts.js +66 -0
- package/lib/v2/supchina/radar.js +19 -0
- package/lib/v2/supchina/router.js +4 -0
- package/lib/v2/techflow520/index.js +34 -0
- package/lib/v2/techflow520/maintainer.js +4 -0
- package/lib/v2/techflow520/newsflash.js +32 -0
- package/lib/v2/techflow520/radar.js +19 -0
- package/lib/v2/techflow520/router.js +4 -0
- package/lib/v2/tencent/cloud/column.js +51 -0
- package/lib/v2/tencent/maintainer.js +1 -0
- package/lib/v2/tencent/radar.js +11 -0
- package/lib/v2/tencent/router.js +1 -0
- package/lib/v2/test/index.js +16 -1
- package/lib/v2/tiktok/user.js +28 -38
- package/lib/v2/trending/allTrending.js +169 -0
- package/lib/v2/trending/maintainer.js +3 -0
- package/lib/v2/trending/radar.js +35 -0
- package/lib/v2/trending/router.js +3 -0
- package/lib/v2/trending/templates/content.art +24 -0
- package/lib/v2/u3c3/index.js +59 -0
- package/lib/v2/u3c3/maintainer.js +3 -0
- package/lib/v2/u3c3/radar.js +29 -0
- package/lib/v2/u3c3/router.js +3 -0
- package/lib/v2/uraaka-joshi/uraaka-joshi-user.js +7 -1
- package/lib/v2/uraaka-joshi/uraaka-joshi.js +8 -1
- package/lib/v2/vlive/index.js +71 -0
- package/lib/v2/vlive/maintainer.js +3 -0
- package/lib/v2/vlive/radar.js +13 -0
- package/lib/v2/vlive/router.js +3 -0
- package/lib/v2/vlive/templates/post.art +8 -0
- package/lib/v2/vlive/templates/video.art +3 -0
- package/lib/v2/xiaohongshu/util.js +6 -6
- package/lib/v2/xjtu/2yuan/news.js +61 -0
- package/lib/v2/xjtu/dean.js +83 -0
- package/lib/{routes/universities → v2}/xjtu/ee.js +5 -5
- package/lib/{routes/universities → v2}/xjtu/gs/tzgg.js +6 -6
- package/lib/v2/xjtu/international.js +51 -0
- package/lib/v2/xjtu/job.js +81 -0
- package/lib/v2/xjtu/maintainer.js +9 -0
- package/lib/v2/xjtu/radar.js +53 -0
- package/lib/v2/xjtu/router.js +9 -0
- package/lib/v2/xjtu/std.js +58 -0
- package/lib/v2/xjtu/templates/attachments.art +3 -0
- package/lib/v2/xjtu/templates/std.art +4 -0
- package/lib/v2/xueqiu/column.js +42 -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/zhangyoubao/index.js +42 -0
- package/lib/v2/zhangyoubao/maintainer.js +3 -0
- package/lib/v2/zhangyoubao/radar.js +13 -0
- package/lib/v2/zhangyoubao/router.js +3 -0
- package/lib/v2/zhangyoubao/templates/article.art +1 -0
- package/package.json +20 -19
- package/lib/routes/acfun/video.js +0 -44
- package/lib/routes/apnews/topics.js +0 -43
- package/lib/routes/dgjyw/index.js +0 -66
- package/lib/routes/hk01/channel.js +0 -22
- package/lib/routes/hk01/issue.js +0 -22
- package/lib/routes/mirror/entries.js +0 -80
- package/lib/routes/universities/ncwu/notice.js +0 -42
- package/lib/routes/universities/xjtu/dean.js +0 -86
- package/lib/routes/universities/xjtu/international.js +0 -53
- package/lib/routes/universities/xjtu/job.js +0 -50
- package/lib/v2/elsevier/latest.js +0 -87
- package/lib/v2/elsevier/volume.js +0 -75
- package/lib/v2/ieee/latestvol.js +0 -87
- package/lib/v2/jasa/maintainer.js +0 -4
- package/lib/v2/jasa/radar.js +0 -19
- package/lib/v2/jasa/router.js +0 -4
- package/lib/v2/jasa/section.js +0 -95
- package/lib/v2/jasa/templates/description.art +0 -11
package/lib/v2/gov/radar.js
CHANGED
|
@@ -18,10 +18,18 @@ module.exports = {
|
|
|
18
18
|
},
|
|
19
19
|
'beijing.gov.cn': {
|
|
20
20
|
_name: '北京市人民政府',
|
|
21
|
+
jw: [
|
|
22
|
+
{
|
|
23
|
+
title: '北京市教育委员会通知公告',
|
|
24
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-jiao-yu-wei-yuan-tong-zhi-gong-gao',
|
|
25
|
+
source: ['/tzgg'],
|
|
26
|
+
target: '/gov/beijing/jw/tzgg',
|
|
27
|
+
},
|
|
28
|
+
],
|
|
21
29
|
kw: [
|
|
22
30
|
{
|
|
23
31
|
title: '北京市科委央地协同',
|
|
24
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
32
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
25
33
|
source: ['/col/:channel/index.html'],
|
|
26
34
|
target: (params) => {
|
|
27
35
|
if (params.channel === 'col1132') {
|
|
@@ -31,7 +39,7 @@ module.exports = {
|
|
|
31
39
|
},
|
|
32
40
|
{
|
|
33
41
|
title: '北京市科委三城一区',
|
|
34
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
42
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
35
43
|
source: ['/col/:channel/index.html'],
|
|
36
44
|
target: (params) => {
|
|
37
45
|
if (params.channel === 'col1134') {
|
|
@@ -41,7 +49,7 @@ module.exports = {
|
|
|
41
49
|
},
|
|
42
50
|
{
|
|
43
51
|
title: '北京市科委高精尖产业',
|
|
44
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
52
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
45
53
|
source: ['/col/:channel/index.html'],
|
|
46
54
|
target: (params) => {
|
|
47
55
|
if (params.channel === 'col1136') {
|
|
@@ -51,7 +59,7 @@ module.exports = {
|
|
|
51
59
|
},
|
|
52
60
|
{
|
|
53
61
|
title: '北京市科委开放创新',
|
|
54
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
62
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
55
63
|
source: ['/col/:channel/index.html'],
|
|
56
64
|
target: (params) => {
|
|
57
65
|
if (params.channel === 'col1138') {
|
|
@@ -61,7 +69,7 @@ module.exports = {
|
|
|
61
69
|
},
|
|
62
70
|
{
|
|
63
71
|
title: '北京市科委深化改革',
|
|
64
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
72
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
65
73
|
source: ['/col/:channel/index.html'],
|
|
66
74
|
target: (params) => {
|
|
67
75
|
if (params.channel === 'col1140') {
|
|
@@ -71,7 +79,7 @@ module.exports = {
|
|
|
71
79
|
},
|
|
72
80
|
{
|
|
73
81
|
title: '北京市科委内设机构',
|
|
74
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
82
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
75
83
|
source: ['/col/:channel/index.html'],
|
|
76
84
|
target: (params) => {
|
|
77
85
|
if (params.channel === 'col746') {
|
|
@@ -81,7 +89,7 @@ module.exports = {
|
|
|
81
89
|
},
|
|
82
90
|
{
|
|
83
91
|
title: '北京市科委直属机构',
|
|
84
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
92
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
85
93
|
source: ['/col/:channel/index.html'],
|
|
86
94
|
target: (params) => {
|
|
87
95
|
if (params.channel === 'col748') {
|
|
@@ -91,7 +99,7 @@ module.exports = {
|
|
|
91
99
|
},
|
|
92
100
|
{
|
|
93
101
|
title: '北京市科委行政许可',
|
|
94
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
102
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
95
103
|
source: ['/col/:channel/index.html'],
|
|
96
104
|
target: (params) => {
|
|
97
105
|
if (params.channel === 'col1520') {
|
|
@@ -101,7 +109,7 @@ module.exports = {
|
|
|
101
109
|
},
|
|
102
110
|
{
|
|
103
111
|
title: '北京市科委行政处罚',
|
|
104
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
112
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
105
113
|
source: ['/col/:channel/index.html'],
|
|
106
114
|
target: (params) => {
|
|
107
115
|
if (params.channel === 'col1522') {
|
|
@@ -111,7 +119,7 @@ module.exports = {
|
|
|
111
119
|
},
|
|
112
120
|
{
|
|
113
121
|
title: '北京市科委行政确认',
|
|
114
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
122
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
115
123
|
source: ['/col/:channel/index.html'],
|
|
116
124
|
target: (params) => {
|
|
117
125
|
if (params.channel === 'col1524') {
|
|
@@ -121,7 +129,7 @@ module.exports = {
|
|
|
121
129
|
},
|
|
122
130
|
{
|
|
123
131
|
title: '北京市科委行政奖励',
|
|
124
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
132
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
125
133
|
source: ['/col/:channel/index.html'],
|
|
126
134
|
target: (params) => {
|
|
127
135
|
if (params.channel === 'col1526') {
|
|
@@ -131,7 +139,7 @@ module.exports = {
|
|
|
131
139
|
},
|
|
132
140
|
{
|
|
133
141
|
title: '行北京市科委政检查',
|
|
134
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
142
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
135
143
|
source: ['/col/:channel/index.html'],
|
|
136
144
|
target: (params) => {
|
|
137
145
|
if (params.channel === 'col1528') {
|
|
@@ -141,7 +149,7 @@ module.exports = {
|
|
|
141
149
|
},
|
|
142
150
|
{
|
|
143
151
|
title: '北京市科委其他权力',
|
|
144
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
152
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
145
153
|
source: ['/col/:channel/index.html'],
|
|
146
154
|
target: (params) => {
|
|
147
155
|
if (params.channel === 'col1542') {
|
|
@@ -151,7 +159,7 @@ module.exports = {
|
|
|
151
159
|
},
|
|
152
160
|
{
|
|
153
161
|
title: '北京市科委最新政策',
|
|
154
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
162
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
155
163
|
source: ['/col/:channel/index.html'],
|
|
156
164
|
target: (params) => {
|
|
157
165
|
if (params.channel === 'col2380') {
|
|
@@ -161,7 +169,7 @@ module.exports = {
|
|
|
161
169
|
},
|
|
162
170
|
{
|
|
163
171
|
title: '北京市科委科技政策-科技法规规章文件',
|
|
164
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
172
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
165
173
|
source: ['/col/:channel/index.html'],
|
|
166
174
|
target: (params) => {
|
|
167
175
|
if (params.channel === 'col2962' || params.channel === 'col2384') {
|
|
@@ -171,7 +179,7 @@ module.exports = {
|
|
|
171
179
|
},
|
|
172
180
|
{
|
|
173
181
|
title: '北京市科委科技政策-科委规范性文件',
|
|
174
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
182
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
175
183
|
source: ['/col/:channel/index.html'],
|
|
176
184
|
target: (params) => {
|
|
177
185
|
if (params.channel === 'col2962' || params.channel === 'col2386') {
|
|
@@ -181,7 +189,7 @@ module.exports = {
|
|
|
181
189
|
},
|
|
182
190
|
{
|
|
183
191
|
title: '北京市科委科技政策-其他科技政策',
|
|
184
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
192
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
185
193
|
source: ['/col/:channel/index.html'],
|
|
186
194
|
target: (params) => {
|
|
187
195
|
if (params.channel === 'col2962' || params.channel === 'col2388') {
|
|
@@ -191,7 +199,7 @@ module.exports = {
|
|
|
191
199
|
},
|
|
192
200
|
{
|
|
193
201
|
title: '北京市科委国家科技政策',
|
|
194
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
202
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
195
203
|
source: ['/col/:channel/index.html'],
|
|
196
204
|
target: (params) => {
|
|
197
205
|
if (params.channel === 'col2964') {
|
|
@@ -201,7 +209,7 @@ module.exports = {
|
|
|
201
209
|
},
|
|
202
210
|
{
|
|
203
211
|
title: '北京市科委政策解读',
|
|
204
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
212
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
205
213
|
source: ['/col/:channel/index.html'],
|
|
206
214
|
target: (params) => {
|
|
207
215
|
if (params.channel === 'col2396') {
|
|
@@ -211,7 +219,7 @@ module.exports = {
|
|
|
211
219
|
},
|
|
212
220
|
{
|
|
213
221
|
title: '北京市科委通知公告',
|
|
214
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
222
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
215
223
|
source: ['/col/:channel/index.html'],
|
|
216
224
|
target: (params) => {
|
|
217
225
|
if (params.channel === 'col736') {
|
|
@@ -221,7 +229,7 @@ module.exports = {
|
|
|
221
229
|
},
|
|
222
230
|
{
|
|
223
231
|
title: '北京市科委新闻中心',
|
|
224
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
232
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
225
233
|
source: ['/col/:channel/index.html'],
|
|
226
234
|
target: (params) => {
|
|
227
235
|
if (params.channel === 'col6382') {
|
|
@@ -231,7 +239,7 @@ module.exports = {
|
|
|
231
239
|
},
|
|
232
240
|
{
|
|
233
241
|
title: '北京市科委要闻',
|
|
234
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
242
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
235
243
|
source: ['/col/:channel/index.html'],
|
|
236
244
|
target: (params) => {
|
|
237
245
|
if (params.channel === 'col6344') {
|
|
@@ -241,7 +249,7 @@ module.exports = {
|
|
|
241
249
|
},
|
|
242
250
|
{
|
|
243
251
|
title: '北京市科委工作动态',
|
|
244
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
252
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
245
253
|
source: ['/col/:channel/index.html'],
|
|
246
254
|
target: (params) => {
|
|
247
255
|
if (params.channel === 'col2330') {
|
|
@@ -251,7 +259,7 @@ module.exports = {
|
|
|
251
259
|
},
|
|
252
260
|
{
|
|
253
261
|
title: '北京市科委媒体报道',
|
|
254
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
262
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
255
263
|
source: ['/col/:channel/index.html'],
|
|
256
264
|
target: (params) => {
|
|
257
265
|
if (params.channel === 'col2332') {
|
|
@@ -261,7 +269,7 @@ module.exports = {
|
|
|
261
269
|
},
|
|
262
270
|
{
|
|
263
271
|
title: '北京市科委图片报道',
|
|
264
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
272
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
265
273
|
source: ['/col/:channel/index.html'],
|
|
266
274
|
target: (params) => {
|
|
267
275
|
if (params.channel === 'col6346') {
|
|
@@ -271,7 +279,7 @@ module.exports = {
|
|
|
271
279
|
},
|
|
272
280
|
{
|
|
273
281
|
title: '北京市科委政府网站年报专栏',
|
|
274
|
-
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui
|
|
282
|
+
docs: 'https://docs.rsshub.app/government.html#bei-jing-shi-ke-xue-ji-shu-wei-yuan-hui-zhong-guan-cun-ke-ji-yuan-qu-guan-li-wei-yuan-hui',
|
|
275
283
|
source: ['/col/:channel/index.html'],
|
|
276
284
|
target: (params) => {
|
|
277
285
|
if (params.channel === 'col1008') {
|
|
@@ -447,12 +455,23 @@ module.exports = {
|
|
|
447
455
|
'.': [
|
|
448
456
|
{
|
|
449
457
|
title: '分类',
|
|
450
|
-
docs: 'https://docs.rsshub.app/government.html#
|
|
458
|
+
docs: 'https://docs.rsshub.app/government.html#guo-jia-guang-bo-dian-shi-zong-ju',
|
|
451
459
|
source: ['/col/*category'],
|
|
452
460
|
target: (params) => `/gov/nrta/news/${params.category.replace('col', '').replace('/index.html', '')}`,
|
|
453
461
|
},
|
|
454
462
|
],
|
|
455
463
|
},
|
|
464
|
+
'nmpa.gov.cn': {
|
|
465
|
+
_name: '国家药品监督管理局',
|
|
466
|
+
'.': [
|
|
467
|
+
{
|
|
468
|
+
title: '通用',
|
|
469
|
+
docs: 'https://docs.rsshub.app/government.html#guo-jia-yao-pin-jian-du-guan-li-ju',
|
|
470
|
+
source: ['/*path'],
|
|
471
|
+
target: (params) => `/gov/nmpa/${params.path.replace('/index.html', '')}`,
|
|
472
|
+
},
|
|
473
|
+
],
|
|
474
|
+
},
|
|
456
475
|
'pbc.gov.cn': {
|
|
457
476
|
_name: '中国人民银行',
|
|
458
477
|
'.': [
|
|
@@ -537,4 +556,15 @@ module.exports = {
|
|
|
537
556
|
},
|
|
538
557
|
],
|
|
539
558
|
},
|
|
559
|
+
'xz.gov.cn': {
|
|
560
|
+
_name: '徐州市人民政府',
|
|
561
|
+
hrss: [
|
|
562
|
+
{
|
|
563
|
+
title: '徐州市人力资源和社会保障局',
|
|
564
|
+
docs: 'https://docs.rsshub.app/government.html#xu-zhou-shi-ren-min-zheng-fu-xu-zhou-shi-ren-li-zi-yuan-he-she-hui-bao-zhang-ju',
|
|
565
|
+
source: ['/*'],
|
|
566
|
+
target: (params, url) => `/gov/xuzhou/hrss${new URL(url).href.match(/\/(\d+)\/subPage.html/)[1] ?? ''}`,
|
|
567
|
+
},
|
|
568
|
+
],
|
|
569
|
+
},
|
|
540
570
|
};
|
package/lib/v2/gov/router.js
CHANGED
|
@@ -11,6 +11,7 @@ module.exports = function (router) {
|
|
|
11
11
|
router.get('/miit/wjgs', require('./miit/wjgs'));
|
|
12
12
|
router.get('/miit/zcjd', require('./miit/zcjd'));
|
|
13
13
|
router.get('/moe/:type', require('./moe/moe'));
|
|
14
|
+
router.get(/\/nmpa\/([\w][\w/]+)?/, require('./nmpa/generic'));
|
|
14
15
|
router.get('/nrta/news/:category?', require('./nrta/news'));
|
|
15
16
|
router.get('/pbc/goutongjiaoliu', require('./pbc/goutongjiaoliu'));
|
|
16
17
|
router.get('/pbc/gzlw', require('./pbc/gzlw'));
|
|
@@ -18,6 +19,7 @@ module.exports = function (router) {
|
|
|
18
19
|
router.get('/pbc/zcyj', require('./pbc/zcyj'));
|
|
19
20
|
// province
|
|
20
21
|
router.get(/anhui\/kjt\/([\w\d/-]+)?/, require('./anhui/kjt'));
|
|
22
|
+
router.get('/beijing/jw/tzgg', require('./beijing/jw/tzgg'));
|
|
21
23
|
router.get('/beijing/kw/:channel', require('./beijing/kw/index'));
|
|
22
24
|
router.get('/hebei/czt/xwdt/:category?', require('./hebei/czt'));
|
|
23
25
|
router.get('/shenzhen/hrss/szksy/:caty/:page?', require('./shenzhen/hrss/szksy/index'));
|
|
@@ -28,4 +30,5 @@ module.exports = function (router) {
|
|
|
28
30
|
router.get('/guangdong/tqyb/sncsyjxh', require('./guangdong/tqyb/sncsyjxh'));
|
|
29
31
|
router.get('/huizhou/zwgk/:category?', require('./huizhou/zwgk/index'));
|
|
30
32
|
router.get('/sichuan/deyang/govpulicinfo/:countyName', require('./sichuan/deyang/govpulicinfo'));
|
|
33
|
+
router.get('/xuzhou/hrss/:category?', require('./xuzhou/hrss'));
|
|
31
34
|
};
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
const got = require('@/utils/got');
|
|
2
|
+
const cheerio = require('cheerio');
|
|
3
|
+
const timezone = require('@/utils/timezone');
|
|
4
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
5
|
+
|
|
6
|
+
module.exports = async (ctx) => {
|
|
7
|
+
const category = ctx.params.category ?? '';
|
|
8
|
+
|
|
9
|
+
const rootUrl = 'http://hrss.xz.gov.cn';
|
|
10
|
+
const currentUrl = `${rootUrl}${category ? `/001/${category}/subPage.html` : ''}`;
|
|
11
|
+
|
|
12
|
+
const response = await got({
|
|
13
|
+
method: 'get',
|
|
14
|
+
url: currentUrl,
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
const $ = cheerio.load(response.data);
|
|
18
|
+
|
|
19
|
+
let items = (category ? $('.module-items a') : $('.bdl[data-target="1"]').eq(1).find('a')).toArray().map((item) => {
|
|
20
|
+
item = $(item);
|
|
21
|
+
|
|
22
|
+
const link = item.attr('href');
|
|
23
|
+
|
|
24
|
+
return {
|
|
25
|
+
title: item.attr('title'),
|
|
26
|
+
link: `${/^http/.test(link) ? '' : rootUrl}${item.attr('href')}`,
|
|
27
|
+
};
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
items = await Promise.all(
|
|
31
|
+
items.map((item) =>
|
|
32
|
+
ctx.cache.tryGet(item.link, async () => {
|
|
33
|
+
const detailResponse = await got({
|
|
34
|
+
method: 'get',
|
|
35
|
+
url: item.link,
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
const content = cheerio.load(detailResponse.data);
|
|
39
|
+
|
|
40
|
+
item.description = content('#Zoom, .mian-cont, .ewb-article-info, #UCAP-CONTENT').html();
|
|
41
|
+
item.pubDate = timezone(parseDate(content('meta[name="PubDate"]').attr('content')), +8);
|
|
42
|
+
item.category = content('meta[name="Keywords"]').attr('content')?.split(' ');
|
|
43
|
+
|
|
44
|
+
return item;
|
|
45
|
+
})
|
|
46
|
+
)
|
|
47
|
+
);
|
|
48
|
+
|
|
49
|
+
ctx.state.data = {
|
|
50
|
+
title: `徐州市人力资源和社会保障局 - ${category ? $('.wb-tree-items.current').text() : '通知公告'}`,
|
|
51
|
+
link: currentUrl,
|
|
52
|
+
item: items,
|
|
53
|
+
};
|
|
54
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
const got = require('@/utils/got');
|
|
2
|
+
const md = require('markdown-it')();
|
|
3
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
4
|
+
|
|
5
|
+
module.exports = async (ctx) => {
|
|
6
|
+
const limit = ctx.query.limit ?? 25;
|
|
7
|
+
|
|
8
|
+
const response = await got(`https://api.hackertalk.net/v1/posts?limit=${limit}&orderBy=time`);
|
|
9
|
+
|
|
10
|
+
const data = response.data.data;
|
|
11
|
+
|
|
12
|
+
ctx.state.data = {
|
|
13
|
+
title: '黑客说的最新帖子',
|
|
14
|
+
link: 'https://hackertalk.net/?tab=new',
|
|
15
|
+
description: '黑客说 - 技术驱动优质交流',
|
|
16
|
+
item: data.map((item) => ({
|
|
17
|
+
title: item.title,
|
|
18
|
+
description: md.render(item.content),
|
|
19
|
+
pubDate: parseDate(item.createdAt),
|
|
20
|
+
link: `https://hackertalk.net/posts/${item.id}`,
|
|
21
|
+
})),
|
|
22
|
+
};
|
|
23
|
+
};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
const got = require('@/utils/got');
|
|
2
|
+
const { art } = require('@/utils/render');
|
|
3
|
+
const path = require('path');
|
|
4
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
5
|
+
|
|
6
|
+
const baseApiUrl = 'https://api.hashnode.com';
|
|
7
|
+
|
|
8
|
+
module.exports = async (ctx) => {
|
|
9
|
+
const username = ctx.params.username;
|
|
10
|
+
if (!username) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const query = `
|
|
15
|
+
{
|
|
16
|
+
user(username: "${username}") {
|
|
17
|
+
publication {
|
|
18
|
+
posts{
|
|
19
|
+
slug
|
|
20
|
+
title
|
|
21
|
+
brief
|
|
22
|
+
coverImage
|
|
23
|
+
dateAdded
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
`;
|
|
29
|
+
|
|
30
|
+
const userUrl = `https://${username}.hashnode.dev`;
|
|
31
|
+
const response = await got({
|
|
32
|
+
method: 'POST',
|
|
33
|
+
url: baseApiUrl,
|
|
34
|
+
headers: {
|
|
35
|
+
Referer: userUrl,
|
|
36
|
+
'Content-type': 'application/json',
|
|
37
|
+
},
|
|
38
|
+
body: JSON.stringify({ query }),
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
const publication = response.data.data.user.publication;
|
|
42
|
+
if (!publication) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
const list = publication.posts;
|
|
47
|
+
ctx.state.data = {
|
|
48
|
+
title: `Hashnode by ${username}`,
|
|
49
|
+
link: userUrl,
|
|
50
|
+
item: list
|
|
51
|
+
.map((item) => ({
|
|
52
|
+
title: item.title,
|
|
53
|
+
description: art(path.join(__dirname, 'templates/description.art'), {
|
|
54
|
+
image: item.coverImage,
|
|
55
|
+
brief: item.brief,
|
|
56
|
+
}),
|
|
57
|
+
pubDate: parseDate(item.dateAdded),
|
|
58
|
+
link: `${userUrl}/${item.slug}`,
|
|
59
|
+
}))
|
|
60
|
+
.filter((item) => item !== ''),
|
|
61
|
+
};
|
|
62
|
+
};
|
|
@@ -6,10 +6,7 @@ const link = 'https://computer.hdu.edu.cn';
|
|
|
6
6
|
const host = 'https://computer.hdu.edu.cn/6738/list.htm';
|
|
7
7
|
|
|
8
8
|
const getSingleRecord = async () => {
|
|
9
|
-
const res = await got(
|
|
10
|
-
method: 'get',
|
|
11
|
-
url: host,
|
|
12
|
-
});
|
|
9
|
+
const res = await got(host);
|
|
13
10
|
|
|
14
11
|
const $ = cheerio.load(res.data);
|
|
15
12
|
const list = $('.posts-list').find('li');
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
const got = require('@/utils/got');
|
|
2
|
+
const cheerio = require('cheerio');
|
|
3
|
+
const { parseDate } = require('@/utils/parse-date');
|
|
4
|
+
|
|
5
|
+
const link = 'https://computer.hdu.edu.cn';
|
|
6
|
+
const host = 'https://computer.hdu.edu.cn/6769/list.htm';
|
|
7
|
+
|
|
8
|
+
const getSingleRecord = async () => {
|
|
9
|
+
const res = await got(host);
|
|
10
|
+
|
|
11
|
+
const $ = cheerio.load(res.data);
|
|
12
|
+
const list = $('.posts-list').find('li');
|
|
13
|
+
|
|
14
|
+
return (
|
|
15
|
+
list &&
|
|
16
|
+
list
|
|
17
|
+
.map((index, item) => {
|
|
18
|
+
item = $(item);
|
|
19
|
+
const dateTxt = item.find('.date').text();
|
|
20
|
+
const date = dateTxt.slice(1, dateTxt.length - 1);
|
|
21
|
+
return {
|
|
22
|
+
title: item.find('a').text(),
|
|
23
|
+
pubDate: parseDate(date),
|
|
24
|
+
link: link + item.find('a').attr('href'),
|
|
25
|
+
};
|
|
26
|
+
})
|
|
27
|
+
.get()
|
|
28
|
+
);
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
module.exports = async (ctx) => {
|
|
32
|
+
const items = await getSingleRecord();
|
|
33
|
+
const out = await Promise.all(
|
|
34
|
+
items.map((item) =>
|
|
35
|
+
ctx.cache.tryGet(item.link, async () => {
|
|
36
|
+
const response = await got(item.link);
|
|
37
|
+
const $ = cheerio.load(response.data);
|
|
38
|
+
return {
|
|
39
|
+
title: item.title,
|
|
40
|
+
link: item.link,
|
|
41
|
+
description: $('.wp_articlecontent').html(),
|
|
42
|
+
pubDate: item.pubDate,
|
|
43
|
+
};
|
|
44
|
+
})
|
|
45
|
+
)
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
ctx.state.data = {
|
|
49
|
+
title: '杭电计算机-研究生通知',
|
|
50
|
+
description: '杭州电子科技大学计算机学院-研究生教学通知',
|
|
51
|
+
link: host,
|
|
52
|
+
item: out,
|
|
53
|
+
};
|
|
54
|
+
};
|
package/lib/v2/hdu/maintainer.js
CHANGED
package/lib/v2/hdu/radar.js
CHANGED
|
@@ -8,6 +8,12 @@ module.exports = {
|
|
|
8
8
|
source: '/6738/list.htm',
|
|
9
9
|
target: '/hdu/cs',
|
|
10
10
|
},
|
|
11
|
+
{
|
|
12
|
+
title: '杭电计算机-研究生通知',
|
|
13
|
+
docs: 'https://docs.rsshub.app/university.html#hang-zhou-dian-zi-ke-ji-da-xue',
|
|
14
|
+
source: '/6769/list.htm',
|
|
15
|
+
target: '/hdu/cs/pg',
|
|
16
|
+
},
|
|
11
17
|
],
|
|
12
18
|
},
|
|
13
19
|
};
|
package/lib/v2/hdu/router.js
CHANGED
package/lib/v2/heu/gx/list.js
CHANGED
|
@@ -47,7 +47,7 @@ module.exports = async (ctx) => {
|
|
|
47
47
|
})
|
|
48
48
|
.get();
|
|
49
49
|
|
|
50
|
-
await Promise.all(
|
|
50
|
+
const items = await Promise.all(
|
|
51
51
|
list.map((item) =>
|
|
52
52
|
ctx.cache.tryGet(item.link, async () => {
|
|
53
53
|
if (item.link.indexOf('info') !== -1) {
|
|
@@ -68,6 +68,6 @@ module.exports = async (ctx) => {
|
|
|
68
68
|
ctx.state.data = {
|
|
69
69
|
title: '工学-' + bigTitle,
|
|
70
70
|
link: toUrl,
|
|
71
|
-
item:
|
|
71
|
+
item: items,
|
|
72
72
|
};
|
|
73
73
|
};
|
package/lib/v2/heu/job/list.js
CHANGED
|
@@ -44,7 +44,7 @@ module.exports = async (ctx) => {
|
|
|
44
44
|
})
|
|
45
45
|
.get();
|
|
46
46
|
|
|
47
|
-
await Promise.all(
|
|
47
|
+
const items = await Promise.all(
|
|
48
48
|
list.map((item) =>
|
|
49
49
|
ctx.cache.tryGet(item.link, async () => {
|
|
50
50
|
if (item.link.indexOf('HrbeuJY') !== -1) {
|
|
@@ -65,6 +65,6 @@ module.exports = async (ctx) => {
|
|
|
65
65
|
ctx.state.data = {
|
|
66
66
|
title: '就业服务平台-' + idMap[id].name,
|
|
67
67
|
link: idMap[id].url,
|
|
68
|
-
item:
|
|
68
|
+
item: items,
|
|
69
69
|
};
|
|
70
70
|
};
|
package/lib/v2/heu/uae/list.js
CHANGED
|
@@ -35,7 +35,7 @@ module.exports = async (ctx) => {
|
|
|
35
35
|
})
|
|
36
36
|
.get();
|
|
37
37
|
|
|
38
|
-
await Promise.all(
|
|
38
|
+
const items = await Promise.all(
|
|
39
39
|
list.map((item) =>
|
|
40
40
|
ctx.cache.tryGet(item.link, async () => {
|
|
41
41
|
if (item.link.indexOf('page.htm') !== -1) {
|
|
@@ -57,6 +57,6 @@ module.exports = async (ctx) => {
|
|
|
57
57
|
ctx.state.data = {
|
|
58
58
|
title: '水声学院-' + bigTitle,
|
|
59
59
|
link: rootUrl.concat('/', id, '/list.htm'),
|
|
60
|
-
item:
|
|
60
|
+
item: items,
|
|
61
61
|
};
|
|
62
62
|
};
|