refactor: bulk insert module
This commit is contained in:
@ -1,26 +1,46 @@
|
||||
import { Prisma } from "@prisma/client";
|
||||
import { AppError } from "../../../helpers/error/instances/app";
|
||||
import { prisma } from "../../../utils/databases/prisma/connection";
|
||||
import { generateUUIDv7 } from "../../../helpers/databases/uuidv7";
|
||||
import {AppError} from "../../../helpers/error/instances/app";
|
||||
import {prisma} from "../../../utils/databases/prisma/connection";
|
||||
import {SystemAccountId} from "../../../config/account/system";
|
||||
|
||||
|
||||
export interface BulkInsertEpisodesPayload {
|
||||
media_id: string
|
||||
episode_number: number
|
||||
title: string
|
||||
title_romanji: string
|
||||
title_origin: string
|
||||
aired_at: Date
|
||||
score: number
|
||||
filler: boolean
|
||||
recap: boolean
|
||||
forum_url: string
|
||||
created_by_id: string
|
||||
}
|
||||
|
||||
export const bulkInsertEpisodesRepository = async (
|
||||
payload: Omit<Prisma.EpisodeUncheckedCreateInput, "id">,
|
||||
payload: BulkInsertEpisodesPayload[]
|
||||
) => {
|
||||
try {
|
||||
return await prisma.episode.upsert({
|
||||
where: {
|
||||
mediaId_episode: {
|
||||
mediaId: payload.mediaId as string,
|
||||
episode: payload.episode as number,
|
||||
},
|
||||
},
|
||||
update: payload,
|
||||
create: {
|
||||
id: generateUUIDv7(),
|
||||
...payload,
|
||||
},
|
||||
});
|
||||
} catch (err) {
|
||||
throw new AppError(500, "Failed to bulk insert episodes", err);
|
||||
}
|
||||
try {
|
||||
await prisma.$transaction(async (tx) => {
|
||||
await Promise.all(
|
||||
payload.map(async (episode) =>
|
||||
await tx.episode.upsert({
|
||||
where: {
|
||||
media_id_episode_number: {
|
||||
media_id: episode.media_id,
|
||||
episode_number: episode.episode_number
|
||||
}
|
||||
},
|
||||
update: episode,
|
||||
create: {
|
||||
...episode,
|
||||
created_by_id: SystemAccountId
|
||||
}
|
||||
})
|
||||
)
|
||||
)
|
||||
})
|
||||
} catch (err) {
|
||||
throw new AppError(500, "Failed to bulk insert episodes", err);
|
||||
}
|
||||
};
|
||||
|
||||
@ -0,0 +1,14 @@
|
||||
import {AppError} from "../../../helpers/error/instances/app";
|
||||
import {prisma} from "../../../utils/databases/prisma/connection";
|
||||
|
||||
export const findMediaWithMalIdRepository = async (malId: number) => {
|
||||
try {
|
||||
return await prisma.media.findUnique({
|
||||
where: {
|
||||
mal_id: malId
|
||||
}
|
||||
});
|
||||
} catch (error) {
|
||||
throw new AppError(500, "Failed to find media with malId", error)
|
||||
}
|
||||
};
|
||||
@ -1,35 +1,37 @@
|
||||
import { ErrorForwarder } from "../../../../helpers/error/instances/forwarder";
|
||||
import { MediaEpisodeInfoResponse } from "../../types/mediaEpisodeInfo.type";
|
||||
import { AppError } from "../../../../helpers/error/instances/app";
|
||||
import { SystemAccountId } from "../../../../config/account/system";
|
||||
import { bulkInsertEpisodesRepository } from "../../repositories/bulkInsertEpisodes.repository";
|
||||
import { getEpisodeReferenceAPI } from "../../../../config/apis/jikan/episode.reference";
|
||||
import { selectMediaByMalIdRepository } from "../../../media/repositories/SELECT/selectMediaByMalId.repository";
|
||||
import {MediaEpisodeInfoResponse} from "../../types/mediaEpisodeInfo.type";
|
||||
import {AppError} from "../../../../helpers/error/instances/app";
|
||||
import {SystemAccountId} from "../../../../config/account/system";
|
||||
import {ErrorForwarder} from "../../../../helpers/error/instances/forwarder";
|
||||
import {bulkInsertEpisodesRepository} from "../../repositories/bulkInsertEpisodes.repository";
|
||||
import {getEpisodeReferenceAPI} from "../../../../config/apis/jikan/episode.reference";
|
||||
import {findMediaWithMalIdRepository} from "../../repositories/findMediaWithMalId.repository";
|
||||
|
||||
export const bulkInsertEpisodeService = async (mal_id: number, page: number = 1) => {
|
||||
try {
|
||||
const episodeAPI = getEpisodeReferenceAPI(mal_id);
|
||||
const episodeData: MediaEpisodeInfoResponse = await fetch(
|
||||
`${episodeAPI.baseURL}${episodeAPI.getEpisodeList}?page=${page}`,
|
||||
).then((res) => res.json());
|
||||
try {
|
||||
const episodeAPI = getEpisodeReferenceAPI(mal_id);
|
||||
const episodeData: MediaEpisodeInfoResponse = await fetch(
|
||||
`${episodeAPI.baseURL}${episodeAPI.getEpisodeList}?page=${page}`,
|
||||
).then((res) => res.json()) as MediaEpisodeInfoResponse;
|
||||
|
||||
const mediaData = await selectMediaByMalIdRepository(mal_id);
|
||||
if (!mediaData) throw new AppError(404, `Media with Mal ID ${mal_id} not found in database`);
|
||||
const mediaData = await findMediaWithMalIdRepository(mal_id)
|
||||
if (!mediaData) throw new AppError(404, "Media not found");
|
||||
|
||||
const insertedEpisodeData = [];
|
||||
episodeData.data.forEach(async (episode) => {
|
||||
insertedEpisodeData.push(
|
||||
await bulkInsertEpisodesRepository({
|
||||
mediaId: mediaData.id!,
|
||||
episode: episode.mal_id,
|
||||
name: episode.title,
|
||||
score: episode.score,
|
||||
uploadedBy: SystemAccountId,
|
||||
}),
|
||||
);
|
||||
});
|
||||
return episodeData;
|
||||
} catch (err) {
|
||||
ErrorForwarder(err);
|
||||
}
|
||||
const constructedInput = episodeData.data.map(c => ({
|
||||
media_id: mediaData.id,
|
||||
episode_number: c.mal_id,
|
||||
title: c.title,
|
||||
title_romanji: c.title_romanji,
|
||||
title_origin: c.title_japanese,
|
||||
aired_at: c.aired,
|
||||
score: c.score,
|
||||
filler: c.filler,
|
||||
recap: c.recap,
|
||||
forum_url: c.forum_url,
|
||||
created_by_id: SystemAccountId
|
||||
}))
|
||||
const insertedEpisodes = await bulkInsertEpisodesRepository(constructedInput)
|
||||
return episodeData;
|
||||
} catch (err) {
|
||||
ErrorForwarder(err);
|
||||
}
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user