Load relationships to populate user fields

This commit is contained in:
PrivateGER 2023-05-26 02:07:34 +02:00 committed by PrivateGER
parent e23ca84925
commit f5aa0c86cf
2 changed files with 19 additions and 8 deletions

View file

@ -1,9 +1,12 @@
import {Health, MeiliSearch, Stats } from 'meilisearch';
import { dbLogger } from "./logger.js";
import {Health, MeiliSearch, Stats} from 'meilisearch';
import {dbLogger} from "./logger.js";
import config from "@/config/index.js";
import {Note} from "@/models/entities/note.js";
import * as url from "url";
import {User} from "@/models/entities/user.js";
import {Users} from "@/models/index.js";
const logger = dbLogger.createSubLogger("meilisearch", "gray", false);
@ -98,14 +101,21 @@ export default hasConfig ? {
filter: constructedFilters
});
},
ingestNote: (note: Note | Note[]) => {
if (note instanceof Note) {
note = [note];
ingestNote: async (ingestNotes: Note | Note[]) => {
if (ingestNotes instanceof Note) {
ingestNotes = [ingestNotes];
}
let indexingBatch: MeilisearchNote[] = [];
note.forEach(note => {
for (let note of ingestNotes) {
if (note.user === undefined) {
let user = await Users.findOne({
where: {
id: note.userId
}
});
}
let attachmentType = "";
if (note.attachedFileTypes.length > 0) {
@ -129,11 +139,11 @@ export default hasConfig ? {
userHost: note.userHost !== "" ? note.userHost : url.parse(config.host).host,
channelId: note.channelId ? note.channelId : "",
mediaAttachment: attachmentType,
userName: note.user?.usernameLower ?? "UNKNOWN",
userName: note.user?.username ?? "UNKNOWN",
createdAt: note.createdAt.getTime() / 1000 // division by 1000 is necessary because Node returns in ms-accuracy
}
)
});
}
let indexingIDs = indexingBatch.map(note => note.id);

View file

@ -39,6 +39,7 @@ export default async function indexAllNotes(
order: {
id: 1,
},
relations: ["user"]
});
} catch (e) {
logger.error(`Failed to query notes ${e}`);