Skip to content

Commit

Permalink
Merge branch 'blizzard-news-cn' of https://github.com/zhangpeng2k/RSSHub
Browse files Browse the repository at this point in the history
 into feat/overwatch-cn
  • Loading branch information
zhangpeng2k committed Jan 8, 2025
2 parents 9bb55fd + 9e166db commit 9654fb3
Showing 1 changed file with 146 additions and 0 deletions.
146 changes: 146 additions & 0 deletions lib/routes/blizzard/news-cn.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
import { Route } from '@/types';
import { load } from 'cheerio';
import cache from '@/utils/cache';
import ofetch from '@/utils/ofetch';
import { parseDate } from '@/utils/parse-date';

export const route: Route = {
path: 'news-cn/:category',
categories: ['game'],
example: 'blizzard/news-cn/ow',
parameters: { category: '游戏类别, 默认为 ow' },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false,
},
radar: [
{
source: ['ow.blizzard.cn', 'wow.blizzard.cn', 'hs.blizzard.cn'],
target: '/news-cn/',
},
],
name: '暴雪游戏国服新闻',
maintainers: ['zhangpeng2k'],
description: `
| 守望先锋 | 炉石传说 | 魔兽世界 |
|----------|----------|---------|
| ow | hs | wow |
`,
handler,
};

const categoryNames = {
ow: '守望先锋',
hs: '炉石传说',
wow: '魔兽世界',
};

/* 列表解析逻辑 */
const parsers = {
ow: ($) =>
$('.list-data-container .list-item-container').toArray().map((item) => {
item = $(item);
return {
title: item.find('.content-title').text(),
link: item.find('.fill-link').attr('href'),
description: item.find('.content-intro').text(),
pubDate: parseDate(item.find('.content-date').text()),
image: item.find('.item-pic').attr('src'),
};
}),
hs: ($) =>

Check failure

Code scanning / ESLint

Disallow trailing whitespace at the end of lines Error

Trailing spaces not allowed.
$('.article-container>a').toArray().map((item) => {
item = $(item);
return {
title: item.find('.title').text(),
link: item.attr('href'),
description: item.find('.desc').text(),
pubDate: parseDate(item.find('.date').attr('data-time')),
image: item.find('.article-img img').attr('src'),
};
}),
wow: ($) => $('.Pane-list>a').toArray().map((item) => {
item = $(item);
return {
title: item.find('.list-title').text(),
link: item.attr('href'),
description: item.find('.list-desc').text(),
pubDate: parseDate(item.find('.list-time').attr('data-time')),
image: item.find('.img-box img').attr('src'),
};
}),
};

// 详情页解析逻辑
const detailParsers = {
ow: ($) => $('.detail-content-box').first().html(),
hs: ($) => $('.article').first().html(),
wow: ($) => $('.detail').first().html(),
};

function getList(category, $) {
return parsers[category] ? parsers[category]($) : [];
}

async function fetchDetail(item, category) {

Check failure

Code scanning / ESLint

Disallow async functions which have no `await` expression Error

Async function 'fetchDetail' has no 'await' expression.
return cache.tryGet(item.link, async () => {
const response = await ofetch(item.link);
const $ = load(response);

const parseDetail = detailParsers[category];
if (parseDetail) {
item.description = parseDetail($);
} else {
item.description = '无法解析详情内容';
}

Check failure

Code scanning / ESLint

Prefer ternary expressions over simple `if-else` statements. Error

This if statement can be replaced by a ternary expression.

return item;
});
}

async function handler(ctx) {
const category = ctx.req.param('category') || 'ow';
if (!categoryNames[category]) {
return {
title: '错误的类别',
description: '您请求的类别不存在。',
item: [],
};
}

const rootUrl = `https://${category}.blizzard.cn/news`;

try {
const response = await ofetch(rootUrl);
const $ = load(response);

const list = getList(category, $);
if (!list.length) {
return {
title: `${categoryNames[category]}新闻`,
description: '未找到相关新闻。',
item: [],
};
}

const items = await Promise.all(
list.map((item) => fetchDetail(item, category))
);

return {
title: `${categoryNames[category]}新闻`,
link: rootUrl,
item: items,
};
} catch (error) {

Check failure

Code scanning / ESLint

Prefer omitting the `catch` binding parameter. Error

Remove unused catch binding error.

Check failure

Code scanning / ESLint

Disallow unused variables Error

'error' is defined but never used.
return {
title: `${categoryNames[category]}新闻`,
description: '抓取新闻时出错。',
item: [],
};
}
}

0 comments on commit 9654fb3

Please sign in to comment.