summaryrefslogtreecommitdiff
path: root/src/server/api/common/generate-muted-note-thread-query.ts
blob: 7e2cbd498b8602946be478cf6d4a518dbf5b15ef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import { User } from '@/models/entities/user';
import { NoteThreadMutings } from '@/models/index';
import { Brackets, SelectQueryBuilder } from 'typeorm';

export function generateMutedNoteThreadQuery(q: SelectQueryBuilder<any>, me: { id: User['id'] }) {
	const mutedQuery = NoteThreadMutings.createQueryBuilder('threadMuted')
		.select('threadMuted.threadId')
		.where('threadMuted.userId = :userId', { userId: me.id });

	q.andWhere(`note.id NOT IN (${ mutedQuery.getQuery() })`);
	q.andWhere(new Brackets(qb => { qb
		.where(`note.threadId IS NULL`)
		.orWhere(`note.threadId NOT IN (${ mutedQuery.getQuery() })`);
	}));

	q.setParameters(mutedQuery.getParameters());
}