Skip to content

Commit

Permalink
🐛 Fix files notifications on shared folder (#369)
Browse files Browse the repository at this point in the history
  • Loading branch information
MontaGhanmy authored Feb 27, 2024
1 parent e1f10b7 commit ff74104
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 12 deletions.
20 changes: 9 additions & 11 deletions tdrive/backend/node/src/services/documents/services/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -369,19 +369,17 @@ export class DocumentsService {
)
: [];

if (sharedWith.length > 0) {
// Notify the user that the document has been shared with them
this.logger.info("Notifying users that the document has been shared with them: ", {
if (context.user.id !== parentItem?.creator && sharedWith.length > 0) {
// Notify the owner that the document has been shared with them
this.logger.info("Notifying the onwer that the document has been shared with them: ", {
sharedWith,
});
for (const info of sharedWith) {
gr.services.documents.engine.notifyDocumentShared({
context,
item: driveItem,
notificationEmitter: context.user.id,
notificationReceiver: info.id,
});
}
gr.services.documents.engine.notifyDocumentShared({
context,
item: driveItem,
notificationEmitter: context.user.id,
notificationReceiver: parentItem.creator,
});
}
}
} catch (error) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@ describe("the Drive feature", () => {
platform = null;
});


it("Did notify the user after sharing a file.", async () => {
// jest.setTimeout(20000);
//given:: user uploaded one doc and give permission to another user
Expand Down Expand Up @@ -86,4 +85,45 @@ describe("the Drive feature", () => {

expect(notifyDocumentVersionUpdated).toHaveBeenCalled();
});

it("Did notify the owner after a user uploaded a file to a shared directory.", async () => {
const oneUser = await UserApi.getInstance(platform, true, { companyRole: "admin" });
const anotherUser = await UserApi.getInstance(platform, true, { companyRole: "admin" });
const thridUser = await UserApi.getInstance(platform, true, { companyRole: "admin" });

const directory = await oneUser.createDirectory();
directory.access_info.entities.push({
type: "user",
id: anotherUser.user.id,
level: "write",
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
grantor: null,
});

directory.access_info.entities.push({
type: "user",
id: thridUser.user.id,
level: "write",
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
grantor: null,
});

await anotherUser.uploadRandomFileAndCreateDocument(directory.id);
// expect the owner to be notified
expect(notifyDocumentShared).toHaveBeenCalledWith(
expect.objectContaining({
notificationEmitter: anotherUser.user.id,
notificationReceiver: oneUser.user.id,
}),
);
// expect only one notification went through (the owner only notified)
expect(notifyDocumentShared).not.toHaveBeenCalledWith(
expect.objectContaining({
notificationEmitter: oneUser.user.id,
notificationReceiver: thridUser.user.id,
}),
);
});
});

0 comments on commit ff74104

Please sign in to comment.