summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/notes/local-timeline.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2020-02-13 22:13:24 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2020-02-13 22:13:24 +0900
commitd76fceae855385ee2a9394ab69058efab169eab1 (patch)
tree6b97d7502ed3e660b8260b97e5608a9b5d782bfa /src/server/api/endpoints/notes/local-timeline.ts
parent:art: (diff)
downloadsharkey-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.ts12
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);