iceshrimp-legacy/packages/backend/src/queue/processors/db/import-posts.ts

77 lines
1.9 KiB
TypeScript
Raw Normal View History

2023-03-28 23:48:27 +02:00
import { downloadTextFile } from "@/misc/download-text-file.js";
2023-07-16 05:02:00 +02:00
import { processMastoNotes } from "@/misc/process-masto-notes.js";
2023-03-28 23:48:27 +02:00
import { Users, DriveFiles } from "@/models/index.js";
2023-03-30 17:31:29 +02:00
import type { DbUserImportPostsJobData } from "@/queue/types.js";
2023-03-28 23:48:27 +02:00
import { queueLogger } from "../../logger.js";
import type Bull from "bull";
2023-05-15 00:20:26 +02:00
import {
createImportCkPostJob,
createImportMastoPostJob,
} from "@/queue/index.js";
2023-03-28 23:48:27 +02:00
const logger = queueLogger.createSubLogger("import-posts");
export async function importPosts(
2023-03-30 17:31:29 +02:00
job: Bull.Job<DbUserImportPostsJobData>,
2023-03-28 23:48:27 +02:00
done: any,
): Promise<void> {
2023-03-29 19:23:37 +02:00
logger.info(`Importing posts of ${job.data.user.id} ...`);
2023-03-28 23:48:27 +02:00
const user = await Users.findOneBy({ id: job.data.user.id });
if (user == null) {
done();
return;
}
const file = await DriveFiles.findOneBy({
id: job.data.fileId,
});
if (file == null) {
done();
return;
}
2023-07-16 12:24:37 +02:00
if (file.name.endsWith("tar.gz") || file.name.endsWith("zip")) {
2023-07-16 05:02:00 +02:00
try {
2023-07-16 09:24:37 +02:00
logger.info("Reading Mastodon archive");
2023-07-16 12:24:37 +02:00
const outbox = await processMastoNotes(
file.name,
file.url,
job.data.user.id,
);
2023-07-16 05:02:00 +02:00
for (const post of outbox.orderedItems) {
createImportMastoPostJob(job.data.user, post, job.data.signatureCheck);
}
} catch (e) {
// handle error
2023-07-16 09:24:37 +02:00
logger.warn(`Failed reading Mastodon archive: ${e}`);
2023-07-16 05:02:00 +02:00
}
2023-07-16 09:24:37 +02:00
logger.succ("Mastodon archive imported");
2023-07-16 05:02:00 +02:00
done();
return;
}
2023-03-29 19:36:23 +02:00
const json = await downloadTextFile(file.url);
2023-03-28 23:48:27 +02:00
2023-03-29 19:36:23 +02:00
try {
2023-03-29 21:10:01 +02:00
const parsed = JSON.parse(json);
if (parsed instanceof Array) {
2023-03-29 21:16:45 +02:00
logger.info("Parsing key style posts");
2023-03-29 21:10:01 +02:00
for (const post of JSON.parse(json)) {
2023-05-14 18:46:48 +02:00
createImportCkPostJob(job.data.user, post, job.data.signatureCheck);
2023-03-29 21:10:01 +02:00
}
2023-03-29 21:16:45 +02:00
} else if (parsed instanceof Object) {
logger.info("Parsing animal style posts");
2023-03-29 21:10:01 +02:00
for (const post of parsed.orderedItems) {
2023-05-14 18:46:48 +02:00
createImportMastoPostJob(job.data.user, post, job.data.signatureCheck);
2023-03-28 23:48:27 +02:00
}
}
2023-03-29 19:36:23 +02:00
} catch (e) {
// handle error
logger.warn(`Error reading: ${e}`);
2023-03-28 23:48:27 +02:00
}
logger.succ("Imported");
done();
}