OAuth sign in isn't redirecting on the server side

Last edited: 2/4/2025

The reason behind this limitation is that the auth helpers library lacks a direct mechanism for performing server-side redirects, as each framework handles redirects differently. However, the library does offer a URL through the data property it returns, which should be utilized for the purpose of redirection.

Next.js:

1
import { NextResponse } from "next/server";
2
...
3
const { data } = await supabase.auth.signInWithOAuth({
4
provider: 'github',
5
})
6
7
return NextResponse.redirect(data.url)

SvelteKit:

1
import { redirect } from '@sveltejs/kit';
2
...
3
const { data } = await supabase.auth.signInWithOAuth({
4
provider: 'github',
5
})
6
7
throw redirect(303, data.url)

Remix:

1
import { redirect } from "@remix-run/node"; // or cloudflare/deno
2
...
3
const { data } = await supabase.auth.signInWithOAuth({
4
provider: 'github',
5
})
6
7
return redirect(data.url)