diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2023-10-15 10:36:22 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-10-15 10:36:22 +0900 |
| commit | 3f4ee9840560d8c423111f1ab93b2e36218a1314 (patch) | |
| tree | a133afad107362fea5ac00ec8e30704d62a357b9 /packages/backend/src/server/api/stream/channels/local-timeline.ts | |
| parent | perf(backend): tweak populateMyReaction (diff) | |
| download | misskey-3f4ee9840560d8c423111f1ab93b2e36218a1314.tar.gz misskey-3f4ee9840560d8c423111f1ab93b2e36218a1314.tar.bz2 misskey-3f4ee9840560d8c423111f1ab93b2e36218a1314.zip | |
perf(backend): improve streaming api performance (#12033)
* wip
* Update NoteEntityService.ts
* wip
* wip
* wip
* wip
Diffstat (limited to 'packages/backend/src/server/api/stream/channels/local-timeline.ts')
| -rw-r--r-- | packages/backend/src/server/api/stream/channels/local-timeline.ts | 18 |
1 files changed, 5 insertions, 13 deletions
diff --git a/packages/backend/src/server/api/stream/channels/local-timeline.ts b/packages/backend/src/server/api/stream/channels/local-timeline.ts index 69aa366f00..a211041134 100644 --- a/packages/backend/src/server/api/stream/channels/local-timeline.ts +++ b/packages/backend/src/server/api/stream/channels/local-timeline.ts @@ -54,19 +54,6 @@ class LocalTimelineChannel extends Channel { if (note.visibility !== 'public') return; if (note.channelId != null && !this.followingChannels.has(note.channelId)) return; - // リプライなら再pack - if (note.replyId != null) { - note.reply = await this.noteEntityService.pack(note.replyId, this.user, { - detail: true, - }); - } - // Renoteなら再pack - if (note.renoteId != null) { - note.renote = await this.noteEntityService.pack(note.renoteId, this.user, { - detail: true, - }); - } - // 関係ない返信は除外 if (note.reply && this.user && !this.following[note.userId]?.withReplies && !this.withReplies) { const reply = note.reply; @@ -83,6 +70,11 @@ class LocalTimelineChannel extends Channel { if (note.renote && !note.text && isUserRelated(note, this.userIdsWhoMeMutingRenotes)) return; + if (this.user && note.renoteId && !note.text) { + const myRenoteReaction = await this.noteEntityService.populateMyReaction(note.renoteId, this.user.id); + note.renote!.myReaction = myRenoteReaction; + } + this.connection.cacheNote(note); this.send('note', note); |