This repository auto-generates the /db folder after each commit to main. The folder includes two files:
categories.json - A list of all categories
resources.json - A list of all APIs
You can then use Octokit to fetch the data from the db folder.
Here's a minimal snippet on how to accomplish that:
import { Octokit } from 'octokit'
async function fetchResources(file: string) {
const octokit = new Octokit({ auth: process.env.GITHUB_ACCESS_TOKEN })
const { data } = await octokit.rest.repos.getContent({
owner: 'marcelscruz',
repo: 'dev-resources',
path: `/db/${file}.json`,
})
if (data.download_url) {
const result = await fetch(data.download_url)
if (!result.ok) {
throw new Error(`Unexpected response ${result.statusText}`)
}
return await result.json()
} else {
throw new Error('Download URL not found')
}
}The response will be an object with the following structure:
categories.json:
{
"count": number,
"data": [
{
"name": string,
"slug": string
}
]
}resources.json:
{
"count": number,
"data": [
{
"name": string,
"categories": [string],
"description": string,
"url": string,
"keywords": [string] // Optional
}
]
}