diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2020-02-13 22:13:24 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2020-02-13 22:13:24 +0900 |
| commit | d76fceae855385ee2a9394ab69058efab169eab1 (patch) | |
| tree | 6b97d7502ed3e660b8260b97e5608a9b5d782bfa /src/server/api/endpoints/notes/local-timeline.ts | |
| parent | :art: (diff) | |
| download | sharkey-d76fceae855385ee2a9394ab69058efab169eab1.tar.gz sharkey-d76fceae855385ee2a9394ab69058efab169eab1.tar.bz2 sharkey-d76fceae855385ee2a9394ab69058efab169eab1.zip | |
Fix #5935
Diffstat (limited to 'src/server/api/endpoints/notes/local-timeline.ts')
| -rw-r--r-- | src/server/api/endpoints/notes/local-timeline.ts | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/server/api/endpoints/notes/local-timeline.ts b/src/server/api/endpoints/notes/local-timeline.ts index 9fae40ecb6..71ebceb0ec 100644 --- a/src/server/api/endpoints/notes/local-timeline.ts +++ b/src/server/api/endpoints/notes/local-timeline.ts @@ -93,6 +93,18 @@ export default define(meta, async (ps, user) => { const query = makePaginationQuery(Notes.createQueryBuilder('note'), ps.sinceId, ps.untilId, ps.sinceDate, ps.untilDate) .andWhere('(note.visibility = \'public\') AND (note.userHost IS NULL)') + .andWhere(new Brackets(qb => { qb + .where(`note.replyId IS NULL`) // 返信ではない + .orWhere('note.replyUserId = :meId', { meId: user.id }) // 返信だけど自分のノートへの返信 + .orWhere(new Brackets(qb => { qb // 返信だけど自分の行った返信 + .where(`note.replyId IS NOT NULL`) + .andWhere('note.userId = :meId', { meId: user.id }); + })) + .orWhere(new Brackets(qb => { qb // 返信だけど投稿者自身への返信 + .where(`note.replyId IS NOT NULL`) + .andWhere('note.replyUserId = note.userId', { meId: user.id }); + })); + })) .leftJoinAndSelect('note.user', 'user'); generateVisibilityQuery(query, user); |