reacto: images not called directly in routes
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
import { NextRequest, NextResponse } from "next/server";
|
||||
import { ImageService } from "@/lib/services/image.service";
|
||||
import { BookService } from "@/lib/services/book.service";
|
||||
|
||||
export const dynamic = "force-dynamic";
|
||||
|
||||
@@ -8,16 +8,8 @@ export async function GET(
|
||||
{ params }: { params: { bookId: string; pageNumber: string } }
|
||||
) {
|
||||
try {
|
||||
const { buffer, contentType } = await ImageService.getImage(
|
||||
`books/${params.bookId}/pages/${params.pageNumber}`
|
||||
);
|
||||
|
||||
return new NextResponse(buffer, {
|
||||
headers: {
|
||||
"Content-Type": contentType || "image/jpeg",
|
||||
"Cache-Control": "public, max-age=31536000, immutable",
|
||||
},
|
||||
});
|
||||
const response = await BookService.getPage(params.bookId, parseInt(params.pageNumber));
|
||||
return response;
|
||||
} catch (error) {
|
||||
console.error("Erreur lors de la récupération de la page du livre:", error);
|
||||
return new NextResponse("Erreur lors de la récupération de la page", { status: 500 });
|
||||
|
||||
@@ -1,16 +1,10 @@
|
||||
import { NextRequest, NextResponse } from "next/server";
|
||||
import { ImageService } from "@/lib/services/image.service";
|
||||
import { BookService } from "@/lib/services/book.service";
|
||||
|
||||
export async function GET(request: NextRequest, { params }: { params: { bookId: string } }) {
|
||||
try {
|
||||
const { buffer, contentType } = await ImageService.getImage(`books/${params.bookId}/thumbnail`);
|
||||
|
||||
return new NextResponse(buffer, {
|
||||
headers: {
|
||||
"Content-Type": contentType || "image/jpeg",
|
||||
"Cache-Control": "public, max-age=31536000, immutable",
|
||||
},
|
||||
});
|
||||
const response = await BookService.getThumbnail(params.bookId);
|
||||
return response;
|
||||
} catch (error) {
|
||||
console.error("Erreur lors de la récupération de la miniature du livre:", error);
|
||||
return new NextResponse("Erreur lors de la récupération de la miniature", { status: 500 });
|
||||
|
||||
@@ -1,39 +1,14 @@
|
||||
import { NextRequest, NextResponse } from "next/server";
|
||||
import { ImageService } from "@/lib/services/image.service";
|
||||
import { SeriesService } from "@/lib/services/series.service";
|
||||
|
||||
export const dynamic = "force-dynamic";
|
||||
|
||||
export async function GET(request: NextRequest, { params }: { params: { seriesId: string } }) {
|
||||
try {
|
||||
// Récupérer l'ID du premier livre
|
||||
const firstBookId = await SeriesService.getFirstBook(params.seriesId);
|
||||
|
||||
// Récupérer la première page du premier livre
|
||||
const { buffer, contentType } = await ImageService.getImage(`books/${firstBookId}/pages/1`);
|
||||
|
||||
return new NextResponse(buffer, {
|
||||
headers: {
|
||||
"Content-Type": contentType || "image/jpeg",
|
||||
"Cache-Control": "public, max-age=31536000, immutable",
|
||||
},
|
||||
});
|
||||
const response = await SeriesService.getFirstPage(params.seriesId);
|
||||
return response;
|
||||
} catch (error) {
|
||||
console.error("Erreur lors de la récupération de la première page de la série:", error);
|
||||
|
||||
// En cas d'erreur, on essaie de récupérer le thumbnail comme fallback
|
||||
try {
|
||||
const { buffer, contentType } = await ImageService.getImage(
|
||||
`series/${params.seriesId}/thumbnail`
|
||||
);
|
||||
return new NextResponse(buffer, {
|
||||
headers: {
|
||||
"Content-Type": contentType || "image/jpeg",
|
||||
"Cache-Control": "public, max-age=31536000, immutable",
|
||||
},
|
||||
});
|
||||
} catch (fallbackError) {
|
||||
return new NextResponse("Erreur lors de la récupération de l'image", { status: 500 });
|
||||
}
|
||||
return new NextResponse("Erreur lors de la récupération de l'image", { status: 500 });
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,18 +1,10 @@
|
||||
import { NextRequest, NextResponse } from "next/server";
|
||||
import { ImageService } from "@/lib/services/image.service";
|
||||
import { SeriesService } from "@/lib/services/series.service";
|
||||
|
||||
export async function GET(request: NextRequest, { params }: { params: { seriesId: string } }) {
|
||||
try {
|
||||
const { buffer, contentType } = await ImageService.getImage(
|
||||
`series/${params.seriesId}/thumbnail`
|
||||
);
|
||||
|
||||
return new NextResponse(buffer, {
|
||||
headers: {
|
||||
"Content-Type": contentType || "image/jpeg",
|
||||
"Cache-Control": "public, max-age=31536000, immutable",
|
||||
},
|
||||
});
|
||||
const response = await SeriesService.getThumbnail(params.seriesId);
|
||||
return response;
|
||||
} catch (error) {
|
||||
console.error("Erreur lors de la récupération de la miniature de la série:", error);
|
||||
return new NextResponse("Erreur lors de la récupération de la miniature", { status: 500 });
|
||||
|
||||
Reference in New Issue
Block a user