summaryrefslogtreecommitdiff
path: root/src/server/api/common/generate-block-query.ts
blob: fa2179ae64e41cccaa86d3435dd76129639dd61a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import { User } from '../../../models/entities/user';
import { Blockings } from '../../../models';
import { SelectQueryBuilder } from 'typeorm';

export function generateBlockQueryForUsers(q: SelectQueryBuilder<any>, me: { id: User['id'] }) {
	const blockingQuery = Blockings.createQueryBuilder('blocking')
		.select('blocking.blockeeId')
		.where('blocking.blockerId = :blockerId', { blockerId: me.id });

	const blockedQuery = Blockings.createQueryBuilder('blocking')
		.select('blocking.blockerId')
		.where('blocking.blockeeId = :blockeeId', { blockeeId: me.id });

	q.andWhere(`user.id NOT IN (${ blockingQuery.getQuery() })`);
	q.setParameters(blockingQuery.getParameters());

	q.andWhere(`user.id NOT IN (${ blockedQuery.getQuery() })`);
	q.setParameters(blockedQuery.getParameters());
}