@lobehub/chat
Version:
Lobe Chat - an open-source, high-performance chatbot framework that supports speech synthesis, multimodal, and extensible Function Call plugin system. Supports one-click free deployment of your private ChatGPT/LLM web application.
71 lines (58 loc) • 2.13 kB
text/typescript
import { User } from 'next-auth';
import { NextRequest } from 'next/server';
import { JWTPayload, LOBE_CHAT_AUTH_HEADER, enableClerk, enableNextAuth } from '@/const/auth';
import { ClerkAuth, IClerkAuth } from '@/libs/clerk-auth';
export interface AuthContext {
authorizationHeader?: string | null;
clerkAuth?: IClerkAuth;
jwtPayload?: JWTPayload | null;
nextAuth?: User;
userId?: string | null;
}
/**
* Inner function for `createContext` where we create the context.
* This is useful for testing when we don't want to mock Next.js' request/response
*/
export const createContextInner = async (params?: {
authorizationHeader?: string | null;
clerkAuth?: IClerkAuth;
nextAuth?: User;
userId?: string | null;
}): Promise<AuthContext> => ({
authorizationHeader: params?.authorizationHeader,
clerkAuth: params?.clerkAuth,
nextAuth: params?.nextAuth,
userId: params?.userId,
});
export type EdgeContext = Awaited<ReturnType<typeof createContextInner>>;
/**
* Creates context for an incoming request
* @link https://trpc.io/docs/v11/context
*/
export const createEdgeContext = async (request: NextRequest): Promise<EdgeContext> => {
// for API-response caching see https://trpc.io/docs/v11/caching
const authorization = request.headers.get(LOBE_CHAT_AUTH_HEADER);
let userId;
let auth;
if (enableClerk) {
const clerkAuth = new ClerkAuth();
const result = clerkAuth.getAuthFromRequest(request);
auth = result.clerkAuth;
userId = result.userId;
return createContextInner({ authorizationHeader: authorization, clerkAuth: auth, userId });
}
if (enableNextAuth) {
try {
const { default: NextAuthEdge } = await import('@/libs/next-auth/edge');
const session = await NextAuthEdge.auth();
if (session && session?.user?.id) {
auth = session.user;
userId = session.user.id;
}
return createContextInner({ authorizationHeader: authorization, nextAuth: auth, userId });
} catch (e) {
console.error('next auth err', e);
}
}
return createContextInner({ authorizationHeader: authorization, userId });
};