mirror of
https://codeberg.org/yeentown/barkey.git
synced 2025-07-08 04:54:32 +00:00
fetch followings asynchronously in bubble-timeline.ts
This commit is contained in:
parent
7f0a705612
commit
51d9b1c8c5
1 changed files with 14 additions and 11 deletions
|
@ -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(() => {
|
||||||
|
|
Loading…
Add table
Reference in a new issue