Rebuild and update project functionality

This commit is contained in:
Gemini AI
2025-12-26 13:13:36 +04:00
Unverified
parent 57576051b3
commit 6fc923c8ba
20 changed files with 375 additions and 396 deletions

View File

@@ -3,6 +3,7 @@ import {
QWEN_OAUTH_CLIENT_ID,
QWEN_OAUTH_DEVICE_CODE_ENDPOINT,
QWEN_OAUTH_SCOPE,
createQwenHeaders,
} from "../../constants";
export async function POST(request: NextRequest) {
@@ -17,12 +18,11 @@ export async function POST(request: NextRequest) {
);
}
console.log(`[Qwen Device Auth] Calling ${QWEN_OAUTH_DEVICE_CODE_ENDPOINT}...`);
const response = await fetch(QWEN_OAUTH_DEVICE_CODE_ENDPOINT, {
method: "POST",
headers: {
"Content-Type": "application/x-www-form-urlencoded",
Accept: "application/json",
},
headers: createQwenHeaders("application/x-www-form-urlencoded"),
body: new URLSearchParams({
client_id: QWEN_OAUTH_CLIENT_ID,
scope: QWEN_OAUTH_SCOPE,
@@ -32,18 +32,25 @@ export async function POST(request: NextRequest) {
});
const payload = await response.text();
if (!response.ok) {
return NextResponse.json(
{ error: "Device authorization failed", details: payload },
{ status: response.status }
);
console.log(`[Qwen Device Auth] Response status: ${response.status}`);
let data;
try {
data = JSON.parse(payload);
} catch {
console.error(`[Qwen Device Auth] Failed to parse response: ${payload}`);
data = { error: payload || "Unknown error from Qwen" };
}
return NextResponse.json(JSON.parse(payload));
if (!response.ok) {
console.warn(`[Qwen Device Auth] Error response:`, data);
}
return NextResponse.json(data, { status: response.status });
} catch (error) {
console.error("Qwen device authorization failed", error);
return NextResponse.json(
{ error: "Device authorization failed" },
{ error: "internal_server_error", message: error instanceof Error ? error.message : "Device authorization failed" },
{ status: 500 }
);
}

View File

@@ -1,5 +1,9 @@
import { NextRequest, NextResponse } from "next/server";
import { QWEN_OAUTH_CLIENT_ID, QWEN_OAUTH_TOKEN_ENDPOINT } from "../../constants";
import {
QWEN_OAUTH_CLIENT_ID,
QWEN_OAUTH_TOKEN_ENDPOINT,
createQwenHeaders,
} from "../../constants";
export async function POST(request: NextRequest) {
try {
@@ -15,10 +19,7 @@ export async function POST(request: NextRequest) {
const response = await fetch(QWEN_OAUTH_TOKEN_ENDPOINT, {
method: "POST",
headers: {
"Content-Type": "application/x-www-form-urlencoded",
Accept: "application/json",
},
headers: createQwenHeaders("application/x-www-form-urlencoded"),
body: new URLSearchParams({
grant_type: "refresh_token",
refresh_token,
@@ -27,18 +28,18 @@ export async function POST(request: NextRequest) {
});
const payload = await response.text();
if (!response.ok) {
return NextResponse.json(
{ error: "Token refresh failed", details: payload },
{ status: response.status }
);
let data;
try {
data = JSON.parse(payload);
} catch {
data = { error: payload || "Unknown error from Qwen" };
}
return NextResponse.json(JSON.parse(payload));
return NextResponse.json(data, { status: response.status });
} catch (error) {
console.error("Qwen token refresh failed", error);
return NextResponse.json(
{ error: "Token refresh failed" },
{ error: "internal_server_error", message: error instanceof Error ? error.message : "Token refresh failed" },
{ status: 500 }
);
}

View File

@@ -3,6 +3,7 @@ import {
QWEN_OAUTH_CLIENT_ID,
QWEN_OAUTH_DEVICE_GRANT_TYPE,
QWEN_OAUTH_TOKEN_ENDPOINT,
createQwenHeaders,
} from "../../constants";
export async function POST(request: NextRequest) {
@@ -17,12 +18,11 @@ export async function POST(request: NextRequest) {
);
}
console.log(`[Qwen Token Poll] Calling ${QWEN_OAUTH_TOKEN_ENDPOINT} for device_code: ${device_code.slice(0, 8)}...`);
const response = await fetch(QWEN_OAUTH_TOKEN_ENDPOINT, {
method: "POST",
headers: {
"Content-Type": "application/x-www-form-urlencoded",
Accept: "application/json",
},
headers: createQwenHeaders("application/x-www-form-urlencoded"),
body: new URLSearchParams({
grant_type: QWEN_OAUTH_DEVICE_GRANT_TYPE,
client_id: QWEN_OAUTH_CLIENT_ID,
@@ -32,18 +32,25 @@ export async function POST(request: NextRequest) {
});
const payload = await response.text();
if (!response.ok) {
return NextResponse.json(
{ error: "Token poll failed", details: payload },
{ status: response.status }
);
console.log(`[Qwen Token Poll] Response status: ${response.status}`);
let data;
try {
data = JSON.parse(payload);
} catch {
console.error(`[Qwen Token Poll] Failed to parse response: ${payload}`);
data = { error: payload || "Unknown error from Qwen" };
}
return NextResponse.json(JSON.parse(payload));
if (data.error && data.error !== "authorization_pending") {
console.warn(`[Qwen Token Poll] Error in response:`, data);
}
return NextResponse.json(data, { status: response.status });
} catch (error) {
console.error("Qwen token poll failed", error);
return NextResponse.json(
{ error: "Token poll failed" },
{ error: "internal_server_error", message: error instanceof Error ? error.message : "Token poll failed" },
{ status: 500 }
);
}