Files
supabase/apps/studio/data/open-api/api-spec-query.ts
Ivan Vasilov 4add928dae chore: Update API types (#35879)
* Regenerate all types from develop branch.

* Fix all types in studio.

* Remove extra type.
2025-05-26 15:43:14 +02:00

69 lines
1.9 KiB
TypeScript

import { useQuery, UseQueryOptions } from '@tanstack/react-query'
import { get, handleError } from 'data/fetchers'
import type { ResponseError } from 'types'
import { openApiKeys } from './keys'
export type OpenAPISpecVariables = {
projectRef?: string
}
export type OpenAPISpecResponse = {
data: any
tables: any[]
functions: any[]
}
export async function getOpenAPISpec({ projectRef }: OpenAPISpecVariables, signal?: AbortSignal) {
if (!projectRef) throw new Error('projectRef is required')
const { data, error } = await get(`/platform/projects/{ref}/api/rest`, {
params: { path: { ref: projectRef } },
signal,
})
if (error) handleError(error)
const definitions = (data as any).definitions
const tables = definitions
? Object.entries(definitions).map(([key, table]: any) => ({
...table,
name: key,
fields: Object.entries(table.properties || {}).map(([key, field]: any) => ({
...field,
name: key,
})),
}))
: []
const paths = (data as any).paths
const functions = paths
? Object.entries(paths)
.map(([path, value]: any) => ({
...value,
path,
name: path.replace('/rpc/', ''),
}))
.filter((x) => x.path.includes('/rpc'))
.sort((a, b) => a.name.localeCompare(b.name))
: []
return { data: data, tables, functions }
}
export type OpenAPISpecData = Awaited<OpenAPISpecResponse>
export type OpenAPISpecError = ResponseError
export const useOpenAPISpecQuery = <TData = OpenAPISpecData>(
{ projectRef }: OpenAPISpecVariables,
{ enabled = true, ...options }: UseQueryOptions<OpenAPISpecData, OpenAPISpecError, TData> = {}
) =>
useQuery<OpenAPISpecData, OpenAPISpecError, TData>(
openApiKeys.apiSpec(projectRef),
({ signal }) => getOpenAPISpec({ projectRef }, signal),
{
enabled: enabled && typeof projectRef !== 'undefined',
...options,
}
)