mirror of
https://github.com/prowler-cloud/prowler.git
synced 2026-03-22 03:08:23 +00:00
66 lines
1.6 KiB
TypeScript
66 lines
1.6 KiB
TypeScript
"use server";
|
|
|
|
import { NextResponse } from "next/server";
|
|
|
|
import { signIn } from "@/auth.config";
|
|
import { apiBaseUrl, baseUrl } from "@/lib/helper";
|
|
|
|
export async function GET(req: Request) {
|
|
const { searchParams } = new URL(req.url);
|
|
|
|
const code = searchParams.get("code");
|
|
|
|
const params = new URLSearchParams();
|
|
params.append("code", code || "");
|
|
|
|
if (!code) {
|
|
return NextResponse.json(
|
|
{ error: "Authorization code is missing" },
|
|
{ status: 400 },
|
|
);
|
|
}
|
|
|
|
try {
|
|
const response = await fetch(`${apiBaseUrl}/tokens/github`, {
|
|
method: "POST",
|
|
headers: {
|
|
"Content-Type": "application/x-www-form-urlencoded",
|
|
},
|
|
body: params.toString(),
|
|
});
|
|
|
|
if (!response.ok) {
|
|
throw new Error("Failed to exchange code for tokens");
|
|
}
|
|
|
|
const data = await response.json();
|
|
const { access, refresh } = data.data.attributes;
|
|
|
|
try {
|
|
const result = await signIn("social-oauth", {
|
|
accessToken: access,
|
|
refreshToken: refresh,
|
|
redirect: false,
|
|
callbackUrl: `${baseUrl}/`,
|
|
});
|
|
|
|
if (result?.error) {
|
|
throw new Error(result.error);
|
|
}
|
|
|
|
return NextResponse.redirect(new URL("/", baseUrl));
|
|
} catch (error) {
|
|
console.error("SignIn error:", error);
|
|
return NextResponse.redirect(
|
|
new URL("/sign-in?error=AuthenticationFailed", baseUrl),
|
|
);
|
|
}
|
|
} catch (error) {
|
|
console.error("Error in Github callback:", error);
|
|
return NextResponse.json(
|
|
{ error: (error as Error).message },
|
|
{ status: 500 },
|
|
);
|
|
}
|
|
}
|