2023-01-13 05:40:33 +01:00
|
|
|
import type { User } from "@/models/entities/user.js";
|
|
|
|
import { Blockings } from "@/models/index.js";
|
|
|
|
import type { SelectQueryBuilder } from "typeorm";
|
|
|
|
import { Brackets } from "typeorm";
|
2021-08-17 14:48:59 +02:00
|
|
|
|
|
|
|
// ここでいうBlockedは被Blockedの意
|
2023-01-13 05:40:33 +01:00
|
|
|
export function generateBlockedUserQuery(
|
|
|
|
q: SelectQueryBuilder<any>,
|
|
|
|
me: { id: User["id"] },
|
|
|
|
) {
|
|
|
|
const blockingQuery = Blockings.createQueryBuilder("blocking")
|
|
|
|
.select("blocking.blockerId")
|
|
|
|
.where("blocking.blockeeId = :blockeeId", { blockeeId: me.id });
|
2021-08-17 14:48:59 +02:00
|
|
|
|
|
|
|
// 投稿の作者にブロックされていない かつ
|
|
|
|
// 投稿の返信先の作者にブロックされていない かつ
|
|
|
|
// 投稿の引用元の作者にブロックされていない
|
2023-01-13 05:40:33 +01:00
|
|
|
q.andWhere(`note.userId NOT IN (${blockingQuery.getQuery()})`)
|
|
|
|
.andWhere(
|
|
|
|
new Brackets((qb) => {
|
|
|
|
qb.where("note.replyUserId IS NULL").orWhere(
|
|
|
|
`note.replyUserId NOT IN (${blockingQuery.getQuery()})`,
|
|
|
|
);
|
|
|
|
}),
|
|
|
|
)
|
|
|
|
.andWhere(
|
|
|
|
new Brackets((qb) => {
|
|
|
|
qb.where("note.renoteUserId IS NULL").orWhere(
|
|
|
|
`note.renoteUserId NOT IN (${blockingQuery.getQuery()})`,
|
|
|
|
);
|
|
|
|
}),
|
|
|
|
);
|
2021-08-17 14:48:59 +02:00
|
|
|
|
|
|
|
q.setParameters(blockingQuery.getParameters());
|
|
|
|
}
|
2019-07-21 15:27:36 +02:00
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
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 });
|
2019-07-21 15:27:36 +02:00
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
const blockedQuery = Blockings.createQueryBuilder("blocking")
|
|
|
|
.select("blocking.blockerId")
|
|
|
|
.where("blocking.blockeeId = :blockeeId", { blockeeId: me.id });
|
2019-07-21 15:27:36 +02:00
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
q.andWhere(`user.id NOT IN (${blockingQuery.getQuery()})`);
|
2019-07-21 15:27:36 +02:00
|
|
|
q.setParameters(blockingQuery.getParameters());
|
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
q.andWhere(`user.id NOT IN (${blockedQuery.getQuery()})`);
|
2019-07-21 15:27:36 +02:00
|
|
|
q.setParameters(blockedQuery.getParameters());
|
|
|
|
}
|