mirror of
https://github.com/DIYgod/RSSHub.git
synced 2025-12-04 02:58:08 +08:00
* fix(route): add Open Graph image to GitHub trending Adds Open Graph image for each repository to the GitHub trending feed. * chore(route): address pull request feedback - Refactors page request call to make it more terse - Adds art template for trending description - Updates maintainers for '/trending/:since/:language?/:spoken_language?'
60 lines
2.0 KiB
JavaScript
60 lines
2.0 KiB
JavaScript
const got = require('@/utils/got');
|
|
const { art } = require('@/utils/render');
|
|
const cheerio = require('cheerio');
|
|
const path = require('path');
|
|
|
|
module.exports = async (ctx) => {
|
|
const since = ctx.params.since;
|
|
const language = ctx.params.language === 'any' ? '' : ctx.params.language;
|
|
const spoken_language = ctx.params.spoken_language ?? '';
|
|
const url = `https://github.com/trending/${encodeURIComponent(language)}?since=${since}&spoken_language_code=${spoken_language}`;
|
|
|
|
const response = await got({
|
|
method: 'get',
|
|
url,
|
|
headers: {
|
|
Referer: url,
|
|
},
|
|
});
|
|
|
|
const data = response.data;
|
|
|
|
const $ = cheerio.load(data);
|
|
const list = $('article');
|
|
|
|
const items = await Promise.all(
|
|
list.map((_, item) => {
|
|
item = $(item);
|
|
const endpoint = item.find('h1 a').attr('href');
|
|
const link = `https://github.com${endpoint}`;
|
|
return ctx.cache.tryGet(`github:trending:${endpoint}`, async () => {
|
|
const response = await got(link);
|
|
|
|
const $ = cheerio.load(response.data);
|
|
const cover = $('meta[property="og:image"]');
|
|
|
|
const single = {
|
|
title: item.find('h1').text(),
|
|
author: item.find('h1').text().split('/')[0].trim(),
|
|
description: art(path.join(__dirname, 'templates/trending-description.art'), {
|
|
cover: cover.attr('content'),
|
|
desc: item.find('p').text(),
|
|
lang: item.find('span[itemprop="programmingLanguage"]').text() || 'Unknown',
|
|
stars: item.find('.Link--muted').eq(0).text().trim(),
|
|
forks: item.find('.Link--muted').eq(1).text().trim(),
|
|
}),
|
|
link,
|
|
};
|
|
|
|
return single;
|
|
});
|
|
})
|
|
);
|
|
|
|
ctx.state.data = {
|
|
title: $('title').text(),
|
|
link: url,
|
|
item: items,
|
|
};
|
|
};
|