fetch followings asynchronously in bubble-timeline.ts

This commit is contained in:
Hazelnoot 2025-06-02 17:34:35 -04:00
parent 7f0a705612
commit 51d9b1c8c5

View file

@ -76,7 +76,9 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
throw new ApiError(meta.errors.btlDisabled); throw new ApiError(meta.errors.btlDisabled);
} }
const followings = me ? await this.cacheService.userFollowingsCache.fetch(me.id) : undefined; // Run this asynchronously - we will await it after the query completes.
// Catch-suppression is needed to avoid "unhandled rejection" if the query throws.
const followingsPromise = me ? this.cacheService.userFollowingsCache.fetch(me.id).catch(() => null) : null;
//#region Construct query //#region Construct query
const query = this.queryService.makePaginationQuery(this.notesRepository.createQueryBuilder('note'), const query = this.queryService.makePaginationQuery(this.notesRepository.createQueryBuilder('note'),
@ -122,16 +124,17 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
let timeline = await query.limit(ps.limit).getMany(); let timeline = await query.limit(ps.limit).getMany();
const followings = await followingsPromise;
if (me && followings) {
timeline = timeline.filter(note => { timeline = timeline.filter(note => {
if (note.user?.isSilenced) { // Allow my own notes
if (!me) return false; if (note.userId === me.id) return true;
if (!followings) return false; // Allow if not silenced
if (note.userId !== me.id) { if (!note.user?.isSilenced) return true;
// Allow if following
return followings[note.userId]; return followings[note.userId];
}
}
return true;
}); });
}
if (me) { if (me) {
process.nextTick(() => { process.nextTick(() => {