fix: visibility

This commit is contained in:
Namekuji 2023-09-19 16:24:38 -04:00
parent 8fd4773260
commit f6980ca040
No known key found for this signature in database
GPG key ID: 1D62332C07FBA532
2 changed files with 51 additions and 31 deletions

View file

@ -163,8 +163,8 @@ export default define(meta, paramDef, async (ps, user) => {
user.id,
30,
)) as ScyllaNotification[]
).slice(0, ps.limit);
return await Notifications.packMany(foundNotifications, user.id);
);
return (await Notifications.packMany(foundNotifications, user.id)).slice(0, ps.limit);
}
const followingQuery = Followings.createQueryBuilder("following")

View file

@ -17,8 +17,10 @@ import {
scyllaClient,
} from "@/db/scylla.js";
import {
ChannelFollowingsCache,
InstanceMutingsCache,
LocalFollowingsCache,
RenoteMutingsCache,
UserBlockedCache,
UserBlockingCache,
UserMutingsCache,
@ -84,28 +86,44 @@ export default define(meta, paramDef, async (ps, me) => {
});
if (scyllaClient) {
const [
let [
followingChannelIds,
followingUserIds,
mutedUserIds,
mutedInstances,
blockerIds,
blockingIds,
renoteMutedIds,
]: string[][] = [];
let mutedWords: string[][];
if (me) {
[
followingChannelIds,
followingUserIds,
mutedUserIds,
mutedInstances,
mutedWords,
blockerIds,
blockingIds,
renoteMutedIds,
] = await Promise.all([
LocalFollowingsCache.init(user.id).then((cache) => cache.getAll()),
UserMutingsCache.init(user.id).then((cache) => cache.getAll()),
InstanceMutingsCache.init(user.id).then((cache) => cache.getAll()),
ChannelFollowingsCache.init(me.id).then((cache) => cache.getAll()),
LocalFollowingsCache.init(me.id).then((cache) => cache.getAll()),
UserMutingsCache.init(me.id).then((cache) => cache.getAll()),
InstanceMutingsCache.init(me.id).then((cache) => cache.getAll()),
userWordMuteCache
.fetchMaybe(user.id, () =>
.fetchMaybe(me.id, () =>
UserProfiles.findOne({
select: ["mutedWords"],
where: { userId: user.id },
}).then((profile) => profile?.mutedWords),
)
.then((words) => words ?? []),
UserBlockedCache.init(user.id).then((cache) => cache.getAll()),
UserBlockingCache.init(user.id).then((cache) => cache.getAll()),
UserBlockedCache.init(me.id).then((cache) => cache.getAll()),
UserBlockingCache.init(me.id).then((cache) => cache.getAll()),
RenoteMutingsCache.init(me.id).then((cache) => cache.getAll()),
]);
}
if (
mutedUserIds.includes(user.id) ||
@ -117,18 +135,20 @@ export default define(meta, paramDef, async (ps, me) => {
const filter = async (notes: ScyllaNote[]) => {
let filtered = notes.filter((n) => n.userId === ps.userId);
filtered = await filterVisibility(filtered, user, followingUserIds);
filtered = await filterVisibility(filtered, me, followingUserIds);
if (me) {
filtered = await filterMutedUser(
filtered,
user,
me,
mutedUserIds,
mutedInstances,
);
filtered = await filterMutedNote(filtered, user, mutedWords);
filtered = await filterBlockUser(filtered, user, [
filtered = await filterMutedNote(filtered, me, mutedWords);
filtered = await filterBlockUser(filtered, me, [
...blockerIds,
...blockingIds,
]);
}
if (ps.withFiles) {
filtered = filtered.filter((n) => n.files.length > 0);
}