Files
music_bot_v2/page/src/app/api/auth/[...nextauth]/route.ts
tkrmagid-desktop 2e014e9b34 검색해서 재생기능 제작
검색하고 재생 누르면 재생됨
플레이리스트 재생 기능(주소 전달해서 재생하는 방식)
2026-04-09 01:53:27 +09:00

36 lines
1.2 KiB
TypeScript

import NextAuth, { NextAuthOptions } from "next-auth";
import DiscordProvider from "next-auth/providers/discord";
export const authOptions: NextAuthOptions = {
providers: [
DiscordProvider({
clientId: process.env.DISCORD_CLIENT_ID as string,
clientSecret: process.env.DISCORD_CLIENT_SECRET as string,
// 🌟 핵심: 로그인할 때 유저의 기본 정보(identify)와 서버 목록(guilds) 권한을 같이 가져옵니다!
authorization: { params: { scope: "identify email guilds" } },
}),
],
session: {
strategy: "jwt",
},
callbacks: {
// 디스코드에서 받은 토큰(accessToken)을 우리 세션에 저장해두는 로직
async jwt({ token, account, profile }) {
if (account && (profile as any)?.id) {
token.id = (profile as any).id;
token.accessToken = account.access_token;
}
return token;
},
async session({ session, token }: any) {
session.user.id = token.id;
session.accessToken = token.accessToken;
return session;
},
},
};
const handler = NextAuth(authOptions);
// App Router 환경에서는 GET과 POST 메서드를 둘 다 내보내야 합니다.
export { handler as GET, handler as POST };