diff --git a/src/helpers/characters/serializeBigInt.ts b/src/helpers/characters/serializeBigInt.ts new file mode 100644 index 0000000..5a24683 --- /dev/null +++ b/src/helpers/characters/serializeBigInt.ts @@ -0,0 +1,5 @@ +export const serializeBigInt = (data: T): T => { + return JSON.parse( + JSON.stringify(data, (_, v) => (typeof v === "bigint" ? Number(v) : v)), + ); +}; diff --git a/src/modules/episode/repositories/GET/getEpisodeDetails.repository.ts b/src/modules/episode/repositories/GET/getEpisodeDetails.repository.ts index 216f35d..7a582bf 100644 --- a/src/modules/episode/repositories/GET/getEpisodeDetails.repository.ts +++ b/src/modules/episode/repositories/GET/getEpisodeDetails.repository.ts @@ -1,3 +1,4 @@ +import { serializeBigInt } from "../../../../helpers/characters/serializeBigInt"; import { AppError } from "../../../../helpers/error/instances/app"; import { episodeModel } from "../../episode.model"; @@ -6,7 +7,7 @@ export const getEpisodeDetailsRepository = async (payload: { episode: number; }) => { try { - return await episodeModel.findUnique({ + const result = await episodeModel.findUnique({ where: { mediaId_episode: { mediaId: payload.mediaId, @@ -57,6 +58,8 @@ export const getEpisodeDetailsRepository = async (payload: { }, }, }); + + return serializeBigInt(result); } catch (error) { throw new AppError(500, "Failed to fetch episode details.", error); }