Files
supabase/apps/studio/data/database/migrations-query.ts
2024-01-04 17:27:49 +01:00

52 lines
1.3 KiB
TypeScript

import { UseQueryOptions } from '@tanstack/react-query'
import { ExecuteSqlData, useExecuteSqlQuery } from '../sql/execute-sql-query'
export type DatabaseMigration = {
version: string
name?: string
statements?: string[]
}
export const getMigrationsQuery = () => {
const sql = /* SQL */ `
select
*
from supabase_migrations.schema_migrations sm
order by sm.version desc
`.trim()
return sql
}
export type MigrationsVariables = {
projectRef?: string
connectionString?: string
}
export type MigrationsData = { result: DatabaseMigration[] }
export type MigrationsError = unknown
export const useMigrationsQuery = <TData extends MigrationsData = MigrationsData>(
{ projectRef, connectionString }: MigrationsVariables,
options: UseQueryOptions<ExecuteSqlData, MigrationsError, TData> = {}
) => {
return useExecuteSqlQuery(
{
projectRef,
connectionString,
sql: getMigrationsQuery(),
queryKey: ['migrations'],
handleError: (error: { code: number; message: string; requestId: string }) => {
if (
error.message.includes('relation "supabase_migrations.schema_migrations" does not exist')
) {
return { result: [] }
} else {
throw error
}
},
},
options
)
}