검색해서 재생기능 제작
검색하고 재생 누르면 재생됨 플레이리스트 재생 기능(주소 전달해서 재생하는 방식)
This commit is contained in:
@@ -15,13 +15,15 @@ export const authOptions: NextAuthOptions = {
|
||||
},
|
||||
callbacks: {
|
||||
// 디스코드에서 받은 토큰(accessToken)을 우리 세션에 저장해두는 로직
|
||||
async jwt({ token, account }) {
|
||||
if (account) {
|
||||
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;
|
||||
},
|
||||
|
||||
44
page/src/app/api/player/play/route.ts
Normal file
44
page/src/app/api/player/play/route.ts
Normal file
@@ -0,0 +1,44 @@
|
||||
import { NextResponse } from "next/server";
|
||||
import { Redis } from "@/lib/Redis";
|
||||
|
||||
export async function POST(request: Request) {
|
||||
try {
|
||||
const body = await request.json();
|
||||
const { serverId, userId, track } = body;
|
||||
|
||||
if (!serverId) return NextResponse.json({ error: "serverId 정보가 필요합니다." }, { status: 400 });
|
||||
if (!userId) return NextResponse.json({ error: "userId 정보가 필요합니다." }, { status: 400 });
|
||||
if (!track) return NextResponse.json({ error: "track 정보가 필요합니다." }, { status: 400 });
|
||||
|
||||
const requestId = `req:${Date.now()}-${Math.random().toString(36).substring(7)}`;
|
||||
const resultKey = `player:play:${requestId}`; // 봇이 대답을 남길 Redis 방 이름
|
||||
|
||||
// 봇에게 'player_play' 명령 전송
|
||||
await Redis.publish("site-bot", JSON.stringify({
|
||||
action: "player_play",
|
||||
requestId: requestId,
|
||||
serverId: serverId,
|
||||
userId: userId,
|
||||
track: track,
|
||||
}));
|
||||
|
||||
// 3. 봇의 대답 기다리기 (최대 약 3초 대기)
|
||||
for (let i = 0; i < 15; i++) {
|
||||
await new Promise(resolve => setTimeout(resolve, 200)); // 0.2초씩 대기
|
||||
const botReply = await Redis.get(resultKey);
|
||||
if (botReply) {
|
||||
// 봇이 대답을 남겼다면! 읽었으니 Redis에서 삭제하고 프론트로 전달
|
||||
await Redis.del(resultKey);
|
||||
const replyData = JSON.parse(botReply);
|
||||
// replyData.success 가 false면 에러 상태코드(400)로 보냄
|
||||
return NextResponse.json(replyData, { status: replyData.success ? 200 : 400 });
|
||||
}
|
||||
}
|
||||
|
||||
// 3초가 지나도 봇이 묵묵부답일 때
|
||||
return NextResponse.json({ success: false, message: "봇이 응답하지 않거나 오프라인 상태입니다." }, { status: 504 });
|
||||
} catch (error) {
|
||||
console.error("Play API Error:", error);
|
||||
return NextResponse.json({ error: "서버 오류가 발생했습니다." }, { status: 500 });
|
||||
}
|
||||
}
|
||||
44
page/src/app/api/player/playlist/route.ts
Normal file
44
page/src/app/api/player/playlist/route.ts
Normal file
@@ -0,0 +1,44 @@
|
||||
import { NextResponse } from "next/server";
|
||||
import { Redis } from "@/lib/Redis";
|
||||
|
||||
export async function POST(request: Request) {
|
||||
try {
|
||||
const body = await request.json();
|
||||
const { serverId, userId, playlistUrl } = body;
|
||||
|
||||
if (!serverId) return NextResponse.json({ error: "serverId 정보가 필요합니다." }, { status: 400 });
|
||||
if (!userId) return NextResponse.json({ error: "userId 정보가 필요합니다." }, { status: 400 });
|
||||
if (!playlistUrl) return NextResponse.json({ error: "playlistUrl 정보가 필요합니다." }, { status: 400 });
|
||||
|
||||
const requestId = `req:${Date.now()}-${Math.random().toString(36).substring(7)}`;
|
||||
const resultKey = `player:playlist:${requestId}`; // 봇이 대답을 남길 Redis 방 이름
|
||||
|
||||
// 봇에게 'player_playlist' 명령 전송
|
||||
await Redis.publish("site-bot", JSON.stringify({
|
||||
action: "player_playlist",
|
||||
requestId: requestId,
|
||||
serverId: serverId,
|
||||
userId: userId,
|
||||
playlistUrl: playlistUrl,
|
||||
}));
|
||||
|
||||
// 3. 봇의 대답 기다리기 (최대 약 3초 대기)
|
||||
for (let i = 0; i < 15; i++) {
|
||||
await new Promise(resolve => setTimeout(resolve, 200)); // 0.2초씩 대기
|
||||
const botReply = await Redis.get(resultKey);
|
||||
if (botReply) {
|
||||
// 봇이 대답을 남겼다면! 읽었으니 Redis에서 삭제하고 프론트로 전달
|
||||
await Redis.del(resultKey);
|
||||
const replyData = JSON.parse(botReply);
|
||||
// replyData.success 가 false면 에러 상태코드(400)로 보냄
|
||||
return NextResponse.json(replyData, { status: replyData.success ? 200 : 400 });
|
||||
}
|
||||
}
|
||||
|
||||
// 3초가 지나도 봇이 묵묵부답일 때
|
||||
return NextResponse.json({ success: false, message: "봇이 응답하지 않거나 오프라인 상태입니다." }, { status: 504 });
|
||||
} catch (error) {
|
||||
console.error("Queue Adds API Error:", error);
|
||||
return NextResponse.json({ error: "서버 오류가 발생했습니다." }, { status: 500 });
|
||||
}
|
||||
}
|
||||
@@ -13,7 +13,7 @@ export async function GET(request: Request) {
|
||||
|
||||
// 2. 고유한 요청 ID 생성 (예: 1690001234567-abc)
|
||||
const requestId = `${Date.now()}-${Math.random().toString(36).substring(7)}`;
|
||||
const resultKey = `search:result:${requestId}`;
|
||||
const resultKey = `search:${requestId}`;
|
||||
|
||||
// 3. 봇에게 'site-bot' 채널로 검색 명령 발송 (Publish)
|
||||
await Redis.publish("site-bot", JSON.stringify({
|
||||
|
||||
Reference in New Issue
Block a user