파일 업로드 로직 리팩토링 2

This commit is contained in:
static
2026-01-12 16:58:28 +09:00
parent e7dc96bb47
commit c778a4fb9e
5 changed files with 129 additions and 117 deletions

View File

@@ -18,7 +18,7 @@
info,
state: getMigrationState(info.id),
}))
.filter((file) => file.state?.status !== "completed"),
.filter((file) => file.state?.status !== "uploaded"),
);
const migrateAllFiles = () => {

View File

@@ -1,12 +1,9 @@
<script module lang="ts">
const subtexts = {
queued: "대기 중",
"download-pending": "다운로드를 기다리는 중",
downloading: "다운로드하는 중",
"encryption-pending": "암호화를 기다리는 중",
encrypting: "암호화하는 중",
"upload-pending": "업로드를 기다리는 중",
completed: "완료",
uploaded: "",
error: "실패",
} as const;
</script>

View File

@@ -9,13 +9,10 @@ import { trpc } from "$trpc/client";
export type MigrationStatus =
| "queued"
| "download-pending"
| "downloading"
| "encryption-pending"
| "encrypting"
| "upload-pending"
| "uploading"
| "completed"
| "uploaded"
| "error";
export interface MigrationState {
@@ -38,13 +35,13 @@ export const getMigrationState = (fileId: number) => {
export const clearMigrationStates = () => {
for (const [id, state] of states) {
if (state.status === "completed" || state.status === "error") {
if (state.status === "uploaded" || state.status === "error") {
states.delete(id);
}
}
};
const uploadMigrationChunks = limitFunction(
const requestFileUpload = limitFunction(
async (state: MigrationState, fileId: number, fileBuffer: ArrayBuffer, dataKey: CryptoKey) => {
state.status = "uploading";
@@ -61,6 +58,7 @@ const uploadMigrationChunks = limitFunction(
});
await trpc().upload.completeMigrationUpload.mutate({ uploadId });
state.status = "uploaded";
},
{ concurrency: 1 },
);
@@ -87,18 +85,11 @@ export const requestFileMigration = async (fileInfo: FileInfo) => {
await scheduler.schedule(
async () => {
state.status = "download-pending";
state.status = "downloading";
fileBuffer = await requestFileDownload(fileInfo.id, dataKey, true);
return fileBuffer.byteLength;
},
async () => {
state.status = "encryption-pending";
await uploadMigrationChunks(state, fileInfo.id, fileBuffer!, dataKey);
state.status = "completed";
},
() => requestFileUpload(state, fileInfo.id, fileBuffer!, dataKey),
);
} catch (e) {
state.status = "error";

View File

@@ -35,7 +35,7 @@ const generateThumbnail = limitFunction(
async (fileId: number, fileBuffer: ArrayBuffer, fileType: string, dataKey: CryptoKey) => {
statuses.set(fileId, "generating");
const thumbnail = await doGenerateThumbnail(fileBuffer, fileType);
const thumbnail = await doGenerateThumbnail(new Blob([fileBuffer], { type: fileType }));
if (!thumbnail) return null;
const thumbnailBuffer = await thumbnail.arrayBuffer();