Skip to content

Latest commit

 

History

History
72 lines (56 loc) · 1.46 KB

API.md

File metadata and controls

72 lines (56 loc) · 1.46 KB

API

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: 'public-apis',
        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,
    "entries": [
        {
            "name": string,
            "slug": string
        }
    ]
}

resources.json:

{
    "count": number,
    "entries": [
        {
            "API": string,
            "Auth": string,
            "Category": string,
            "Cors": string,
            "Description": string,
            "HTTPS": boolean,
            "Link": string,
        }
    ]
}