* Update Next.js and React versions in all packages * Replace onRedirect function with next/link in BillingSessionStatus, since it's no longer cached by default * Remove unused revalidatePath import in billing return page, since it's no longer cached by default * Add Turbopack module aliases to improve development server speed * Converted new Dynamic APIs to be Promise-based * Adjust mobile layout * Use ENABLE_REACT_COMPILER to enable the React Compiler in Next.js 15 * Report Errors using the new onRequestError hook
77 lines
1.8 KiB
TypeScript
77 lines
1.8 KiB
TypeScript
import 'server-only';
|
|
|
|
import { cookies } from 'next/headers';
|
|
|
|
import { createClient } from '@supabase/supabase-js';
|
|
|
|
import { createServerClient } from '@supabase/ssr';
|
|
|
|
import { Database } from '../database.types';
|
|
import {
|
|
getServiceRoleKey,
|
|
warnServiceRoleKeyUsage,
|
|
} from '../get-service-role-key';
|
|
import { getSupabaseClientKeys } from '../get-supabase-client-keys';
|
|
|
|
const keys = getSupabaseClientKeys();
|
|
const serviceRoleKey = getServiceRoleKey();
|
|
|
|
function createServerSupabaseClient<
|
|
GenericSchema extends Database = Database,
|
|
>() {
|
|
return createServerClient<GenericSchema>(keys.url, keys.anonKey, {
|
|
cookies: getCookiesStrategy(),
|
|
});
|
|
}
|
|
|
|
/**
|
|
* @name getSupabaseServerComponentClient
|
|
* @deprecated Use `getSupabaseServerClient` instead.
|
|
* @param params
|
|
*/
|
|
export function getSupabaseServerActionClient<
|
|
GenericSchema extends Database = Database,
|
|
>(params?: { admin: boolean }) {
|
|
const keys = getSupabaseClientKeys();
|
|
const admin = params?.admin ?? false;
|
|
|
|
if (admin) {
|
|
warnServiceRoleKeyUsage();
|
|
|
|
return createClient<GenericSchema>(keys.url, serviceRoleKey, {
|
|
auth: {
|
|
persistSession: false,
|
|
detectSessionInUrl: false,
|
|
autoRefreshToken: false,
|
|
},
|
|
});
|
|
}
|
|
|
|
return createServerSupabaseClient();
|
|
}
|
|
|
|
function getCookiesStrategy() {
|
|
return {
|
|
get: async (name: string) => {
|
|
const cookieStore = await cookies();
|
|
const cookie = cookieStore.get(name);
|
|
|
|
return cookie?.value;
|
|
},
|
|
set: async (name: string, value: string, options: object) => {
|
|
const cookieStore = await cookies();
|
|
|
|
cookieStore.set({ name, value, ...options });
|
|
},
|
|
remove: async (name: string, options: object) => {
|
|
const cookieStore = await cookies();
|
|
|
|
cookieStore.set({
|
|
name,
|
|
value: '',
|
|
...options,
|
|
});
|
|
},
|
|
};
|
|
}
|