refactor: utilisation de ImageService pour la route des miniatures de livres
This commit is contained in:
@@ -1,54 +1,18 @@
|
|||||||
import { NextResponse } from "next/server";
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
import { cookies } from "next/headers";
|
import { ImageService } from "@/lib/services/image.service";
|
||||||
|
|
||||||
export async function GET(request: Request, { params }: { params: { bookId: string } }) {
|
export async function GET(request: NextRequest, { params }: { params: { bookId: string } }) {
|
||||||
try {
|
try {
|
||||||
// Récupérer les credentials Komga depuis le cookie
|
const { buffer, contentType } = await ImageService.getImage(`books/${params.bookId}/thumbnail`);
|
||||||
const configCookie = cookies().get("komgaCredentials");
|
|
||||||
if (!configCookie) {
|
|
||||||
return NextResponse.json({ error: "Configuration Komga manquante" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
let config;
|
return new NextResponse(buffer, {
|
||||||
try {
|
|
||||||
config = JSON.parse(atob(configCookie.value));
|
|
||||||
} catch (error) {
|
|
||||||
return NextResponse.json({ error: "Configuration Komga invalide" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!config.credentials?.username || !config.credentials?.password) {
|
|
||||||
return NextResponse.json({ error: "Credentials Komga manquants" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
// Appel à l'API Komga
|
|
||||||
const response = await fetch(`${config.serverUrl}/api/v1/books/${params.bookId}/thumbnail`, {
|
|
||||||
headers: {
|
|
||||||
Authorization: `Basic ${Buffer.from(
|
|
||||||
`${config.credentials.username}:${config.credentials.password}`
|
|
||||||
).toString("base64")}`,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!response.ok) {
|
|
||||||
return NextResponse.json(
|
|
||||||
{ error: "Erreur lors de la récupération de l'image" },
|
|
||||||
{ status: response.status }
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Récupérer le type MIME de l'image
|
|
||||||
const contentType = response.headers.get("content-type");
|
|
||||||
const imageBuffer = await response.arrayBuffer();
|
|
||||||
|
|
||||||
// Retourner l'image avec le bon type MIME
|
|
||||||
return new NextResponse(imageBuffer, {
|
|
||||||
headers: {
|
headers: {
|
||||||
"Content-Type": contentType || "image/jpeg",
|
"Content-Type": contentType || "image/jpeg",
|
||||||
"Cache-Control": "public, max-age=31536000, immutable",
|
"Cache-Control": "public, max-age=31536000, immutable",
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Erreur lors de la récupération de l'image:", error);
|
console.error("Erreur lors de la récupération de la miniature du livre:", error);
|
||||||
return NextResponse.json({ error: "Erreur serveur" }, { status: 500 });
|
return new NextResponse("Erreur lors de la récupération de la miniature", { status: 500 });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,50 +1,20 @@
|
|||||||
import { NextResponse } from "next/server";
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
import { cookies } from "next/headers";
|
import { ImageService } from "@/lib/services/image.service";
|
||||||
|
|
||||||
export async function GET(request: Request, { params }: { params: { seriesId: string } }) {
|
export async function GET(request: NextRequest, { params }: { params: { seriesId: string } }) {
|
||||||
try {
|
try {
|
||||||
// Récupérer les credentials Komga depuis le cookie
|
const { buffer, contentType } = await ImageService.getImage(
|
||||||
const configCookie = cookies().get("komga_credentials");
|
`/api/v1/series/${params.seriesId}/thumbnail`
|
||||||
if (!configCookie) {
|
|
||||||
return NextResponse.json({ error: "Configuration Komga manquante" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
let config;
|
|
||||||
try {
|
|
||||||
config = JSON.parse(atob(configCookie.value));
|
|
||||||
} catch (error) {
|
|
||||||
return NextResponse.json({ error: "Configuration Komga invalide" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
// Appel à l'API Komga
|
|
||||||
const response = await fetch(`${config.serverUrl}/api/v1/series/${params.seriesId}/thumbnail`, {
|
|
||||||
headers: {
|
|
||||||
Authorization: `Basic ${Buffer.from(
|
|
||||||
`${config.credentials?.username}:${config.credentials?.password}`
|
|
||||||
).toString("base64")}`,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!response.ok) {
|
|
||||||
return NextResponse.json(
|
|
||||||
{ error: "Erreur lors de la récupération de l'image" },
|
|
||||||
{ status: response.status }
|
|
||||||
);
|
);
|
||||||
}
|
|
||||||
|
|
||||||
// Récupérer le type MIME de l'image
|
return new NextResponse(buffer, {
|
||||||
const contentType = response.headers.get("content-type");
|
|
||||||
const imageBuffer = await response.arrayBuffer();
|
|
||||||
|
|
||||||
// Retourner l'image avec le bon type MIME
|
|
||||||
return new NextResponse(imageBuffer, {
|
|
||||||
headers: {
|
headers: {
|
||||||
"Content-Type": contentType || "image/jpeg",
|
"Content-Type": contentType || "image/jpeg",
|
||||||
"Cache-Control": "public, max-age=31536000, immutable",
|
"Cache-Control": "public, max-age=31536000, immutable",
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Erreur lors de la récupération de l'image:", error);
|
console.error("Erreur lors de la récupération de la miniature de la série:", error);
|
||||||
return NextResponse.json({ error: "Erreur serveur" }, { status: 500 });
|
return new NextResponse("Erreur lors de la récupération de la miniature", { status: 500 });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,70 +1,25 @@
|
|||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
import { TestService } from "@/lib/services/test.service";
|
||||||
|
import { AuthConfig } from "@/types/auth";
|
||||||
|
|
||||||
export async function POST(request: Request) {
|
export async function POST(request: Request) {
|
||||||
try {
|
try {
|
||||||
const { serverUrl, username, password } = await request.json();
|
const { serverUrl, username, password } = await request.json();
|
||||||
|
|
||||||
// Vérification des paramètres requis
|
const config: AuthConfig = {
|
||||||
if (!serverUrl || !username || !password) {
|
serverUrl,
|
||||||
return NextResponse.json({ error: "Tous les champs sont requis" }, { status: 400 });
|
credentials: { username, password },
|
||||||
}
|
};
|
||||||
|
|
||||||
// Test de connexion à Komga en utilisant la route /api/v1/libraries
|
const result = await TestService.testConnection(config);
|
||||||
const response = await fetch(`${serverUrl}/api/v1/libraries`, {
|
return NextResponse.json(result);
|
||||||
headers: {
|
|
||||||
Authorization: `Basic ${Buffer.from(`${username}:${password}`).toString("base64")}`,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
// Log de la réponse pour le debug
|
|
||||||
console.log("Komga response status:", response.status);
|
|
||||||
console.log("Komga response headers:", Object.fromEntries(response.headers.entries()));
|
|
||||||
|
|
||||||
if (!response.ok) {
|
|
||||||
let errorMessage = "Impossible de se connecter au serveur Komga";
|
|
||||||
let errorDetails = null;
|
|
||||||
|
|
||||||
try {
|
|
||||||
errorDetails = await response.json();
|
|
||||||
} catch (e) {
|
|
||||||
// Si on ne peut pas parser la réponse, on utilise le texte brut
|
|
||||||
try {
|
|
||||||
errorDetails = await response.text();
|
|
||||||
} catch (e) {
|
|
||||||
// Si on ne peut pas récupérer le texte non plus, on garde le message par défaut
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Personnalisation du message d'erreur en fonction du status
|
|
||||||
if (response.status === 401) {
|
|
||||||
errorMessage = "Identifiants Komga invalides";
|
|
||||||
} else if (response.status === 404) {
|
|
||||||
errorMessage = "Le serveur Komga n'est pas accessible à cette adresse";
|
|
||||||
}
|
|
||||||
|
|
||||||
return NextResponse.json(
|
|
||||||
{
|
|
||||||
error: errorMessage,
|
|
||||||
details: {
|
|
||||||
status: response.status,
|
|
||||||
statusText: response.statusText,
|
|
||||||
errorDetails,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{ status: response.status }
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
const libraries = await response.json();
|
|
||||||
return NextResponse.json({ success: true, libraries });
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Erreur lors du test de connexion:", error);
|
console.error("Erreur lors du test de connexion:", error);
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
error: "Le serveur Komga est inaccessible",
|
error: error instanceof Error ? error.message : "Erreur inconnue",
|
||||||
details: error instanceof Error ? error.message : "Erreur inconnue",
|
|
||||||
},
|
},
|
||||||
{ status: 500 }
|
{ status: 400 }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user