mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 08:36:12 +01:00
fix: removal of topics from applicable user inboxes when synced
re: #12642
This commit is contained in:
@@ -292,8 +292,13 @@ Notes.syncUserInboxes = async function (tid, uid) {
|
||||
const keys = Array.from(uids).map(uid => `uid:${uid}:inbox`);
|
||||
const score = await db.sortedSetScore(`cid:${cid}:tids`, tid);
|
||||
|
||||
const removeKeys = (await db.getSetMembers(`tid:${tid}:recipients`))
|
||||
.filter(uid => !uids.has(parseInt(uid, 10)))
|
||||
.map((uid => `uid:${uid}:inbox`));
|
||||
|
||||
// winston.verbose(`[activitypub/syncUserInboxes] Syncing tid ${tid} with ${uids.size} inboxes`);
|
||||
await Promise.all([
|
||||
db.sortedSetsRemove(removeKeys, tid),
|
||||
db.sortedSetsAdd(keys, keys.map(() => score || Date.now()), tid),
|
||||
db.setAdd(`tid:${tid}:recipients`, Array.from(uids)),
|
||||
]);
|
||||
@@ -371,10 +376,14 @@ Notes.delete = async (pids) => {
|
||||
const exists = await posts.exists(pids);
|
||||
pids = pids.filter((_, idx) => exists[idx]);
|
||||
|
||||
let tids = await posts.getPostsFields(pids, ['tid']);
|
||||
tids = new Set(tids.map(obj => obj.tid));
|
||||
|
||||
const recipientSets = pids.map(id => `post:${id}:recipients`);
|
||||
const announcerSets = pids.map(id => `pid:${id}:announces`);
|
||||
|
||||
await db.deleteAll([...recipientSets, ...announcerSets]);
|
||||
await Promise.all(Array.from(tids).map(async tid => Notes.syncUserInboxes(tid)));
|
||||
};
|
||||
|
||||
Notes.prune = async () => {
|
||||
|
||||
@@ -69,6 +69,14 @@ describe('Notes', () => {
|
||||
|
||||
assert.strictEqual(inboxed, true);
|
||||
});
|
||||
|
||||
it('should remove a topic from a user\'s inbox if that user is no longer a recipient in any contained posts', async () => {
|
||||
await activitypub.notes.syncUserInboxes(topicData.tid, uid);
|
||||
await activitypub.notes.syncUserInboxes(topicData.tid);
|
||||
const inboxed = await db.isSortedSetMember(`uid:${uid}:inbox`, topicData.tid);
|
||||
|
||||
assert.strictEqual(inboxed, false);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Deletion', () => {
|
||||
|
||||
Reference in New Issue
Block a user