summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/common/generate-muted-instance-query.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api/common/generate-muted-instance-query.ts')
-rw-r--r--packages/backend/src/server/api/common/generate-muted-instance-query.ts40
1 files changed, 40 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/common/generate-muted-instance-query.ts b/packages/backend/src/server/api/common/generate-muted-instance-query.ts
new file mode 100644
index 0000000000..dbc9fc98f1
--- /dev/null
+++ b/packages/backend/src/server/api/common/generate-muted-instance-query.ts
@@ -0,0 +1,40 @@
+import { User } from '@/models/entities/user';
+import { id } from '@/models/id';
+import { UserProfiles } from '@/models/index';
+import { SelectQueryBuilder, Brackets } from 'typeorm';
+
+function createMutesQuery(id: string) {
+ return UserProfiles.createQueryBuilder('user_profile')
+ .select('user_profile.mutedInstances')
+ .where('user_profile.userId = :muterId', { muterId: id });
+}
+
+export function generateMutedInstanceQuery(q: SelectQueryBuilder<any>, me: { id: User['id'] }) {
+ const mutingQuery = createMutesQuery(me.id);
+
+ q
+ .andWhere(new Brackets(qb => { qb
+ .andWhere('note.userHost IS NULL')
+ .orWhere(`NOT((${ mutingQuery.getQuery() })::jsonb ? note.userHost)`);
+ }))
+ .andWhere(new Brackets(qb => { qb
+ .where(`note.replyUserHost IS NULL`)
+ .orWhere(`NOT ((${ mutingQuery.getQuery() })::jsonb ? note.replyUserHost)`);
+ }))
+ .andWhere(new Brackets(qb => { qb
+ .where(`note.renoteUserHost IS NULL`)
+ .orWhere(`NOT ((${ mutingQuery.getQuery() })::jsonb ? note.renoteUserHost)`);
+ }));
+ q.setParameters(mutingQuery.getParameters());
+}
+
+export function generateMutedInstanceNotificationQuery(q: SelectQueryBuilder<any>, me: { id: User['id'] }) {
+ const mutingQuery = createMutesQuery(me.id);
+
+ q.andWhere(new Brackets(qb => { qb
+ .andWhere('notifier.host IS NULL')
+ .orWhere(`NOT (( ${mutingQuery.getQuery()} )::jsonb ? notifier.host)`);
+ }));
+
+ q.setParameters(mutingQuery.getParameters());
+}