mirror of
https://github.com/supabase/supabase.git
synced 2026-06-23 15:45:38 +08:00
## Context > [!IMPORTANT] > Will open up for review once CLI PR is merged and deployed so that it's easier to test Related PR: https://github.com/supabase/cli/pull/5230 Adding support for vector buckets for local CLI - will need to be tested locally via `pnpm run dev:studio-local` ## To test There's a bit of testing instructions in the linear ticket [here](https://linear.app/supabase/issue/FE-3474/show-vector-buckets-in-local-admin-studio) as it involves using a branch of CLI - otherwise do reach out to Fabrizio if any help might be needed, but generally: ### Local CLI You might need to manually set `isCli` to `true` in `StorageMenuV2` if the "Vectors" nav item isn't showing up on the storage UI given we're testing via `pnpm run dev:studio-local` - [x] Can create bucket - [x] Can delete bucket - [x] Can create indexes - [x] Can insert data into indexes (via FDW) - [x] Can delete indexes Known issues (that aren't directly solvable from FE end) Reach out to Fabrizio for context as we were both investigating this - PG database needs to be on 17.6 (otherwise there's no S3 vectors FDW) - Storage version needs to be on 1.59.0 ### Self-hosted (This might be tricky to actually test, but just ensure that the code satisfies this) - [x] Cannot see vector buckets ### Hosted - [x] Everything works status quo <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **New Features** * Vector bucket management UI and platform APIs (create/list/delete buckets & indexes) * Local S3 credentials endpoint and client-side hook for self‑hosted/CLI use * **Bug Fixes** * Improved S3 vector setup notifications and clearer error guidance for manual installation * **Refactor** * Deployment-mode gating: platform vs CLI/self‑hosted now controls feature visibility and page behavior * **Tests** * Added suites covering deployment-mode gates and vector bucket error/usage scenarios * **Chores** * Build env updated to expose local S3 credential vars <!-- review_stack_entry_start --> [](https://app.coderabbit.ai/change-stack/supabase/supabase/pull/46381?utm_source=github_walkthrough&utm_medium=github&utm_campaign=change_stack) <!-- review_stack_entry_end --> <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: Ali Waseem <waseema393@gmail.com>
33 lines
1.0 KiB
TypeScript
33 lines
1.0 KiB
TypeScript
import { useQuery } from '@tanstack/react-query'
|
|
|
|
import { miscKeys } from './keys'
|
|
import { fetchHandler } from '@/data/fetchers'
|
|
import { BASE_PATH, IS_PLATFORM } from '@/lib/constants'
|
|
import type { ResponseError, UseCustomQueryOptions } from '@/types'
|
|
|
|
export async function getLocalS3Keys() {
|
|
try {
|
|
const data = await fetchHandler(`${BASE_PATH}/api/get-s3-keys`).then((res) => res.json())
|
|
return data as { accessKey?: string; secretKey?: string }
|
|
} catch (error) {
|
|
throw error
|
|
}
|
|
}
|
|
|
|
export type LocalS3KeysData = Awaited<ReturnType<typeof getLocalS3Keys>>
|
|
export type LocalS3KeysError = ResponseError
|
|
|
|
/**
|
|
* Specifically only for local CLI - to use the S3 keys as defined in the env file
|
|
*/
|
|
export const useLocalS3KeysQuery = <TData = LocalS3KeysData>({
|
|
enabled = true,
|
|
...options
|
|
}: UseCustomQueryOptions<LocalS3KeysData, LocalS3KeysError, TData> = {}) =>
|
|
useQuery<LocalS3KeysData, LocalS3KeysError, TData>({
|
|
queryKey: miscKeys.localS3Keys(),
|
|
queryFn: () => getLocalS3Keys(),
|
|
enabled: enabled && !IS_PLATFORM,
|
|
...options,
|
|
})
|