@sync-in/server 1.8.1 → 1.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +57 -11
- package/environment/environment.dist.yaml +29 -26
- package/package.json +15 -15
- package/server/app.constants.js +9 -0
- package/server/app.constants.js.map +1 -1
- package/server/app.functions.js +42 -0
- package/server/app.functions.js.map +1 -0
- package/server/app.module.js +4 -0
- package/server/app.module.js.map +1 -1
- package/server/applications/admin/admin.module.js +6 -1
- package/server/applications/admin/admin.module.js.map +1 -1
- package/server/applications/{notifications/interfaces/user-mail-notification.js → admin/interfaces/check-update.interfaces.js} +1 -1
- package/server/applications/admin/interfaces/check-update.interfaces.js.map +1 -0
- package/server/applications/admin/services/admin-scheduler.service.js +53 -0
- package/server/applications/admin/services/admin-scheduler.service.js.map +1 -0
- package/server/applications/admin/services/admin.service.js +102 -0
- package/server/applications/admin/services/admin.service.js.map +1 -0
- package/server/applications/admin/services/admin.service.spec.js +46 -0
- package/server/applications/admin/services/admin.service.spec.js.map +1 -0
- package/server/applications/admin/utils/check-update.js +28 -0
- package/server/applications/admin/utils/check-update.js.map +1 -0
- package/server/applications/comments/services/comments-manager.service.js +1 -1
- package/server/applications/comments/services/comments-manager.service.js.map +1 -1
- package/server/applications/comments/services/comments-manager.service.spec.js +1 -1
- package/server/applications/comments/services/comments-manager.service.spec.js.map +1 -1
- package/server/applications/comments/services/comments-queries.service.js.map +1 -1
- package/server/applications/files/constants/cache.js +10 -1
- package/server/applications/files/constants/cache.js.map +1 -1
- package/server/applications/files/constants/only-office.js +0 -25
- package/server/applications/files/constants/only-office.js.map +1 -1
- package/server/applications/files/constants/operations.js +20 -3
- package/server/applications/files/constants/operations.js.map +1 -1
- package/server/applications/files/dto/file-operations.dto.js +7 -0
- package/server/applications/files/dto/file-operations.dto.js.map +1 -1
- package/server/applications/files/files-only-office.controller.js +3 -2
- package/server/applications/files/files-only-office.controller.js.map +1 -1
- package/server/applications/files/files-only-office.controller.spec.js +6 -5
- package/server/applications/files/files-only-office.controller.spec.js.map +1 -1
- package/server/applications/files/files.controller.js +88 -8
- package/server/applications/files/files.controller.js.map +1 -1
- package/server/applications/files/files.controller.spec.js +11 -4
- package/server/applications/files/files.controller.spec.js.map +1 -1
- package/server/applications/files/guards/files-only-office.guard.js +6 -0
- package/server/applications/files/guards/files-only-office.guard.js.map +1 -1
- package/server/applications/files/interfaces/file-db-props.interface.js.map +1 -1
- package/server/applications/files/interfaces/file-props.interface.js.map +1 -1
- package/server/applications/files/interfaces/only-office-config.interface.js.map +1 -1
- package/server/applications/files/services/files-content-manager.service.js +3 -3
- package/server/applications/files/services/files-content-manager.service.js.map +1 -1
- package/server/applications/files/services/files-lock-manager.service.js +61 -22
- package/server/applications/files/services/files-lock-manager.service.js.map +1 -1
- package/server/applications/files/services/files-manager.service.js +122 -24
- package/server/applications/files/services/files-manager.service.js.map +1 -1
- package/server/applications/files/services/files-manager.service.spec.js +15 -0
- package/server/applications/files/services/files-manager.service.spec.js.map +1 -1
- package/server/applications/files/services/files-methods.service.js +38 -8
- package/server/applications/files/services/files-methods.service.js.map +1 -1
- package/server/applications/files/services/files-only-office-manager.service.js +12 -12
- package/server/applications/files/services/files-only-office-manager.service.js.map +1 -1
- package/server/applications/files/services/files-parser.service.js +1 -1
- package/server/applications/files/services/files-parser.service.js.map +1 -1
- package/server/applications/files/services/files-queries.service.js +10 -0
- package/server/applications/files/services/files-queries.service.js.map +1 -1
- package/server/applications/files/utils/files.js +1 -1
- package/server/applications/files/utils/files.js.map +1 -1
- package/server/applications/files/utils/send-file.js +3 -2
- package/server/applications/files/utils/send-file.js.map +1 -1
- package/server/applications/links/services/links-queries.service.js +1 -1
- package/server/applications/links/services/links-queries.service.js.map +1 -1
- package/server/applications/notifications/constants/notifications.js +5 -1
- package/server/applications/notifications/constants/notifications.js.map +1 -1
- package/server/applications/notifications/i18n/de.js +8 -2
- package/server/applications/notifications/i18n/de.js.map +1 -1
- package/server/applications/notifications/i18n/es.js +8 -2
- package/server/applications/notifications/i18n/es.js.map +1 -1
- package/server/applications/notifications/i18n/fr.js +8 -2
- package/server/applications/notifications/i18n/fr.js.map +1 -1
- package/server/applications/notifications/i18n/hi.js +8 -2
- package/server/applications/notifications/i18n/hi.js.map +1 -1
- package/server/applications/notifications/i18n/it.js +8 -2
- package/server/applications/notifications/i18n/it.js.map +1 -1
- package/server/applications/notifications/i18n/ja.js +8 -2
- package/server/applications/notifications/i18n/ja.js.map +1 -1
- package/server/applications/notifications/i18n/ko.js +8 -2
- package/server/applications/notifications/i18n/ko.js.map +1 -1
- package/server/applications/notifications/i18n/pl.js +8 -2
- package/server/applications/notifications/i18n/pl.js.map +1 -1
- package/server/applications/notifications/i18n/pt.js +8 -2
- package/server/applications/notifications/i18n/pt.js.map +1 -1
- package/server/applications/notifications/i18n/pt_br.js +8 -2
- package/server/applications/notifications/i18n/pt_br.js.map +1 -1
- package/server/applications/notifications/i18n/ru.js +8 -2
- package/server/applications/notifications/i18n/ru.js.map +1 -1
- package/server/applications/notifications/i18n/tr.js +8 -2
- package/server/applications/notifications/i18n/tr.js.map +1 -1
- package/server/applications/notifications/i18n/zh.js +8 -2
- package/server/applications/notifications/i18n/zh.js.map +1 -1
- package/server/applications/notifications/interfaces/notification-properties.interface.js.map +1 -1
- package/server/applications/notifications/interfaces/user-mail-notification.interface.js +10 -0
- package/server/applications/notifications/interfaces/user-mail-notification.interface.js.map +1 -0
- package/server/applications/notifications/mails/models.js +38 -3
- package/server/applications/notifications/mails/models.js.map +1 -1
- package/server/applications/notifications/mails/templates.js +1 -1
- package/server/applications/notifications/mails/templates.js.map +1 -1
- package/server/applications/notifications/services/notifications-manager.service.js +8 -1
- package/server/applications/notifications/services/notifications-manager.service.js.map +1 -1
- package/server/applications/notifications/services/notifications-queries.service.js.map +1 -1
- package/server/applications/shares/services/shares-manager.service.js +17 -10
- package/server/applications/shares/services/shares-manager.service.js.map +1 -1
- package/server/applications/shares/services/shares-manager.service.spec.js +10 -3
- package/server/applications/shares/services/shares-manager.service.spec.js.map +1 -1
- package/server/applications/shares/services/shares-queries.service.js +11 -1
- package/server/applications/shares/services/shares-queries.service.js.map +1 -1
- package/server/applications/spaces/guards/space.guard.spec.js +2 -2
- package/server/applications/spaces/guards/space.guard.spec.js.map +1 -1
- package/server/applications/spaces/services/spaces-browser.service.js +31 -11
- package/server/applications/spaces/services/spaces-browser.service.js.map +1 -1
- package/server/applications/spaces/services/spaces-manager.service.js +2 -2
- package/server/applications/spaces/services/spaces-manager.service.js.map +1 -1
- package/server/applications/spaces/services/spaces-queries.service.js +6 -2
- package/server/applications/spaces/services/spaces-queries.service.js.map +1 -1
- package/server/applications/spaces/utils/permissions.js +2 -2
- package/server/applications/spaces/utils/permissions.js.map +1 -1
- package/server/applications/sync/services/sync-manager.service.js +1 -0
- package/server/applications/sync/services/sync-manager.service.js.map +1 -1
- package/server/applications/sync/services/sync-paths-manager.service.js +1 -1
- package/server/applications/sync/services/sync-paths-manager.service.js.map +1 -1
- package/server/applications/sync/services/sync-paths-manager.service.spec.js +1 -1
- package/server/applications/sync/services/sync-paths-manager.service.spec.js.map +1 -1
- package/server/applications/users/constants/user.js +1 -1
- package/server/applications/users/constants/user.js.map +1 -1
- package/server/applications/users/services/admin-users-queries.service.js +8 -0
- package/server/applications/users/services/admin-users-queries.service.js.map +1 -1
- package/server/applications/users/services/users-queries.service.js +67 -68
- package/server/applications/users/services/users-queries.service.js.map +1 -1
- package/server/applications/users/users.module.js +2 -1
- package/server/applications/users/users.module.js.map +1 -1
- package/server/applications/webdav/guards/webdav-protocol.guard.js +4 -4
- package/server/applications/webdav/guards/webdav-protocol.guard.js.map +1 -1
- package/server/applications/webdav/guards/webdav-protocol.guard.spec.js +6 -6
- package/server/applications/webdav/guards/webdav-protocol.guard.spec.js.map +1 -1
- package/server/applications/webdav/services/webdav-methods.service.js +3 -2
- package/server/applications/webdav/services/webdav-methods.service.js.map +1 -1
- package/server/applications/webdav/services/webdav-methods.service.spec.js +2 -2
- package/server/applications/webdav/services/webdav-methods.service.spec.js.map +1 -1
- package/server/authentication/constants/auth-ldap.js +2 -0
- package/server/authentication/constants/auth-ldap.js.map +1 -1
- package/server/authentication/services/auth-methods/auth-method-ldap.service.js +34 -21
- package/server/authentication/services/auth-methods/auth-method-ldap.service.js.map +1 -1
- package/server/common/functions.js +0 -8
- package/server/common/functions.js.map +1 -1
- package/server/common/image.js +1 -0
- package/server/common/image.js.map +1 -1
- package/server/common/shared.js +18 -1
- package/server/common/shared.js.map +1 -1
- package/server/infrastructure/context/services/context-manager.service.js +3 -0
- package/server/infrastructure/context/services/context-manager.service.js.map +1 -1
- package/server/infrastructure/websocket/adapters/cluster.adapter.js +4 -4
- package/server/infrastructure/websocket/adapters/cluster.adapter.js.map +1 -1
- package/static/3rdpartylicenses.txt +1393 -44
- package/static/assets/favicon.svg +2 -25
- package/static/assets/logo-dark.svg +2 -32
- package/static/assets/logo.svg +2 -32
- package/static/assets/mimes/application-sql.svg +29 -1
- package/static/assets/mimes/application-x-sql.svg +29 -0
- package/static/assets/mimes/image-bmp.svg +12 -0
- package/static/assets/pdfjs/build/pdf.mjs +4869 -4454
- package/static/assets/pdfjs/build/pdf.mjs.map +1 -1
- package/static/assets/pdfjs/build/pdf.sandbox.mjs +3 -3
- package/static/assets/pdfjs/build/pdf.sandbox.mjs.map +1 -1
- package/static/assets/pdfjs/build/pdf.worker.mjs +885 -596
- package/static/assets/pdfjs/build/pdf.worker.mjs.map +1 -1
- package/static/assets/pdfjs/version +1 -1
- package/static/assets/pdfjs/web/locale/be/viewer.ftl +40 -0
- package/static/assets/pdfjs/web/locale/bg/viewer.ftl +2 -0
- package/static/assets/pdfjs/web/locale/cs/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/cy/viewer.ftl +43 -0
- package/static/assets/pdfjs/web/locale/da/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/de/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/dsb/viewer.ftl +43 -0
- package/static/assets/pdfjs/web/locale/el/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/en-CA/viewer.ftl +35 -0
- package/static/assets/pdfjs/web/locale/en-GB/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/en-US/viewer.ftl +2 -2
- package/static/assets/pdfjs/web/locale/eo/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/es-AR/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/es-CL/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/es-ES/viewer.ftl +72 -0
- package/static/assets/pdfjs/web/locale/es-MX/viewer.ftl +120 -0
- package/static/assets/pdfjs/web/locale/eu/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/fi/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/fr/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/fur/viewer.ftl +77 -0
- package/static/assets/pdfjs/web/locale/fy-NL/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/gn/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/he/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/hsb/viewer.ftl +43 -0
- package/static/assets/pdfjs/web/locale/hu/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/hy-AM/viewer.ftl +1 -1
- package/static/assets/pdfjs/web/locale/ia/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/it/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/ja/viewer.ftl +32 -0
- package/static/assets/pdfjs/web/locale/ka/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/kab/viewer.ftl +73 -0
- package/static/assets/pdfjs/web/locale/kk/viewer.ftl +21 -0
- package/static/assets/pdfjs/web/locale/ko/viewer.ftl +38 -1
- package/static/assets/pdfjs/web/locale/nb-NO/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/nl/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/nn-NO/viewer.ftl +37 -0
- package/static/assets/pdfjs/web/locale/pa-IN/viewer.ftl +37 -0
- package/static/assets/pdfjs/web/locale/pl/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/pt-BR/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/rm/viewer.ftl +73 -0
- package/static/assets/pdfjs/web/locale/ro/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/ru/viewer.ftl +42 -0
- package/static/assets/pdfjs/web/locale/sc/viewer.ftl +6 -0
- package/static/assets/pdfjs/web/locale/sk/viewer.ftl +43 -0
- package/static/assets/pdfjs/web/locale/sl/viewer.ftl +42 -1
- package/static/assets/pdfjs/web/locale/sq/viewer.ftl +77 -0
- package/static/assets/pdfjs/web/locale/sv-SE/viewer.ftl +41 -0
- package/static/assets/pdfjs/web/locale/tg/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/th/viewer.ftl +35 -0
- package/static/assets/pdfjs/web/locale/tr/viewer.ftl +39 -0
- package/static/assets/pdfjs/web/locale/vi/viewer.ftl +42 -5
- package/static/assets/pdfjs/web/locale/zh-CN/viewer.ftl +35 -0
- package/static/assets/pdfjs/web/locale/zh-TW/viewer.ftl +37 -0
- package/static/assets/pdfjs/web/viewer.css +141 -110
- package/static/assets/pdfjs/web/viewer.html +7 -7
- package/static/assets/pdfjs/web/viewer.mjs +97 -14
- package/static/assets/pdfjs/web/viewer.mjs.map +1 -1
- package/static/chunk-22DWHRCL.js +1 -0
- package/static/chunk-23UUFZSR.js +1 -0
- package/static/chunk-25QTY2GI.js +1 -0
- package/static/chunk-2E7IJZLL.js +1 -0
- package/static/chunk-2FC5EKS5.js +1 -0
- package/static/chunk-2TB2INBF.js +1 -0
- package/static/chunk-32L7RG2G.js +1 -0
- package/static/chunk-3OHSTP3R.js +1 -0
- package/static/chunk-3WLBVJ2S.js +1 -0
- package/static/{chunk-MTVSJTIW.js → chunk-3YDYZLF7.js} +1 -1
- package/static/chunk-42L6C5MT.js +1 -0
- package/static/chunk-4AGQL5GV.js +1 -0
- package/static/chunk-4BPSQMI2.js +1 -0
- package/static/chunk-4FDRWZWT.js +1 -0
- package/static/chunk-4GCCF6PF.js +1 -0
- package/static/chunk-4ORP3SBY.js +1 -0
- package/static/chunk-4PZPHJ7L.js +1 -0
- package/static/chunk-4QBOHIC3.js +1 -0
- package/static/chunk-4YT6K5KY.js +1 -0
- package/static/chunk-556I6YIW.js +1 -0
- package/static/chunk-5DPIGJU4.js +1 -0
- package/static/chunk-5E3TYOL3.js +1 -0
- package/static/chunk-5IL7C45D.js +1 -0
- package/static/chunk-5KJXGMKR.js +1 -0
- package/static/chunk-5S6KPQRA.js +1 -0
- package/static/chunk-5SPGSHKL.js +1 -0
- package/static/chunk-5WCQBTXW.js +1 -0
- package/static/chunk-5XUIPWOH.js +1 -0
- package/static/chunk-62WT7PI3.js +1 -0
- package/static/chunk-6B3GGAV3.js +4 -0
- package/static/chunk-6F6OMQ5H.js +1 -0
- package/static/chunk-6I5BGQHT.js +1 -0
- package/static/chunk-6NEBGCAZ.js +1 -0
- package/static/chunk-6NOS45DG.js +1 -0
- package/static/chunk-6OKLPRCD.js +1 -0
- package/static/chunk-6VEJCG43.js +1 -0
- package/static/chunk-77SS36Z2.js +1 -0
- package/static/chunk-7AXEPO3G.js +1 -0
- package/static/chunk-7CKHC72R.js +1 -0
- package/static/chunk-7DUTYOJG.js +1 -0
- package/static/chunk-7HKFYRPF.js +1 -0
- package/static/chunk-7NZJZATZ.js +1 -0
- package/static/chunk-AADK5D2H.js +1 -0
- package/static/chunk-ACUF7IKP.js +1 -0
- package/static/chunk-AGREZPV4.js +1 -0
- package/static/chunk-ATBJWFA3.js +1 -0
- package/static/chunk-ATXLZN2B.js +1 -0
- package/static/chunk-AZ5TF5Y3.js +1 -0
- package/static/chunk-BBHYIURC.js +1 -0
- package/static/chunk-BHZEPHRI.js +13 -0
- package/static/chunk-BODMMLVB.js +7 -0
- package/static/chunk-BSB4VROD.js +2 -0
- package/static/chunk-BU4ZICZR.js +1 -0
- package/static/chunk-C3AAEQKW.js +1 -0
- package/static/chunk-CFTKW432.js +1 -0
- package/static/chunk-CNOVT6KU.js +1 -0
- package/static/chunk-D56H3XE2.js +1 -0
- package/static/chunk-DFOOSIIA.js +1 -0
- package/static/chunk-DHFQIFOF.js +1 -0
- package/static/{chunk-3GMLWAFZ.js → chunk-DIC2MVRI.js} +1 -1
- package/static/chunk-DJDRX53V.js +2 -0
- package/static/chunk-DKGXUMLT.js +1 -0
- package/static/chunk-DQ3GEMPM.js +1 -0
- package/static/chunk-DRHPEERW.js +2 -0
- package/static/chunk-DWYP6ZGG.js +1 -0
- package/static/chunk-EDJAISWO.js +13 -0
- package/static/chunk-EIYRBM4J.js +1 -0
- package/static/chunk-EL6QL4TP.js +1 -0
- package/static/chunk-ERDZ7IVF.js +1 -0
- package/static/chunk-EVQKKVUZ.js +1 -0
- package/static/chunk-F2XG7EWI.js +1 -0
- package/static/chunk-F672FY5I.js +1 -0
- package/static/chunk-F6V37MKG.js +1 -0
- package/static/chunk-FCGTI42I.js +1 -0
- package/static/chunk-FNOTGWRW.js +1 -0
- package/static/chunk-FQHOSSCO.js +1 -0
- package/static/chunk-GAGHHYLF.js +1 -0
- package/static/chunk-GNZPP2VO.js +1 -0
- package/static/{chunk-JPT5WEAT.js → chunk-GOJYWL2M.js} +1 -1
- package/static/chunk-GRLHFXGB.js +1 -0
- package/static/chunk-H6WOTGQ5.js +1 -0
- package/static/{chunk-CHJ64RJM.js → chunk-H6ZXFINQ.js} +1 -1
- package/static/chunk-HC7F57NA.js +1 -0
- package/static/chunk-HCSWO7BO.js +7 -0
- package/static/chunk-HHWXIK2M.js +7 -0
- package/static/chunk-HKRGIRKB.js +3 -0
- package/static/chunk-HMOB6XC5.js +1 -0
- package/static/chunk-HNMGPG72.js +1 -0
- package/static/chunk-HS4S6BV3.js +1 -0
- package/static/chunk-I2S3XPC5.js +3 -0
- package/static/chunk-IJ7K7ATQ.js +1 -0
- package/static/chunk-IOIBQGHN.js +562 -0
- package/static/chunk-ITVA26X2.js +2 -0
- package/static/chunk-J6YSFHLZ.js +1 -0
- package/static/chunk-JAEJ6IMV.js +1 -0
- package/static/chunk-JB5R6V33.js +1 -0
- package/static/chunk-JF6WIV6M.js +1 -0
- package/static/chunk-JGB4LLUT.js +1 -0
- package/static/chunk-JGXVTKLG.js +1 -0
- package/static/chunk-JMYAD7E2.js +1 -0
- package/static/chunk-JSE63Q5X.js +1 -0
- package/static/chunk-JVV3ZL6L.js +1 -0
- package/static/chunk-JWPXQOS3.js +5 -0
- package/static/chunk-JXZCNFW7.js +1 -0
- package/static/chunk-JY2I3HGL.js +1 -0
- package/static/chunk-K657XPXA.js +1 -0
- package/static/chunk-KAVP6UXH.js +1 -0
- package/static/{chunk-3R74L4UU.js → chunk-KDEEERWZ.js} +1 -1
- package/static/chunk-KLOUBIO4.js +1 -0
- package/static/chunk-KMF3ZRAO.js +1 -0
- package/static/chunk-KT3TWCST.js +1 -0
- package/static/chunk-L6SYG23T.js +1 -0
- package/static/{chunk-LNTUR3GU.js → chunk-LRDKG274.js} +1 -1
- package/static/chunk-LRQSPCYZ.js +1 -0
- package/static/chunk-LUSVISM6.js +1 -0
- package/static/{chunk-LVSNIS5P.js → chunk-LYZGJZNP.js} +1 -1
- package/static/chunk-LZKI5P5T.js +1 -0
- package/static/chunk-M4XL3JN5.js +6 -0
- package/static/{chunk-UNCPXHHT.js → chunk-MGWG7OD7.js} +1 -1
- package/static/chunk-MIA5YBOI.js +1 -0
- package/static/chunk-MKUUWY6Y.js +1 -0
- package/static/chunk-MR3U7TKQ.js +1 -0
- package/static/chunk-MYM43ENO.js +1 -0
- package/static/chunk-NAH4V2R6.js +2 -0
- package/static/chunk-NBBDVVUF.js +1 -0
- package/static/chunk-NKGKBQBX.js +1 -0
- package/static/chunk-NMF2ZFBE.js +1 -0
- package/static/chunk-NN4ONTOT.js +1 -0
- package/static/chunk-NOPACN4F.js +1 -0
- package/static/chunk-NYJPOP4L.js +1 -0
- package/static/chunk-OQRWXCLY.js +1 -0
- package/static/chunk-PCFH5HCI.js +2 -0
- package/static/chunk-PJF5XUTO.js +1 -0
- package/static/{chunk-FJE6BOFL.js → chunk-PSUAQBYM.js} +1 -1
- package/static/chunk-PTLYIUFW.js +1 -0
- package/static/chunk-PXRT4L57.js +1 -0
- package/static/chunk-PZGLDZZM.js +1 -0
- package/static/chunk-Q4VNZGFI.js +1 -0
- package/static/chunk-Q556XB3S.js +1 -0
- package/static/{chunk-PB4AIT7O.js → chunk-Q7IXRPOO.js} +1 -1
- package/static/chunk-Q7U2VPIS.js +1 -0
- package/static/chunk-QM6CQMEX.js +1 -0
- package/static/chunk-QMHUIHSR.js +1 -0
- package/static/chunk-QVFPHTOH.js +1 -0
- package/static/chunk-R4MI25E2.js +1 -0
- package/static/chunk-R7JRAR3P.js +1 -0
- package/static/chunk-R7PNKQU2.js +1 -0
- package/static/chunk-RCAORRB7.js +1 -0
- package/static/chunk-RDNTK4YH.js +1 -0
- package/static/{chunk-VJTXJ43D.js → chunk-RK2ONYTL.js} +1 -1
- package/static/chunk-RK7XRDNB.js +1 -0
- package/static/chunk-RO7SAOLK.js +1 -0
- package/static/chunk-RQUUINHV.js +1 -0
- package/static/chunk-RUN556VW.js +1 -0
- package/static/chunk-S2VBGI6Q.js +1 -0
- package/static/chunk-S7S5M3AZ.js +1 -0
- package/static/chunk-SBLNYV74.js +1 -0
- package/static/chunk-SIZCHHUA.js +1 -0
- package/static/chunk-SRBOO7AO.js +1 -0
- package/static/{chunk-PVDHBQRM.js → chunk-STA7NTYL.js} +1 -1
- package/static/chunk-T3YI3BSS.js +1 -0
- package/static/chunk-TAL3RTTQ.js +1 -0
- package/static/chunk-TGLJFALR.js +1 -0
- package/static/chunk-TJZKTNNS.js +1 -0
- package/static/chunk-U4RW6XG5.js +1 -0
- package/static/chunk-UJTFWZEC.js +1 -0
- package/static/chunk-UPGVU5LG.js +1 -0
- package/static/chunk-UQ6O3I6W.js +1 -0
- package/static/{chunk-5NMSIIQB.js → chunk-V43RGNXA.js} +1 -1
- package/static/chunk-V6FA5QY4.js +1 -0
- package/static/chunk-VK7XMFVE.js +1 -0
- package/static/chunk-VQJYCYWI.js +1 -0
- package/static/chunk-VWIRXLNE.js +1 -0
- package/static/chunk-VZMVGIVW.js +1 -0
- package/static/chunk-VZPCXSRG.js +2 -0
- package/static/chunk-WR3MA3L3.js +1 -0
- package/static/chunk-XCLK7NJL.js +1 -0
- package/static/{chunk-DSWEWLXJ.js → chunk-XCPDPB5G.js} +1 -1
- package/static/chunk-XEGHEUP5.js +1 -0
- package/static/chunk-XKEBQNQJ.js +1 -0
- package/static/chunk-XOF4UW3S.js +1 -0
- package/static/chunk-XQGPSNQB.js +1 -0
- package/static/{chunk-QO6BTONN.js → chunk-Y4MAPE2C.js} +1 -1
- package/static/chunk-Y5RLD72B.js +1 -0
- package/static/{chunk-DPUVSXRB.js → chunk-Y5XTRCFK.js} +1 -1
- package/static/chunk-Y63UUJGJ.js +1 -0
- package/static/chunk-YBNAC7QM.js +1 -0
- package/static/chunk-YCTCESL4.js +1 -0
- package/static/chunk-YMAN4LIU.js +1 -0
- package/static/chunk-YTDE6SXT.js +1 -0
- package/static/chunk-YZPIUJB3.js +1 -0
- package/static/chunk-ZCOWBVOT.js +1 -0
- package/static/chunk-ZHRYYMYE.js +1 -0
- package/static/chunk-ZNXTOQFG.js +1 -0
- package/static/{chunk-URHTCJ7G.js → chunk-ZQLBPLXI.js} +1 -1
- package/static/chunk-ZXXHFBGL.js +1 -0
- package/static/favicon.ico +0 -0
- package/static/index.html +2 -2
- package/static/main-56PZQ6TJ.js +11 -0
- package/static/styles-Q4OZOSSK.css +1 -0
- package/server/applications/notifications/interfaces/user-mail-notification.js.map +0 -1
- package/static/assets/codemirror/mode/apl/apl.js +0 -174
- package/static/assets/codemirror/mode/asciiarmor/asciiarmor.js +0 -74
- package/static/assets/codemirror/mode/asn.1/asn.1.js +0 -204
- package/static/assets/codemirror/mode/asterisk/asterisk.js +0 -220
- package/static/assets/codemirror/mode/brainfuck/brainfuck.js +0 -85
- package/static/assets/codemirror/mode/clike/clike.js +0 -942
- package/static/assets/codemirror/mode/clojure/clojure.js +0 -293
- package/static/assets/codemirror/mode/cmake/cmake.js +0 -97
- package/static/assets/codemirror/mode/cobol/cobol.js +0 -255
- package/static/assets/codemirror/mode/coffeescript/coffeescript.js +0 -359
- package/static/assets/codemirror/mode/commonlisp/commonlisp.js +0 -125
- package/static/assets/codemirror/mode/crystal/crystal.js +0 -433
- package/static/assets/codemirror/mode/css/css.js +0 -862
- package/static/assets/codemirror/mode/cypher/cypher.js +0 -152
- package/static/assets/codemirror/mode/d/d.js +0 -223
- package/static/assets/codemirror/mode/dart/dart.js +0 -168
- package/static/assets/codemirror/mode/diff/diff.js +0 -47
- package/static/assets/codemirror/mode/django/django.js +0 -356
- package/static/assets/codemirror/mode/dockerfile/dockerfile.js +0 -211
- package/static/assets/codemirror/mode/dtd/dtd.js +0 -142
- package/static/assets/codemirror/mode/dylan/dylan.js +0 -352
- package/static/assets/codemirror/mode/ebnf/ebnf.js +0 -195
- package/static/assets/codemirror/mode/ecl/ecl.js +0 -206
- package/static/assets/codemirror/mode/eiffel/eiffel.js +0 -160
- package/static/assets/codemirror/mode/elm/elm.js +0 -245
- package/static/assets/codemirror/mode/erlang/erlang.js +0 -619
- package/static/assets/codemirror/mode/factor/factor.js +0 -85
- package/static/assets/codemirror/mode/fcl/fcl.js +0 -173
- package/static/assets/codemirror/mode/forth/forth.js +0 -180
- package/static/assets/codemirror/mode/fortran/fortran.js +0 -188
- package/static/assets/codemirror/mode/gas/gas.js +0 -355
- package/static/assets/codemirror/mode/gfm/gfm.js +0 -129
- package/static/assets/codemirror/mode/gherkin/gherkin.js +0 -194
- package/static/assets/codemirror/mode/go/go.js +0 -187
- package/static/assets/codemirror/mode/groovy/groovy.js +0 -245
- package/static/assets/codemirror/mode/haml/haml.js +0 -161
- package/static/assets/codemirror/mode/handlebars/handlebars.js +0 -70
- package/static/assets/codemirror/mode/haskell/haskell.js +0 -268
- package/static/assets/codemirror/mode/haskell-literate/haskell-literate.js +0 -43
- package/static/assets/codemirror/mode/haxe/haxe.js +0 -515
- package/static/assets/codemirror/mode/htmlembedded/htmlembedded.js +0 -37
- package/static/assets/codemirror/mode/htmlmixed/htmlmixed.js +0 -153
- package/static/assets/codemirror/mode/http/http.js +0 -113
- package/static/assets/codemirror/mode/idl/idl.js +0 -290
- package/static/assets/codemirror/mode/javascript/javascript.js +0 -960
- package/static/assets/codemirror/mode/jinja2/jinja2.js +0 -193
- package/static/assets/codemirror/mode/jsx/jsx.js +0 -149
- package/static/assets/codemirror/mode/julia/julia.js +0 -390
- package/static/assets/codemirror/mode/livescript/livescript.js +0 -280
- package/static/assets/codemirror/mode/lua/lua.js +0 -160
- package/static/assets/codemirror/mode/markdown/markdown.js +0 -886
- package/static/assets/codemirror/mode/mathematica/mathematica.js +0 -176
- package/static/assets/codemirror/mode/mbox/mbox.js +0 -129
- package/static/assets/codemirror/mode/meta.js +0 -221
- package/static/assets/codemirror/mode/mirc/mirc.js +0 -193
- package/static/assets/codemirror/mode/mllike/mllike.js +0 -359
- package/static/assets/codemirror/mode/modelica/modelica.js +0 -245
- package/static/assets/codemirror/mode/mscgen/mscgen.js +0 -175
- package/static/assets/codemirror/mode/mumps/mumps.js +0 -148
- package/static/assets/codemirror/mode/nginx/nginx.js +0 -178
- package/static/assets/codemirror/mode/nsis/nsis.js +0 -95
- package/static/assets/codemirror/mode/ntriples/ntriples.js +0 -195
- package/static/assets/codemirror/mode/octave/octave.js +0 -139
- package/static/assets/codemirror/mode/oz/oz.js +0 -252
- package/static/assets/codemirror/mode/pascal/pascal.js +0 -136
- package/static/assets/codemirror/mode/pegjs/pegjs.js +0 -111
- package/static/assets/codemirror/mode/perl/perl.js +0 -836
- package/static/assets/codemirror/mode/php/php.js +0 -234
- package/static/assets/codemirror/mode/pig/pig.js +0 -178
- package/static/assets/codemirror/mode/powershell/powershell.js +0 -398
- package/static/assets/codemirror/mode/properties/properties.js +0 -78
- package/static/assets/codemirror/mode/protobuf/protobuf.js +0 -72
- package/static/assets/codemirror/mode/pug/pug.js +0 -591
- package/static/assets/codemirror/mode/puppet/puppet.js +0 -220
- package/static/assets/codemirror/mode/python/python.js +0 -402
- package/static/assets/codemirror/mode/q/q.js +0 -139
- package/static/assets/codemirror/mode/r/r.js +0 -190
- package/static/assets/codemirror/mode/rpm/changes/index.html +0 -66
- package/static/assets/codemirror/mode/rpm/rpm.js +0 -109
- package/static/assets/codemirror/mode/rst/rst.js +0 -557
- package/static/assets/codemirror/mode/ruby/ruby.js +0 -303
- package/static/assets/codemirror/mode/rust/rust.js +0 -72
- package/static/assets/codemirror/mode/sas/sas.js +0 -303
- package/static/assets/codemirror/mode/sass/sass.js +0 -459
- package/static/assets/codemirror/mode/scheme/scheme.js +0 -284
- package/static/assets/codemirror/mode/shell/shell.js +0 -168
- package/static/assets/codemirror/mode/sieve/sieve.js +0 -193
- package/static/assets/codemirror/mode/slim/slim.js +0 -575
- package/static/assets/codemirror/mode/smalltalk/smalltalk.js +0 -168
- package/static/assets/codemirror/mode/smarty/smarty.js +0 -225
- package/static/assets/codemirror/mode/solr/solr.js +0 -104
- package/static/assets/codemirror/mode/soy/soy.js +0 -665
- package/static/assets/codemirror/mode/sparql/sparql.js +0 -184
- package/static/assets/codemirror/mode/spreadsheet/spreadsheet.js +0 -112
- package/static/assets/codemirror/mode/sql/sql.js +0 -529
- package/static/assets/codemirror/mode/stex/stex.js +0 -264
- package/static/assets/codemirror/mode/stylus/stylus.js +0 -775
- package/static/assets/codemirror/mode/swift/swift.js +0 -221
- package/static/assets/codemirror/mode/tcl/tcl.js +0 -140
- package/static/assets/codemirror/mode/textile/textile.js +0 -469
- package/static/assets/codemirror/mode/tiddlywiki/tiddlywiki.css +0 -14
- package/static/assets/codemirror/mode/tiddlywiki/tiddlywiki.js +0 -308
- package/static/assets/codemirror/mode/tiki/tiki.css +0 -26
- package/static/assets/codemirror/mode/tiki/tiki.js +0 -312
- package/static/assets/codemirror/mode/toml/toml.js +0 -88
- package/static/assets/codemirror/mode/tornado/tornado.js +0 -68
- package/static/assets/codemirror/mode/troff/troff.js +0 -84
- package/static/assets/codemirror/mode/ttcn/ttcn.js +0 -283
- package/static/assets/codemirror/mode/ttcn-cfg/ttcn-cfg.js +0 -214
- package/static/assets/codemirror/mode/turtle/turtle.js +0 -162
- package/static/assets/codemirror/mode/twig/twig.js +0 -141
- package/static/assets/codemirror/mode/vb/vb.js +0 -275
- package/static/assets/codemirror/mode/vbscript/vbscript.js +0 -350
- package/static/assets/codemirror/mode/velocity/velocity.js +0 -202
- package/static/assets/codemirror/mode/verilog/verilog.js +0 -781
- package/static/assets/codemirror/mode/vhdl/vhdl.js +0 -189
- package/static/assets/codemirror/mode/vue/vue.js +0 -77
- package/static/assets/codemirror/mode/wast/wast.js +0 -132
- package/static/assets/codemirror/mode/webidl/webidl.js +0 -195
- package/static/assets/codemirror/mode/xml/xml.js +0 -417
- package/static/assets/codemirror/mode/xquery/xquery.js +0 -448
- package/static/assets/codemirror/mode/yacas/yacas.js +0 -204
- package/static/assets/codemirror/mode/yaml/yaml.js +0 -120
- package/static/assets/codemirror/mode/yaml-frontmatter/yaml-frontmatter.js +0 -72
- package/static/assets/codemirror/mode/z80/z80.js +0 -116
- package/static/chunk-2KLC4T2Z.js +0 -1
- package/static/chunk-2VMSXRCB.js +0 -12
- package/static/chunk-3OHSRRKH.js +0 -4
- package/static/chunk-3R4WKOHQ.js +0 -1
- package/static/chunk-3XVM35O2.js +0 -1
- package/static/chunk-3YVRP3VM.js +0 -2
- package/static/chunk-5UKZLU5H.js +0 -1
- package/static/chunk-AF24EYXU.js +0 -1
- package/static/chunk-AKQVEHO6.js +0 -2
- package/static/chunk-BCVX464U.js +0 -2
- package/static/chunk-BQV4FRM6.js +0 -1
- package/static/chunk-CETH7UYS.js +0 -1
- package/static/chunk-DIT6W7VM.js +0 -562
- package/static/chunk-DKSEQTMX.js +0 -1
- package/static/chunk-FZ3JPGYZ.js +0 -1
- package/static/chunk-IQSKQXC3.js +0 -1
- package/static/chunk-ITUFI2BJ.js +0 -1
- package/static/chunk-LCTZJ537.js +0 -1
- package/static/chunk-LK2UCQJ6.js +0 -1
- package/static/chunk-LP5TBXEN.js +0 -7
- package/static/chunk-N3U6637P.js +0 -1
- package/static/chunk-NNV4OXSB.js +0 -1
- package/static/chunk-O6FYXVHI.js +0 -1
- package/static/chunk-OOGP4WSH.js +0 -2
- package/static/chunk-PCWDQPOM.js +0 -2
- package/static/chunk-PNR6M34W.js +0 -1
- package/static/chunk-Q5KM7LTX.js +0 -1
- package/static/chunk-QHC6ZPQ4.js +0 -1
- package/static/chunk-QMRBZHE4.js +0 -1
- package/static/chunk-QSJRY3TF.js +0 -1
- package/static/chunk-QUUIRSYT.js +0 -1
- package/static/chunk-RFH46UW3.js +0 -1
- package/static/chunk-RSXHRKM5.js +0 -1
- package/static/chunk-RV3VZJPZ.js +0 -1
- package/static/chunk-S7HNXVRB.js +0 -1
- package/static/chunk-SBZ572Q4.js +0 -2
- package/static/chunk-SJR5R3Y4.js +0 -1
- package/static/chunk-SLHTEGRU.js +0 -1
- package/static/chunk-SSFF27P2.js +0 -24
- package/static/chunk-V3LHHZYN.js +0 -1
- package/static/chunk-VQQKMY2C.js +0 -1
- package/static/chunk-WSSU2HXE.js +0 -1
- package/static/chunk-XDZGW64M.js +0 -3
- package/static/chunk-XTRDKGKG.js +0 -1
- package/static/chunk-YLWTEC3X.js +0 -1
- package/static/chunk-Z5J5F5SX.js +0 -1
- package/static/main-4H5BJY3J.js +0 -9
- package/static/scripts-WRDOQIU5.js +0 -24
- package/static/styles-2C2UNCNB.css +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../backend/src/applications/shares/services/shares-manager.service.spec.ts"],"sourcesContent":["/*\n * Copyright (C) 2012-2025 Johan Legrand <johan.legrand@sync-in.com>\n * This file is part of Sync-in | The open source file sync and share solution\n * See the LICENSE file for licensing details\n */\n\nimport { HttpException, HttpStatus } from '@nestjs/common'\nimport { Test, TestingModule } from '@nestjs/testing'\nimport * as commonFunctions from '../../../common/functions'\nimport { ContextManager } from '../../../infrastructure/context/services/context-manager.service'\nimport { DB_TOKEN_PROVIDER } from '../../../infrastructure/database/constants'\nimport { LINK_TYPE } from '../../links/constants/links'\nimport { LinksQueries } from '../../links/services/links-queries.service'\nimport { NotificationsManager } from '../../notifications/services/notifications-manager.service'\nimport { SpacesQueries } from '../../spaces/services/spaces-queries.service'\nimport * as permissionsUtils from '../../spaces/utils/permissions'\nimport { GUEST_PERMISSION } from '../../users/constants/user'\nimport { UsersQueries } from '../../users/services/users-queries.service'\nimport { SHARE_ALL_OPERATIONS } from '../constants/shares'\nimport { SharesManager } from './shares-manager.service'\nimport { SharesQueries } from './shares-queries.service'\n\n// Mock classes and utility modules used by SharesManager\njest.mock('../../spaces/models/space-env.model', () => ({\n SpaceEnv: jest.fn().mockImplementation(() => ({\n setPermissions: jest.fn(),\n envPermissions: 'ENV_PERMS'\n }))\n}))\n\njest.mock('../../spaces/utils/permissions', () => ({\n havePermission: jest.fn(),\n haveSpacePermission: jest.fn(),\n removePermissions: jest.fn(() => 'trimmed')\n}))\n\njest.mock('../../../common/functions', () => {\n const actual = jest.requireActual('../../../common/functions')\n return {\n ...actual,\n generateShortUUID: jest.fn(),\n hashPassword: jest.fn(),\n intersectPermissions: jest.fn()\n }\n})\n\ndescribe(SharesManager.name, () => {\n let service: SharesManager\n\n // Mocks\n const contextManagerMock = {\n get: jest.fn()\n }\n\n const notificationsManagerMock = {\n create: jest.fn().mockResolvedValue(undefined),\n sendEmailNotification: jest.fn().mockResolvedValue(undefined)\n }\n\n const spacesQueriesMock = {\n permissions: jest.fn()\n }\n\n const usersQueriesMock = {\n createUserOrGuest: jest.fn(),\n deleteGuestLink: jest.fn(),\n usersWhitelist: jest.fn().mockResolvedValue([]),\n groupsWhitelist: jest.fn().mockResolvedValue([]),\n allUserIdsFromGroupsAndSubGroups: jest.fn().mockResolvedValue([])\n }\n\n const linksQueriesMock = {\n isUniqueUUID: jest.fn(),\n isReservedUUID: jest.fn(),\n allLinksFromSpaceOrShare: jest.fn(),\n createLinkToSpaceOrShare: jest.fn(),\n updateLinkFromSpaceOrShare: jest.fn(),\n linkFromShare: jest.fn(),\n linkFromSpace: jest.fn()\n }\n\n const sharesQueriesMock = {\n permissions: jest.fn(),\n listShareLinks: jest.fn(),\n getShareWithMembers: jest.fn(),\n createShare: jest.fn(),\n updateShare: jest.fn(),\n selectShares: jest.fn(),\n deleteShare: jest.fn(),\n updateMember: jest.fn(),\n updateMembers: jest.fn(),\n shareExistsForOwner: jest.fn(),\n childExistsForShareOwner: jest.fn()\n }\n\n const user = { id: 1, isAdmin: false } as any\n\n beforeAll(async () => {\n const module: TestingModule = await Test.createTestingModule({\n providers: [\n { provide: DB_TOKEN_PROVIDER, useValue: {} },\n { provide: ContextManager, useValue: contextManagerMock },\n { provide: NotificationsManager, useValue: notificationsManagerMock },\n { provide: SpacesQueries, useValue: spacesQueriesMock },\n { provide: UsersQueries, useValue: usersQueriesMock },\n { provide: LinksQueries, useValue: linksQueriesMock },\n { provide: SharesQueries, useValue: sharesQueriesMock },\n SharesManager\n ]\n }).compile()\n\n module.useLogger(['fatal'])\n service = module.get<SharesManager>(SharesManager)\n })\n\n beforeEach(() => {\n jest.clearAllMocks()\n })\n\n it('should be defined', () => {\n expect(service).toBeDefined()\n })\n\n describe('setAllowedPermissions', () => {\n it('sets all operations when the user is the file owner (personal space case)', async () => {\n const share: any = { file: { ownerId: user.id, permissions: '' } }\n await service.setAllowedPermissions(user, share)\n expect(share.file.permissions).toBe(SHARE_ALL_OPERATIONS)\n })\n\n it('uses space permissions when file has a space alias', async () => {\n spacesQueriesMock.permissions.mockResolvedValueOnce({ any: 'thing' })\n const share: any = {\n file: { ownerId: 999, space: { alias: 'space-1', root: { alias: 'root' } }, permissions: undefined }\n }\n await service.setAllowedPermissions(user, share)\n expect(spacesQueriesMock.permissions).toHaveBeenCalledWith(user.id, 'space-1', 'root')\n expect(share.file.ownerId).toBeNull()\n expect(share.file.permissions).toBe('ENV_PERMS')\n })\n\n it('uses parent share permissions when parent alias is present', async () => {\n sharesQueriesMock.permissions.mockResolvedValueOnce({ permissions: 'PARENT_PERMS' })\n const share: any = {\n ownerId: 77,\n parent: { alias: 'parent-share' },\n file: { permissions: undefined }\n }\n await service.setAllowedPermissions(user, share)\n expect(sharesQueriesMock.permissions).toHaveBeenCalledWith(user.id, 'parent-share', +user.isAdmin)\n expect(share.file.permissions).toBe('PARENT_PERMS')\n })\n\n it('throws Bad Request when missing required information', async () => {\n const share: any = { file: {}, parent: {} }\n await expect(service.setAllowedPermissions(user, share)).rejects.toEqual(new HttpException('Missing information', HttpStatus.BAD_REQUEST))\n })\n })\n\n describe('getShareWithMembers', () => {\n it('returns the share and calls setAllowedPermissions', async () => {\n const share: any = { id: 10, file: {} }\n sharesQueriesMock.getShareWithMembers.mockResolvedValueOnce(share)\n const spy = jest.spyOn(service, 'setAllowedPermissions').mockResolvedValueOnce(void 0)\n\n const result = await service.getShareWithMembers(user, 10, true)\n\n expect(result).toBe(share)\n expect(spy).toHaveBeenCalledWith(user, share, true)\n })\n\n it('throws Forbidden when share is not found or not authorized', async () => {\n sharesQueriesMock.getShareWithMembers.mockResolvedValueOnce(null)\n await expect(service.getShareWithMembers(user, 99, false)).rejects.toEqual(new HttpException('Not authorized', HttpStatus.FORBIDDEN))\n })\n })\n\n describe('generateLinkUUID', () => {\n it('loops until a unique UUID is found', async () => {\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValueOnce('aaa').mockReturnValueOnce('bbb')\n\n linksQueriesMock.isUniqueUUID.mockResolvedValueOnce(false).mockResolvedValueOnce(true)\n\n const { uuid } = await service.generateLinkUUID(user.id)\n\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenCalledTimes(2)\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenNthCalledWith(1, user.id, 'aaa')\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenNthCalledWith(2, user.id, 'bbb')\n expect(uuid).toBe('bbb')\n })\n })\n\n describe('getShareLink', () => {\n it('returns the share link and trims unsupported permissions', async () => {\n const shareLink: any = { id: 5, file: { permissions: 'ORIG' } }\n sharesQueriesMock.listShareLinks.mockResolvedValueOnce(shareLink)\n const spy = jest.spyOn(service, 'setAllowedPermissions').mockResolvedValueOnce(void 0)\n\n const result = await service.getShareLink(user, 5)\n\n expect(spy).toHaveBeenCalledWith(user, shareLink)\n expect(result).toBe(shareLink)\n expect(result.file.permissions).toBe('trimmed')\n expect((permissionsUtils.removePermissions as jest.Mock).mock.calls[0][0]).toBe('ORIG')\n })\n\n it('throws Forbidden when link is not found', async () => {\n sharesQueriesMock.listShareLinks.mockResolvedValueOnce(null)\n await expect(service.getShareLink(user, 123)).rejects.toEqual(new HttpException('Not authorized', HttpStatus.FORBIDDEN))\n })\n })\n\n describe('updateLinkFromSpaceOrShare (from API)', () => {\n it('intersects permissions and returns updated link object', async () => {\n const baseLink: any = {\n id: 42,\n name: 'old',\n email: 'x@x',\n requireAuth: false,\n limitAccess: null,\n expiresAt: null,\n permissions: 'OLD',\n shareName: 'OldShare',\n shareDescription: 'OldDesc'\n }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(baseLink)\n jest.spyOn(service, 'getShareLink').mockResolvedValueOnce({ file: { permissions: 'SHARE_PERMS' } } as any)\n ;(commonFunctions.intersectPermissions as jest.Mock).mockReturnValue('INTERSECTED')\n linksQueriesMock.updateLinkFromSpaceOrShare.mockResolvedValueOnce(undefined)\n\n const dto: any = {\n permissions: 'NEW_PERMS',\n language: 'fr',\n isActive: false\n }\n\n const result = await service.updateLinkFromSpaceOrShare(user, 7, 55, 1 as any, dto, true)\n\n expect(linksQueriesMock.updateLinkFromSpaceOrShare).toHaveBeenCalled()\n expect(result.permissions).toBe('INTERSECTED')\n expect(result.language).toBe('fr')\n expect(result.isActive).toBe(false)\n })\n })\n\n describe('createGuestLink', () => {\n it('creates guest link with hashed password and returns created user info', async () => {\n ;(commonFunctions.hashPassword as jest.Mock).mockResolvedValue('HASHED')\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValue('RANDOMSEQ')\n usersQueriesMock.createUserOrGuest.mockResolvedValueOnce(99)\n\n const guest = await service.createGuestLink(GUEST_PERMISSION.SHARES, 'plaintext', 'en', true)\n\n expect(usersQueriesMock.createUserOrGuest).toHaveBeenCalled()\n expect(guest.id).toBe(99)\n expect(guest.password).toBe('HASHED')\n expect(guest.role).toBeDefined()\n expect(guest.permissions).toBe(GUEST_PERMISSION.SHARES)\n expect(guest.language).toBe('en')\n expect(guest.isActive).toBe(true)\n })\n\n it('generates a random password and defaults isActive when not provided', async () => {\n ;(commonFunctions.hashPassword as jest.Mock).mockResolvedValue('HASHED-RAND')\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValueOnce('RANDOMSEQ')\n usersQueriesMock.createUserOrGuest.mockResolvedValueOnce(123)\n\n const guest = await service.createGuestLink(GUEST_PERMISSION.SPACES)\n\n expect(commonFunctions.hashPassword).toHaveBeenCalled()\n expect(guest.id).toBe(123)\n expect(guest.isActive).toBe(true)\n expect(guest.language).toBeNull()\n })\n })\n\n describe('getLinkFromSpaceOrShare', () => {\n it('returns a link guest for SPACE type', async () => {\n const lg = { id: 1 }\n linksQueriesMock.linkFromSpace.mockResolvedValueOnce(lg)\n\n const res = await service.getLinkFromSpaceOrShare(user, 11, 22, LINK_TYPE.SPACE)\n\n expect(res).toBe(lg)\n expect(linksQueriesMock.linkFromSpace).toHaveBeenCalledWith(user.id, 11, 22)\n expect(linksQueriesMock.linkFromShare).not.toHaveBeenCalled()\n })\n\n it('returns a link guest for SHARE type', async () => {\n const lg = { id: 2 }\n linksQueriesMock.linkFromShare.mockResolvedValueOnce(lg)\n\n const res = await service.getLinkFromSpaceOrShare(user, 33, 44, LINK_TYPE.SHARE)\n\n expect(res).toBe(lg)\n expect(linksQueriesMock.linkFromShare).toHaveBeenCalledWith(user.id, 33, 44, +user.isAdmin)\n expect(linksQueriesMock.linkFromSpace).not.toHaveBeenCalled()\n })\n\n it('throws when link not found', async () => {\n linksQueriesMock.linkFromSpace.mockResolvedValueOnce(null)\n\n await expect(service.getLinkFromSpaceOrShare(user, 55, 66, LINK_TYPE.SPACE)).rejects.toEqual(\n new HttpException('Link not found', HttpStatus.NOT_FOUND)\n )\n })\n })\n\n describe('updateLinkFromSpaceOrShare (additional branches)', () => {\n it('returns null when no diff and not from API', async () => {\n const link: any = { id: 1, name: 'n', email: 'e', requireAuth: false, limitAccess: null, expiresAt: null }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(link)\n\n const result = await service.updateLinkFromSpaceOrShare(user, 1, 2, LINK_TYPE.SHARE, {}, false)\n\n expect(result).toBeNull()\n expect(linksQueriesMock.updateLinkFromSpaceOrShare).not.toHaveBeenCalled()\n })\n\n it('hashes password and does not leak it when fromAPI is true', async () => {\n const link: any = { id: 1 }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(link)\n ;(commonFunctions.hashPassword as jest.Mock).mockResolvedValueOnce('HASHED')\n ;(linksQueriesMock.updateLinkFromSpaceOrShare as jest.Mock).mockImplementation(async (_link: any, _spaceOrShareId: number, updateUser: any) => {\n // Assert at call time before the service deletes the password\n expect(updateUser).toMatchObject({ password: 'HASHED' })\n return\n })\n\n const result = await service.updateLinkFromSpaceOrShare(user, 1, 2, LINK_TYPE.SHARE, { password: 'secret' }, true)\n\n expect(linksQueriesMock.updateLinkFromSpaceOrShare).toHaveBeenCalled()\n // The returned link must not leak password\n expect(result).toBe(link)\n expect((result as any).password).toBeUndefined()\n })\n\n it('updates multiple link/user fields and ignores equal expiresAt', async () => {\n const base = {\n id: 9,\n name: 'a',\n email: 'b',\n requireAuth: false,\n limitAccess: null,\n expiresAt: { date: '2025-01-01' }\n }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(base as any)\n linksQueriesMock.updateLinkFromSpaceOrShare.mockResolvedValueOnce(undefined)\n\n const dto = {\n name: 'a2',\n email: 'b2',\n requireAuth: true,\n limitAccess: 5,\n expiresAt: { date: '2025-01-01' } // equal, should be ignored\n }\n\n await service.updateLinkFromSpaceOrShare(user, 9, 99, LINK_TYPE.SHARE, dto as any, false)\n\n const [, , , updateLink] = (linksQueriesMock.updateLinkFromSpaceOrShare as jest.Mock).mock.calls[0].slice(0, 5)\n expect(updateLink).toMatchObject({\n name: 'a2',\n email: 'b2',\n requireAuth: true,\n limitAccess: 5\n })\n expect(updateLink.expiresAt).toBeUndefined()\n })\n })\n\n describe('setAllowedPermissions (additional branches)', () => {\n it('sets all operations when share has externalPath and user is admin', async () => {\n const admin = { id: 10, isAdmin: true } as any\n const share: any = { externalPath: '/ext', file: {} }\n await service.setAllowedPermissions(admin, share)\n expect(share.file.permissions).toBe(SHARE_ALL_OPERATIONS)\n })\n\n it('throws NOT_FOUND when space permissions are missing', async () => {\n spacesQueriesMock.permissions.mockResolvedValueOnce(null)\n const share: any = { file: { space: { alias: 'space-x', root: { alias: 'r' } } } }\n\n await expect(service.setAllowedPermissions(user, share)).rejects.toEqual(new HttpException('Space not found', HttpStatus.NOT_FOUND))\n })\n\n it('throws NOT_FOUND when parent share permissions are missing', async () => {\n sharesQueriesMock.permissions.mockResolvedValueOnce(null)\n const share: any = { ownerId: 42, parent: { alias: 'parent' }, file: {} }\n\n await expect(service.setAllowedPermissions(user, share)).rejects.toEqual(new HttpException('Share not found', HttpStatus.NOT_FOUND))\n })\n\n it('uses owner permissions when asAdmin is true', async () => {\n const asAdminUser = { id: 3, isAdmin: false } as any\n sharesQueriesMock.permissions.mockResolvedValueOnce({ permissions: 'ADMIN_PARENT' })\n const share: any = { ownerId: 77, parent: { alias: 'pa' }, file: {} }\n\n await service.setAllowedPermissions(asAdminUser, share, true)\n\n expect(sharesQueriesMock.permissions).toHaveBeenCalledWith(77, 'pa', +asAdminUser.isAdmin)\n expect(share.file.permissions).toBe('ADMIN_PARENT')\n })\n })\n\n describe('getShareLink (additional branch)', () => {\n it('does not trim permissions if file.permissions is falsy', async () => {\n const shareLink: any = { id: 7, file: {} }\n sharesQueriesMock.listShareLinks.mockResolvedValueOnce(shareLink)\n const spy = jest.spyOn(service, 'setAllowedPermissions').mockResolvedValueOnce(void 0)\n\n const res = await service.getShareLink(user, 7)\n\n expect(spy).toHaveBeenCalled()\n expect(res).toBe(shareLink)\n expect(permissionsUtils.removePermissions).not.toHaveBeenCalled()\n })\n })\n\n describe('deleteShare', () => {\n it('throws Forbidden when user is not admin and not owner', async () => {\n sharesQueriesMock.shareExistsForOwner.mockResolvedValueOnce(false)\n\n await expect(service.deleteShare({ id: 2, isAdmin: false } as any, 123)).rejects.toEqual(\n new HttpException('Not authorized', HttpStatus.FORBIDDEN)\n )\n })\n\n it('deletes links and removes shares when authorized (asAdmin)', async () => {\n const deleteLinksSpy = jest.spyOn(service, 'deleteAllLinkMembers').mockResolvedValue(void 0)\n const removeSpy = jest.spyOn<any, any>(service as any, 'removeShareFromOwners').mockResolvedValue(void 0)\n\n await service.deleteShare(user, 456, true)\n\n expect(deleteLinksSpy).toHaveBeenCalledWith(456, expect.anything())\n expect(removeSpy).toHaveBeenCalledWith(456, 'all', false, user.id)\n })\n })\n\n describe('child share wrappers', () => {\n it('getChildShare returns share link when isLink = true', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValueOnce(99)\n const getShareLinkSpy = jest.spyOn(service, 'getShareLink').mockResolvedValueOnce({ id: 99 } as any)\n\n const res = await service.getChildShare(user, 1, 99, true)\n expect(res).toEqual({ id: 99 })\n expect(getShareLinkSpy).toHaveBeenCalledWith(user, 99, true)\n })\n\n it('getChildShare returns child share when isLink = false', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValueOnce(100)\n const getShareSpy = jest.spyOn(service, 'getShareWithMembers').mockResolvedValueOnce({ id: 100 } as any)\n\n const res = await service.getChildShare(user, 1, 100, false)\n expect(res).toEqual({ id: 100 })\n expect(getShareSpy).toHaveBeenCalledWith(user, 100, true)\n })\n\n it('updateChildShare forwards update and deleteChildShare forwards delete', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValue(200)\n const updateSpy = jest.spyOn(service, 'updateShare').mockResolvedValueOnce({ id: 200 } as any)\n const deleteSpy = jest.spyOn(service, 'deleteShare').mockResolvedValueOnce(void 0)\n\n await service.updateChildShare(user, 1, 200, {} as any)\n expect(updateSpy).toHaveBeenCalledWith(user, 200, {} as any, true)\n\n await service.deleteChildShare(user, 1, 200)\n expect(deleteSpy).toHaveBeenCalledWith(user, 200, true)\n })\n\n it('throws Forbidden when not allowed to manage child share', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValueOnce(null)\n await expect(service.getChildShare(user, 1, 2, false)).rejects.toEqual(new HttpException('Not authorized', HttpStatus.FORBIDDEN))\n })\n })\n\n describe('createOrUpdateLinksAsMembers', () => {\n it('creates new links for id < 0 and notifies guest', async () => {\n const createLinkSpy = jest.spyOn<any, any>(service as any, 'createLinkFromSpaceOrShare').mockResolvedValue(void 0)\n const notifySpy = jest.spyOn<any, any>(service as any, 'notifyGuestLink').mockResolvedValue(void 0)\n\n const links = [{ id: -1, linkSettings: { uuid: 'u', email: 'e', permissions: 'p' }, permissions: 'p' }] as any\n\n const res = await service.createOrUpdateLinksAsMembers(user, { id: 1, name: 'S' } as any, LINK_TYPE.SHARE, links)\n\n expect(res).toEqual([])\n expect(createLinkSpy).toHaveBeenCalled()\n expect(notifySpy).toHaveBeenCalled()\n })\n\n it('updates modified links and returns them along with unmodified ones', async () => {\n const updateLinkSpy = jest.spyOn(service, 'updateLinkFromSpaceOrShare').mockResolvedValue(void 0)\n\n const members = await service.createOrUpdateLinksAsMembers(user, { id: 1, name: 'S' } as any, LINK_TYPE.SHARE, [\n { id: 2, linkId: 2, permissions: 'p', linkSettings: { name: 'new' } },\n { id: 3, linkId: 3, permissions: 'q' } // unmodified\n ] as any)\n\n expect(updateLinkSpy).toHaveBeenCalledWith(user, 2, 1, LINK_TYPE.SHARE, { name: 'new' })\n expect(members).toHaveLength(2)\n expect(members.map((m: any) => m.id)).toEqual([2, 3])\n })\n })\n\n describe('generateLinkUUID (additional)', () => {\n it('returns immediately when the first UUID is unique', async () => {\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValueOnce('only-one')\n linksQueriesMock.isUniqueUUID.mockResolvedValueOnce(true)\n\n const { uuid } = await service.generateLinkUUID(user.id)\n\n expect(uuid).toBe('only-one')\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenCalledTimes(1)\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenCalledWith(user.id, 'only-one')\n })\n })\n})\n"],"names":["jest","mock","SpaceEnv","fn","mockImplementation","setPermissions","envPermissions","havePermission","haveSpacePermission","removePermissions","actual","requireActual","generateShortUUID","hashPassword","intersectPermissions","describe","SharesManager","name","service","contextManagerMock","get","notificationsManagerMock","create","mockResolvedValue","undefined","sendEmailNotification","spacesQueriesMock","permissions","usersQueriesMock","createUserOrGuest","deleteGuestLink","usersWhitelist","groupsWhitelist","allUserIdsFromGroupsAndSubGroups","linksQueriesMock","isUniqueUUID","isReservedUUID","allLinksFromSpaceOrShare","createLinkToSpaceOrShare","updateLinkFromSpaceOrShare","linkFromShare","linkFromSpace","sharesQueriesMock","listShareLinks","getShareWithMembers","createShare","updateShare","selectShares","deleteShare","updateMember","updateMembers","shareExistsForOwner","childExistsForShareOwner","user","id","isAdmin","beforeAll","module","Test","createTestingModule","providers","provide","DB_TOKEN_PROVIDER","useValue","ContextManager","NotificationsManager","SpacesQueries","UsersQueries","LinksQueries","SharesQueries","compile","useLogger","beforeEach","clearAllMocks","it","expect","toBeDefined","share","file","ownerId","setAllowedPermissions","toBe","SHARE_ALL_OPERATIONS","mockResolvedValueOnce","any","space","alias","root","toHaveBeenCalledWith","toBeNull","parent","rejects","toEqual","HttpException","HttpStatus","BAD_REQUEST","spy","spyOn","result","FORBIDDEN","commonFunctions","mockReturnValueOnce","uuid","generateLinkUUID","toHaveBeenCalledTimes","toHaveBeenNthCalledWith","shareLink","getShareLink","permissionsUtils","calls","baseLink","email","requireAuth","limitAccess","expiresAt","shareName","shareDescription","mockReturnValue","dto","language","isActive","toHaveBeenCalled","guest","createGuestLink","GUEST_PERMISSION","SHARES","password","role","SPACES","lg","res","getLinkFromSpaceOrShare","LINK_TYPE","SPACE","not","SHARE","NOT_FOUND","link","_link","_spaceOrShareId","updateUser","toMatchObject","toBeUndefined","base","date","updateLink","slice","admin","externalPath","asAdminUser","deleteLinksSpy","removeSpy","anything","getShareLinkSpy","getChildShare","getShareSpy","updateSpy","deleteSpy","updateChildShare","deleteChildShare","createLinkSpy","notifySpy","links","linkSettings","createOrUpdateLinksAsMembers","updateLinkSpy","members","linkId","toHaveLength","map","m"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../../../backend/src/applications/shares/services/shares-manager.service.spec.ts"],"sourcesContent":["/*\n * Copyright (C) 2012-2025 Johan Legrand <johan.legrand@sync-in.com>\n * This file is part of Sync-in | The open source file sync and share solution\n * See the LICENSE file for licensing details\n */\n\nimport { HttpException, HttpStatus } from '@nestjs/common'\nimport { Test, TestingModule } from '@nestjs/testing'\nimport * as commonFunctions from '../../../common/functions'\nimport { intersectPermissions } from '../../../common/shared'\nimport { ContextManager } from '../../../infrastructure/context/services/context-manager.service'\nimport { DB_TOKEN_PROVIDER } from '../../../infrastructure/database/constants'\nimport { LINK_TYPE } from '../../links/constants/links'\nimport { LinksQueries } from '../../links/services/links-queries.service'\nimport { NotificationsManager } from '../../notifications/services/notifications-manager.service'\nimport { SpacesQueries } from '../../spaces/services/spaces-queries.service'\nimport * as permissionsUtils from '../../spaces/utils/permissions'\nimport { GUEST_PERMISSION } from '../../users/constants/user'\nimport { UsersQueries } from '../../users/services/users-queries.service'\nimport { SHARE_ALL_OPERATIONS } from '../constants/shares'\nimport { SharesManager } from './shares-manager.service'\nimport { SharesQueries } from './shares-queries.service'\n\n// Mock classes and utility modules used by SharesManager\njest.mock('../../spaces/models/space-env.model', () => ({\n SpaceEnv: jest.fn().mockImplementation(() => ({\n setPermissions: jest.fn(),\n envPermissions: 'ENV_PERMS'\n }))\n}))\n\njest.mock('../../spaces/utils/permissions', () => ({\n havePermission: jest.fn(),\n haveSpacePermission: jest.fn(),\n removePermissions: jest.fn(() => 'trimmed')\n}))\n\njest.mock('../../../common/functions', () => {\n const actual = jest.requireActual('../../../common/functions')\n return {\n ...actual,\n generateShortUUID: jest.fn(),\n hashPassword: jest.fn()\n }\n})\n\njest.mock('../../../common/shared', () => {\n const actual = jest.requireActual('../../../common/shared')\n return {\n ...actual,\n intersectPermissions: jest.fn()\n }\n})\n\ndescribe(SharesManager.name, () => {\n let service: SharesManager\n\n // Mocks\n const contextManagerMock = {\n headerOriginUrl: jest.fn()\n }\n\n const notificationsManagerMock = {\n create: jest.fn().mockResolvedValue(undefined),\n sendEmailNotification: jest.fn().mockResolvedValue(undefined)\n }\n\n const spacesQueriesMock = {\n permissions: jest.fn()\n }\n\n const usersQueriesMock = {\n createUserOrGuest: jest.fn(),\n deleteGuestLink: jest.fn(),\n usersWhitelist: jest.fn().mockResolvedValue([]),\n groupsWhitelist: jest.fn().mockResolvedValue([]),\n allUserIdsFromGroupsAndSubGroups: jest.fn().mockResolvedValue([])\n }\n\n const linksQueriesMock = {\n isUniqueUUID: jest.fn(),\n isReservedUUID: jest.fn(),\n allLinksFromSpaceOrShare: jest.fn(),\n createLinkToSpaceOrShare: jest.fn(),\n updateLinkFromSpaceOrShare: jest.fn(),\n linkFromShare: jest.fn(),\n linkFromSpace: jest.fn()\n }\n\n const sharesQueriesMock = {\n permissions: jest.fn(),\n listShareLinks: jest.fn(),\n getShareWithMembers: jest.fn(),\n createShare: jest.fn(),\n updateShare: jest.fn(),\n selectShares: jest.fn(),\n deleteShare: jest.fn(),\n updateMember: jest.fn(),\n updateMembers: jest.fn(),\n shareExistsForOwner: jest.fn(),\n childExistsForShareOwner: jest.fn()\n }\n\n const user = { id: 1, isAdmin: false } as any\n\n beforeAll(async () => {\n const module: TestingModule = await Test.createTestingModule({\n providers: [\n { provide: DB_TOKEN_PROVIDER, useValue: {} },\n { provide: ContextManager, useValue: contextManagerMock },\n { provide: NotificationsManager, useValue: notificationsManagerMock },\n { provide: SpacesQueries, useValue: spacesQueriesMock },\n { provide: UsersQueries, useValue: usersQueriesMock },\n { provide: LinksQueries, useValue: linksQueriesMock },\n { provide: SharesQueries, useValue: sharesQueriesMock },\n SharesManager\n ]\n }).compile()\n\n module.useLogger(['fatal'])\n service = module.get<SharesManager>(SharesManager)\n })\n\n beforeEach(() => {\n jest.clearAllMocks()\n })\n\n it('should be defined', () => {\n expect(service).toBeDefined()\n })\n\n describe('setAllowedPermissions', () => {\n it('sets all operations when the user is the file owner (personal space case)', async () => {\n const share: any = { file: { ownerId: user.id, permissions: '' } }\n await service.setAllowedPermissions(user, share)\n expect(share.file.permissions).toBe(SHARE_ALL_OPERATIONS)\n })\n\n it('uses space permissions when file has a space alias', async () => {\n spacesQueriesMock.permissions.mockResolvedValueOnce({ any: 'thing' })\n const share: any = {\n file: { ownerId: 999, space: { alias: 'space-1', root: { alias: 'root' } }, permissions: undefined }\n }\n await service.setAllowedPermissions(user, share)\n expect(spacesQueriesMock.permissions).toHaveBeenCalledWith(user.id, 'space-1', 'root')\n expect(share.file.ownerId).toBeNull()\n expect(share.file.permissions).toBe('ENV_PERMS')\n })\n\n it('uses parent share permissions when parent alias is present', async () => {\n sharesQueriesMock.permissions.mockResolvedValueOnce({ permissions: 'PARENT_PERMS' })\n const share: any = {\n ownerId: 77,\n parent: { alias: 'parent-share' },\n file: { permissions: undefined }\n }\n await service.setAllowedPermissions(user, share)\n expect(sharesQueriesMock.permissions).toHaveBeenCalledWith(user.id, 'parent-share', +user.isAdmin)\n expect(share.file.permissions).toBe('PARENT_PERMS')\n })\n\n it('throws Bad Request when missing required information', async () => {\n const share: any = { file: {}, parent: {} }\n await expect(service.setAllowedPermissions(user, share)).rejects.toEqual(new HttpException('Missing information', HttpStatus.BAD_REQUEST))\n })\n })\n\n describe('getShareWithMembers', () => {\n it('returns the share and calls setAllowedPermissions', async () => {\n const share: any = { id: 10, file: {} }\n sharesQueriesMock.getShareWithMembers.mockResolvedValueOnce(share)\n const spy = jest.spyOn(service, 'setAllowedPermissions').mockResolvedValueOnce(void 0)\n\n const result = await service.getShareWithMembers(user, 10, true)\n\n expect(result).toBe(share)\n expect(spy).toHaveBeenCalledWith(user, share, true)\n })\n\n it('throws Forbidden when share is not found or not authorized', async () => {\n sharesQueriesMock.getShareWithMembers.mockResolvedValueOnce(null)\n await expect(service.getShareWithMembers(user, 99, false)).rejects.toEqual(new HttpException('Not authorized', HttpStatus.FORBIDDEN))\n })\n })\n\n describe('generateLinkUUID', () => {\n it('loops until a unique UUID is found', async () => {\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValueOnce('aaa').mockReturnValueOnce('bbb')\n\n linksQueriesMock.isUniqueUUID.mockResolvedValueOnce(false).mockResolvedValueOnce(true)\n\n const { uuid } = await service.generateLinkUUID(user.id)\n\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenCalledTimes(2)\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenNthCalledWith(1, user.id, 'aaa')\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenNthCalledWith(2, user.id, 'bbb')\n expect(uuid).toBe('bbb')\n })\n })\n\n describe('getShareLink', () => {\n it('returns the share link and trims unsupported permissions', async () => {\n const shareLink: any = { id: 5, file: { permissions: 'ORIG' } }\n sharesQueriesMock.listShareLinks.mockResolvedValueOnce(shareLink)\n const spy = jest.spyOn(service, 'setAllowedPermissions').mockResolvedValueOnce(void 0)\n\n const result = await service.getShareLink(user, 5)\n\n expect(spy).toHaveBeenCalledWith(user, shareLink)\n expect(result).toBe(shareLink)\n expect(result.file.permissions).toBe('trimmed')\n expect((permissionsUtils.removePermissions as jest.Mock).mock.calls[0][0]).toBe('ORIG')\n })\n\n it('throws Forbidden when link is not found', async () => {\n sharesQueriesMock.listShareLinks.mockResolvedValueOnce(null)\n await expect(service.getShareLink(user, 123)).rejects.toEqual(new HttpException('Not authorized', HttpStatus.FORBIDDEN))\n })\n })\n\n describe('updateLinkFromSpaceOrShare (from API)', () => {\n it('intersects permissions and returns updated link object', async () => {\n const baseLink: any = {\n id: 42,\n name: 'old',\n email: 'x@x',\n requireAuth: false,\n limitAccess: null,\n expiresAt: null,\n permissions: 'OLD',\n shareName: 'OldShare',\n shareDescription: 'OldDesc'\n }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(baseLink)\n jest.spyOn(service, 'getShareLink').mockResolvedValueOnce({ file: { permissions: 'SHARE_PERMS' } } as any)\n ;(intersectPermissions as jest.Mock).mockReturnValue('INTERSECTED')\n linksQueriesMock.updateLinkFromSpaceOrShare.mockResolvedValueOnce(undefined)\n\n const dto: any = {\n permissions: 'NEW_PERMS',\n language: 'fr',\n isActive: false\n }\n\n const result = await service.updateLinkFromSpaceOrShare(user, 7, 55, 1 as any, dto, true)\n\n expect(linksQueriesMock.updateLinkFromSpaceOrShare).toHaveBeenCalled()\n expect(result.permissions).toBe('INTERSECTED')\n expect(result.language).toBe('fr')\n expect(result.isActive).toBe(false)\n })\n })\n\n describe('createGuestLink', () => {\n it('creates guest link with hashed password and returns created user info', async () => {\n ;(commonFunctions.hashPassword as jest.Mock).mockResolvedValue('HASHED')\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValue('RANDOMSEQ')\n usersQueriesMock.createUserOrGuest.mockResolvedValueOnce(99)\n\n const guest = await service.createGuestLink(GUEST_PERMISSION.SHARES, 'plaintext', 'en', true)\n\n expect(usersQueriesMock.createUserOrGuest).toHaveBeenCalled()\n expect(guest.id).toBe(99)\n expect(guest.password).toBe('HASHED')\n expect(guest.role).toBeDefined()\n expect(guest.permissions).toBe(GUEST_PERMISSION.SHARES)\n expect(guest.language).toBe('en')\n expect(guest.isActive).toBe(true)\n })\n\n it('generates a random password and defaults isActive when not provided', async () => {\n ;(commonFunctions.hashPassword as jest.Mock).mockResolvedValue('HASHED-RAND')\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValueOnce('RANDOMSEQ')\n usersQueriesMock.createUserOrGuest.mockResolvedValueOnce(123)\n\n const guest = await service.createGuestLink(GUEST_PERMISSION.SPACES)\n\n expect(commonFunctions.hashPassword).toHaveBeenCalled()\n expect(guest.id).toBe(123)\n expect(guest.isActive).toBe(true)\n expect(guest.language).toBeNull()\n })\n })\n\n describe('getLinkFromSpaceOrShare', () => {\n it('returns a link guest for SPACE type', async () => {\n const lg = { id: 1 }\n linksQueriesMock.linkFromSpace.mockResolvedValueOnce(lg)\n\n const res = await service.getLinkFromSpaceOrShare(user, 11, 22, LINK_TYPE.SPACE)\n\n expect(res).toBe(lg)\n expect(linksQueriesMock.linkFromSpace).toHaveBeenCalledWith(user.id, 11, 22)\n expect(linksQueriesMock.linkFromShare).not.toHaveBeenCalled()\n })\n\n it('returns a link guest for SHARE type', async () => {\n const lg = { id: 2 }\n linksQueriesMock.linkFromShare.mockResolvedValueOnce(lg)\n\n const res = await service.getLinkFromSpaceOrShare(user, 33, 44, LINK_TYPE.SHARE)\n\n expect(res).toBe(lg)\n expect(linksQueriesMock.linkFromShare).toHaveBeenCalledWith(user.id, 33, 44, +user.isAdmin)\n expect(linksQueriesMock.linkFromSpace).not.toHaveBeenCalled()\n })\n\n it('throws when link not found', async () => {\n linksQueriesMock.linkFromSpace.mockResolvedValueOnce(null)\n\n await expect(service.getLinkFromSpaceOrShare(user, 55, 66, LINK_TYPE.SPACE)).rejects.toEqual(\n new HttpException('Link not found', HttpStatus.NOT_FOUND)\n )\n })\n })\n\n describe('updateLinkFromSpaceOrShare (additional branches)', () => {\n it('returns null when no diff and not from API', async () => {\n const link: any = { id: 1, name: 'n', email: 'e', requireAuth: false, limitAccess: null, expiresAt: null }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(link)\n\n const result = await service.updateLinkFromSpaceOrShare(user, 1, 2, LINK_TYPE.SHARE, {}, false)\n\n expect(result).toBeNull()\n expect(linksQueriesMock.updateLinkFromSpaceOrShare).not.toHaveBeenCalled()\n })\n\n it('hashes password and does not leak it when fromAPI is true', async () => {\n const link: any = { id: 1 }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(link)\n ;(commonFunctions.hashPassword as jest.Mock).mockResolvedValueOnce('HASHED')\n ;(linksQueriesMock.updateLinkFromSpaceOrShare as jest.Mock).mockImplementation(async (_link: any, _spaceOrShareId: number, updateUser: any) => {\n // Assert at call time before the service deletes the password\n expect(updateUser).toMatchObject({ password: 'HASHED' })\n return\n })\n\n const result = await service.updateLinkFromSpaceOrShare(user, 1, 2, LINK_TYPE.SHARE, { password: 'secret' }, true)\n\n expect(linksQueriesMock.updateLinkFromSpaceOrShare).toHaveBeenCalled()\n // The returned link must not leak password\n expect(result).toBe(link)\n expect((result as any).password).toBeUndefined()\n })\n\n it('updates multiple link/user fields and ignores equal expiresAt', async () => {\n const base = {\n id: 9,\n name: 'a',\n email: 'b',\n requireAuth: false,\n limitAccess: null,\n expiresAt: { date: '2025-01-01' }\n }\n jest.spyOn(service, 'getLinkFromSpaceOrShare').mockResolvedValueOnce(base as any)\n linksQueriesMock.updateLinkFromSpaceOrShare.mockResolvedValueOnce(undefined)\n\n const dto = {\n name: 'a2',\n email: 'b2',\n requireAuth: true,\n limitAccess: 5,\n expiresAt: { date: '2025-01-01' } // equal, should be ignored\n }\n\n await service.updateLinkFromSpaceOrShare(user, 9, 99, LINK_TYPE.SHARE, dto as any, false)\n\n const [, , , updateLink] = (linksQueriesMock.updateLinkFromSpaceOrShare as jest.Mock).mock.calls[0].slice(0, 5)\n expect(updateLink).toMatchObject({\n name: 'a2',\n email: 'b2',\n requireAuth: true,\n limitAccess: 5\n })\n expect(updateLink.expiresAt).toBeUndefined()\n })\n })\n\n describe('setAllowedPermissions (additional branches)', () => {\n it('sets all operations when share has externalPath and user is admin', async () => {\n const admin = { id: 10, isAdmin: true } as any\n const share: any = { externalPath: '/ext', file: {} }\n await service.setAllowedPermissions(admin, share)\n expect(share.file.permissions).toBe(SHARE_ALL_OPERATIONS)\n })\n\n it('throws NOT_FOUND when space permissions are missing', async () => {\n spacesQueriesMock.permissions.mockResolvedValueOnce(null)\n const share: any = { file: { space: { alias: 'space-x', root: { alias: 'r' } } } }\n\n await expect(service.setAllowedPermissions(user, share)).rejects.toEqual(new HttpException('Space not found', HttpStatus.NOT_FOUND))\n })\n\n it('throws NOT_FOUND when parent share permissions are missing', async () => {\n sharesQueriesMock.permissions.mockResolvedValueOnce(null)\n const share: any = { ownerId: 42, parent: { alias: 'parent' }, file: {} }\n\n await expect(service.setAllowedPermissions(user, share)).rejects.toEqual(new HttpException('Share not found', HttpStatus.NOT_FOUND))\n })\n\n it('uses owner permissions when asAdmin is true', async () => {\n const asAdminUser = { id: 3, isAdmin: false } as any\n sharesQueriesMock.permissions.mockResolvedValueOnce({ permissions: 'ADMIN_PARENT' })\n const share: any = { ownerId: 77, parent: { alias: 'pa' }, file: {} }\n\n await service.setAllowedPermissions(asAdminUser, share, true)\n\n expect(sharesQueriesMock.permissions).toHaveBeenCalledWith(77, 'pa', +asAdminUser.isAdmin)\n expect(share.file.permissions).toBe('ADMIN_PARENT')\n })\n })\n\n describe('getShareLink (additional branch)', () => {\n it('does not trim permissions if file.permissions is falsy', async () => {\n const shareLink: any = { id: 7, file: {} }\n sharesQueriesMock.listShareLinks.mockResolvedValueOnce(shareLink)\n const spy = jest.spyOn(service, 'setAllowedPermissions').mockResolvedValueOnce(void 0)\n\n const res = await service.getShareLink(user, 7)\n\n expect(spy).toHaveBeenCalled()\n expect(res).toBe(shareLink)\n expect(permissionsUtils.removePermissions).not.toHaveBeenCalled()\n })\n })\n\n describe('deleteShare', () => {\n it('throws Forbidden when user is not admin and not owner', async () => {\n sharesQueriesMock.shareExistsForOwner.mockResolvedValueOnce(false)\n\n await expect(service.deleteShare({ id: 2, isAdmin: false } as any, 123)).rejects.toEqual(\n new HttpException('Not authorized', HttpStatus.FORBIDDEN)\n )\n })\n\n it('deletes links and removes shares when authorized (asAdmin)', async () => {\n const deleteLinksSpy = jest.spyOn(service, 'deleteAllLinkMembers').mockResolvedValue(void 0)\n const removeSpy = jest.spyOn<any, any>(service as any, 'removeShareFromOwners').mockResolvedValue(void 0)\n\n await service.deleteShare(user, 456, true)\n\n expect(deleteLinksSpy).toHaveBeenCalledWith(456, expect.anything())\n expect(removeSpy).toHaveBeenCalledWith(456, 'all', false, user.id)\n })\n })\n\n describe('child share wrappers', () => {\n it('getChildShare returns share link when isLink = true', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValueOnce(99)\n const getShareLinkSpy = jest.spyOn(service, 'getShareLink').mockResolvedValueOnce({ id: 99 } as any)\n\n const res = await service.getChildShare(user, 1, 99, true)\n expect(res).toEqual({ id: 99 })\n expect(getShareLinkSpy).toHaveBeenCalledWith(user, 99, true)\n })\n\n it('getChildShare returns child share when isLink = false', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValueOnce(100)\n const getShareSpy = jest.spyOn(service, 'getShareWithMembers').mockResolvedValueOnce({ id: 100 } as any)\n\n const res = await service.getChildShare(user, 1, 100, false)\n expect(res).toEqual({ id: 100 })\n expect(getShareSpy).toHaveBeenCalledWith(user, 100, true)\n })\n\n it('updateChildShare forwards update and deleteChildShare forwards delete', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValue(200)\n const updateSpy = jest.spyOn(service, 'updateShare').mockResolvedValueOnce({ id: 200 } as any)\n const deleteSpy = jest.spyOn(service, 'deleteShare').mockResolvedValueOnce(void 0)\n\n await service.updateChildShare(user, 1, 200, {} as any)\n expect(updateSpy).toHaveBeenCalledWith(user, 200, {} as any, true)\n\n await service.deleteChildShare(user, 1, 200)\n expect(deleteSpy).toHaveBeenCalledWith(user, 200, true)\n })\n\n it('throws Forbidden when not allowed to manage child share', async () => {\n sharesQueriesMock.childExistsForShareOwner.mockResolvedValueOnce(null)\n await expect(service.getChildShare(user, 1, 2, false)).rejects.toEqual(new HttpException('Not authorized', HttpStatus.FORBIDDEN))\n })\n })\n\n describe('createOrUpdateLinksAsMembers', () => {\n it('creates new links for id < 0 and notifies guest', async () => {\n const createLinkSpy = jest.spyOn<any, any>(service as any, 'createLinkFromSpaceOrShare').mockResolvedValue(void 0)\n const notifySpy = jest.spyOn<any, any>(service as any, 'notifyGuestLink').mockResolvedValue(void 0)\n\n const links = [{ id: -1, linkSettings: { uuid: 'u', email: 'e', permissions: 'p' }, permissions: 'p' }] as any\n\n const res = await service.createOrUpdateLinksAsMembers(user, { id: 1, name: 'S' } as any, LINK_TYPE.SHARE, links)\n\n expect(res).toEqual([])\n expect(createLinkSpy).toHaveBeenCalled()\n expect(notifySpy).toHaveBeenCalled()\n })\n\n it('updates modified links and returns them along with unmodified ones', async () => {\n const updateLinkSpy = jest.spyOn(service, 'updateLinkFromSpaceOrShare').mockResolvedValue(void 0)\n\n const members = await service.createOrUpdateLinksAsMembers(user, { id: 1, name: 'S' } as any, LINK_TYPE.SHARE, [\n { id: 2, linkId: 2, permissions: 'p', linkSettings: { name: 'new' } },\n { id: 3, linkId: 3, permissions: 'q' } // unmodified\n ] as any)\n\n expect(updateLinkSpy).toHaveBeenCalledWith(user, 2, 1, LINK_TYPE.SHARE, { name: 'new' })\n expect(members).toHaveLength(2)\n expect(members.map((m: any) => m.id)).toEqual([2, 3])\n })\n })\n\n describe('generateLinkUUID (additional)', () => {\n it('returns immediately when the first UUID is unique', async () => {\n ;(commonFunctions.generateShortUUID as jest.Mock).mockReturnValueOnce('only-one')\n linksQueriesMock.isUniqueUUID.mockResolvedValueOnce(true)\n\n const { uuid } = await service.generateLinkUUID(user.id)\n\n expect(uuid).toBe('only-one')\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenCalledTimes(1)\n expect(linksQueriesMock.isUniqueUUID).toHaveBeenCalledWith(user.id, 'only-one')\n })\n })\n})\n"],"names":["jest","mock","SpaceEnv","fn","mockImplementation","setPermissions","envPermissions","havePermission","haveSpacePermission","removePermissions","actual","requireActual","generateShortUUID","hashPassword","intersectPermissions","describe","SharesManager","name","service","contextManagerMock","headerOriginUrl","notificationsManagerMock","create","mockResolvedValue","undefined","sendEmailNotification","spacesQueriesMock","permissions","usersQueriesMock","createUserOrGuest","deleteGuestLink","usersWhitelist","groupsWhitelist","allUserIdsFromGroupsAndSubGroups","linksQueriesMock","isUniqueUUID","isReservedUUID","allLinksFromSpaceOrShare","createLinkToSpaceOrShare","updateLinkFromSpaceOrShare","linkFromShare","linkFromSpace","sharesQueriesMock","listShareLinks","getShareWithMembers","createShare","updateShare","selectShares","deleteShare","updateMember","updateMembers","shareExistsForOwner","childExistsForShareOwner","user","id","isAdmin","beforeAll","module","Test","createTestingModule","providers","provide","DB_TOKEN_PROVIDER","useValue","ContextManager","NotificationsManager","SpacesQueries","UsersQueries","LinksQueries","SharesQueries","compile","useLogger","get","beforeEach","clearAllMocks","it","expect","toBeDefined","share","file","ownerId","setAllowedPermissions","toBe","SHARE_ALL_OPERATIONS","mockResolvedValueOnce","any","space","alias","root","toHaveBeenCalledWith","toBeNull","parent","rejects","toEqual","HttpException","HttpStatus","BAD_REQUEST","spy","spyOn","result","FORBIDDEN","commonFunctions","mockReturnValueOnce","uuid","generateLinkUUID","toHaveBeenCalledTimes","toHaveBeenNthCalledWith","shareLink","getShareLink","permissionsUtils","calls","baseLink","email","requireAuth","limitAccess","expiresAt","shareName","shareDescription","mockReturnValue","dto","language","isActive","toHaveBeenCalled","guest","createGuestLink","GUEST_PERMISSION","SHARES","password","role","SPACES","lg","res","getLinkFromSpaceOrShare","LINK_TYPE","SPACE","not","SHARE","NOT_FOUND","link","_link","_spaceOrShareId","updateUser","toMatchObject","toBeUndefined","base","date","updateLink","slice","admin","externalPath","asAdminUser","deleteLinksSpy","removeSpy","anything","getShareLinkSpy","getChildShare","getShareSpy","updateSpy","deleteSpy","updateChildShare","deleteChildShare","createLinkSpy","notifySpy","links","linkSettings","createOrUpdateLinksAsMembers","updateLinkSpy","members","linkId","toHaveLength","map","m"],"mappings":"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"}
|
|
@@ -568,10 +568,14 @@ let SharesQueries = class SharesQueries {
|
|
|
568
568
|
ctime: _filesschema.files.ctime,
|
|
569
569
|
mtime: _filesschema.files.mtime,
|
|
570
570
|
mime: _filesschema.files.mime,
|
|
571
|
+
originOwnerId: (0, _drizzleorm.sql)`${originOwner.id}`.as('originOwnerId'),
|
|
571
572
|
originOwnerLogin: (0, _drizzleorm.sql)`${originOwner.login}`.as('originOwnerLogin'),
|
|
573
|
+
originSpaceId: (0, _drizzleorm.sql)`${_spacesschema.spaces.id}`.as('originSpaceId'),
|
|
572
574
|
originSpaceAlias: (0, _drizzleorm.sql)`${_spacesschema.spaces.alias}`.as('originSpaceAlias'),
|
|
575
|
+
originSpaceExternalRootId: (0, _drizzleorm.sql)`${_filesschema.files.spaceExternalRootId}`.as('originSpaceExternalRootId'),
|
|
573
576
|
originSpaceRootExternalPath: (0, _drizzleorm.sql)`IF (${_spacesrootsschema.spacesRoots.externalPath} IS NULL,
|
|
574
577
|
${shareSpaceRoot.externalPath}, ${_spacesrootsschema.spacesRoots.externalPath})`.as('originSpaceRootExternalPath'),
|
|
578
|
+
originShareExternalId: (0, _drizzleorm.sql)`IF (${_sharesschema.shares.externalPath} IS NOT NULL, ${_sharesschema.shares.parentId}, NULL)`.as('originShareExternalId'),
|
|
575
579
|
rootId: (0, _drizzleorm.sql)`${_sharesschema.shares.id}`.as('rootId'),
|
|
576
580
|
rootAlias: _sharesschema.shares.alias,
|
|
577
581
|
rootName: _sharesschema.shares.name,
|
|
@@ -579,6 +583,7 @@ let SharesQueries = class SharesQueries {
|
|
|
579
583
|
rootEnabled: _sharesschema.shares.enabled,
|
|
580
584
|
rootExternalPath: _sharesschema.shares.externalPath,
|
|
581
585
|
rootPermissions: _sharesmembersschema.sharesMembers.permissions,
|
|
586
|
+
rootOwnerId: (0, _drizzleorm.sql)`${_usersschema.users.id}`.as('rootOwnerId'),
|
|
582
587
|
rootOwnerLogin: (0, _drizzleorm.sql)`${_usersschema.users.login}`.as('rootOwnerLogin'),
|
|
583
588
|
rootOwnerEmail: (0, _drizzleorm.sql)`${_usersschema.users.email}`.as('rootOwnerEmail'),
|
|
584
589
|
rootOwnerFullName: (0, _usersschema.userFullNameSQL)(_usersschema.users).as('rootOwnerFullName'),
|
|
@@ -618,9 +623,13 @@ let SharesQueries = class SharesQueries {
|
|
|
618
623
|
mtime: unionAlias.mtime,
|
|
619
624
|
mime: unionAlias.mime,
|
|
620
625
|
origin: {
|
|
626
|
+
ownerId: unionAlias.originOwnerId,
|
|
621
627
|
ownerLogin: unionAlias.originOwnerLogin,
|
|
628
|
+
spaceId: unionAlias.originSpaceId,
|
|
622
629
|
spaceAlias: unionAlias.originSpaceAlias,
|
|
623
|
-
|
|
630
|
+
spaceExternalRootId: unionAlias.originSpaceExternalRootId,
|
|
631
|
+
spaceRootExternalPath: unionAlias.originSpaceRootExternalPath,
|
|
632
|
+
shareExternalId: unionAlias.originShareExternalId
|
|
624
633
|
},
|
|
625
634
|
root: {
|
|
626
635
|
id: unionAlias.rootId,
|
|
@@ -631,6 +640,7 @@ let SharesQueries = class SharesQueries {
|
|
|
631
640
|
externalPath: unionAlias.rootExternalPath,
|
|
632
641
|
permissions: (0, _spacesschema.spaceGroupConcatPermissions)(unionAlias.rootPermissions),
|
|
633
642
|
owner: {
|
|
643
|
+
id: unionAlias.rootOwnerId,
|
|
634
644
|
login: unionAlias.rootOwnerLogin,
|
|
635
645
|
email: unionAlias.rootOwnerEmail,
|
|
636
646
|
fullName: unionAlias.rootOwnerFullName
|