This commit is contained in:
parent
d200a1ea6c
commit
875412fb69
|
|
@ -1,41 +1,41 @@
|
||||||
// import { createBrowserClient } from "@supabase/ssr"
|
|
||||||
// import { getRuntimeEnv } from "@/lib/ipconfig"
|
|
||||||
// import { Database } from "@/supabase/types"
|
|
||||||
|
|
||||||
// export const supabase = createBrowserClient<Database>(
|
|
||||||
// getRuntimeEnv("SUPABASE_URL") ?? "http://localhost:8000",
|
|
||||||
// process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY! // ✅ 编译时写死,照你意图
|
|
||||||
// )
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import { createBrowserClient } from "@supabase/ssr"
|
import { createBrowserClient } from "@supabase/ssr"
|
||||||
|
import { getRuntimeEnv } from "@/lib/ipconfig"
|
||||||
import { Database } from "@/supabase/types"
|
import { Database } from "@/supabase/types"
|
||||||
|
|
||||||
let _supabase: ReturnType<typeof createBrowserClient<Database>> | null = null
|
export const supabase = createBrowserClient<Database>(
|
||||||
|
getRuntimeEnv("SUPABASE_URL") ?? "http://localhost:8000",
|
||||||
|
process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY! // ✅ 编译时写死,照你意图
|
||||||
|
)
|
||||||
|
|
||||||
export async function createClient() {
|
|
||||||
if (_supabase) return _supabase
|
|
||||||
|
|
||||||
const url = await getRuntimeSupabaseUrl()
|
|
||||||
const key = process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY! // 你要求写死,保留
|
|
||||||
|
|
||||||
_supabase = createBrowserClient(url, key)
|
|
||||||
return _supabase
|
|
||||||
}
|
|
||||||
|
|
||||||
// Export the supabase client directly for easier usage
|
// import { createBrowserClient } from "@supabase/ssr"
|
||||||
export const supabase = async () => {
|
// import { Database } from "@/supabase/types"
|
||||||
// Simply return the client created by createClient
|
|
||||||
return await createClient()
|
|
||||||
}
|
|
||||||
|
|
||||||
async function getRuntimeSupabaseUrl(retry = 30, interval = 50): Promise<string> {
|
// let _supabase: ReturnType<typeof createBrowserClient<Database>> | null = null
|
||||||
for (let i = 0; i < retry; i++) {
|
|
||||||
const url = window?.RUNTIME_ENV?.SUPABASE_URL
|
// export async function createClient() {
|
||||||
if (url) return url
|
// if (_supabase) return _supabase
|
||||||
await new Promise((r) => setTimeout(r, interval))
|
|
||||||
}
|
// const url = await getRuntimeSupabaseUrl()
|
||||||
throw new Error("RUNTIME_ENV.SUPABASE_URL not ready")
|
// const key = process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY! // 你要求写死,保留
|
||||||
}
|
|
||||||
|
// _supabase = createBrowserClient(url, key)
|
||||||
|
// return _supabase
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // Export the supabase client directly for easier usage
|
||||||
|
// export const supabase = async () => {
|
||||||
|
// // Simply return the client created by createClient
|
||||||
|
// return await createClient()
|
||||||
|
// }
|
||||||
|
|
||||||
|
// async function getRuntimeSupabaseUrl(retry = 30, interval = 50): Promise<string> {
|
||||||
|
// for (let i = 0; i < retry; i++) {
|
||||||
|
// const url = window?.RUNTIME_ENV?.SUPABASE_URL
|
||||||
|
// if (url) return url
|
||||||
|
// await new Promise((r) => setTimeout(r, interval))
|
||||||
|
// }
|
||||||
|
// throw new Error("RUNTIME_ENV.SUPABASE_URL not ready")
|
||||||
|
// }
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue