mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-02 12:47:41 +02:00
Server: Fixed sharing issue when a user no longer has a user item associated with their account
This commit is contained in:
parent
c5b551bbcb
commit
293f621e46
@ -219,7 +219,15 @@ export default class ShareModel extends BaseModel<Share> {
|
||||
const shareUserIds = await this.allShareUserIds(previousShare);
|
||||
for (const shareUserId of shareUserIds) {
|
||||
if (shareUserId === change.user_id) continue;
|
||||
await removeUserItem(shareUserId, item.id);
|
||||
try {
|
||||
await removeUserItem(shareUserId, item.id);
|
||||
} catch (error) {
|
||||
if (error.httpCode === ErrorNotFound.httpCode) {
|
||||
logger.warn('Could not remove a user item because it has already been removed:', error);
|
||||
} else {
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -82,10 +82,10 @@ export default class UserItemModel extends BaseModel<UserItem> {
|
||||
.where('user_items.user_id', '=', userId);
|
||||
}
|
||||
|
||||
public async deleteByUserItem(userId: Uuid, itemId: Uuid): Promise<void> {
|
||||
public async deleteByUserItem(userId: Uuid, itemId: Uuid, options: UserItemDeleteOptions = null): Promise<void> {
|
||||
const userItem = await this.byUserAndItemId(userId, itemId);
|
||||
if (!userItem) throw new ErrorNotFound(`No such user_item: ${userId} / ${itemId}`);
|
||||
await this.deleteBy({ byUserItem: userItem });
|
||||
await this.deleteBy({ ...options, byUserItem: userItem });
|
||||
}
|
||||
|
||||
public async deleteByItemIds(itemIds: Uuid[], options: UserItemDeleteOptions = null): Promise<void> {
|
||||
|
@ -414,6 +414,43 @@ describe('shares.folder', function() {
|
||||
await expectNotThrow(async () => await models().share().updateSharedItems3());
|
||||
});
|
||||
|
||||
test('should not throw an error if a user no longer has a user item, and the target share changes', async function() {
|
||||
const { user: user1, session: session1 } = await createUserAndSession(1);
|
||||
const { user: user2, session: session2 } = await createUserAndSession(2);
|
||||
|
||||
await shareFolderWithUser(session1.id, session2.id, '000000000000000000000000000000F1', [
|
||||
{
|
||||
id: '000000000000000000000000000000F1',
|
||||
children: [
|
||||
{
|
||||
id: '00000000000000000000000000000001',
|
||||
},
|
||||
],
|
||||
},
|
||||
]);
|
||||
|
||||
const { share: share2 } = await shareFolderWithUser(session1.id, session2.id, '000000000000000000000000000000F5', [
|
||||
{
|
||||
id: '000000000000000000000000000000F5',
|
||||
children: [],
|
||||
},
|
||||
]);
|
||||
|
||||
const noteItem = await models().item().loadByJopId(user1.id, '00000000000000000000000000000001');
|
||||
|
||||
// Note is moved from a shared folder to a different shared folder
|
||||
|
||||
await models().item().saveForUser(user1.id, {
|
||||
id: noteItem.id,
|
||||
jop_parent_id: '000000000000000000000000000000F5',
|
||||
jop_share_id: share2.id,
|
||||
});
|
||||
|
||||
await models().userItem().deleteByUserItem(user2.id, noteItem.id, { recordChanges: false });
|
||||
|
||||
await expectNotThrow(async () => await models().share().updateSharedItems3());
|
||||
});
|
||||
|
||||
test('should unshare a deleted item', async function() {
|
||||
const { user: user1, session: session1 } = await createUserAndSession(1);
|
||||
const { user: user2, session: session2 } = await createUserAndSession(2);
|
||||
|
Loading…
Reference in New Issue
Block a user