rsshub
Version:
Make RSS Great Again!
51 lines (46 loc) • 1.73 kB
text/typescript
import { Route } from '@/types';
import ofetch from '@/utils/ofetch';
export const route: Route = {
path: '/hacs/repositories',
name: 'HACS Repositories',
maintainers: ['DIYgod'],
categories: ['program-update'],
example: '/home-assistant/hacs/repositories',
handler,
};
async function handler() {
const sections = ['appdaemon', 'critical', 'integration', 'theme', 'python_script', 'plugin'];
const dataList = (
await Promise.all(
sections.map(async (section) => {
const url = `https://data-v2.hacs.xyz/${section}/data.json`;
const response = await ofetch(url);
return Object.values(response);
})
)
).flat() as {
manifest: {
name: string;
};
manifest_name: string;
description: string;
full_name: string;
domain: string;
stargazers_count: number;
topics?: string[];
last_updated: string;
last_fetched: number;
}[];
return {
title: 'HACS Repositories',
link: `https://www.hacs.xyz/`,
item: dataList.map((item) => ({
title: item.manifest_name || item.manifest?.name || item.full_name,
description: `${item.domain ? `<img src="https://brands.home-assistant.io/_/${item.domain}/icon.png" />` : ''}<br>${item.description}<br><br>Last updated: ${item.last_updated}<br>Stars: ${item.stargazers_count}<br>Topics: ${item.topics?.join(', ')}`,
link: `https://github.com/${item.full_name}`,
guid: item.domain || item.full_name,
tags: item.topics,
pubDate: new Date(item.last_fetched * 1000),
})),
};
}