Add .well-known config option to force disable encryption on room creation (#11120)

* force disable encryption on room creation

* test allowChangingEncryption

* move into utils/room directory

* tests

* unit test CreateRoomDialog

* remove debug

* wait for constructor promises to settle

* test case for force_disable

* comment

* set forced value after resolving checkUserIsAllowedToChangeEncryption

* tidy and comments

* use label text in test
This commit is contained in:
Kerry 2023-06-22 09:50:01 +12:00 committed by GitHub
parent 9d9c55d92e
commit a692fe2181
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 375 additions and 9 deletions

View file

@ -81,6 +81,26 @@ describe("<CreateRoomDialog />", () => {
);
});
it("should use server .well-known force_disable for encryption setting", async () => {
// force to off
mockClient.getClientWellKnown.mockReturnValue({
"io.element.e2ee": {
default: true,
force_disable: true,
},
});
getComponent();
await flushPromises();
expect(getE2eeEnableToggleInputElement()).not.toBeChecked();
expect(getE2eeEnableToggleIsDisabled()).toBeTruthy();
expect(
screen.getByText(
"Your server admin has disabled end-to-end encryption by default in private rooms & Direct Messages.",
),
);
});
it("should use defaultEncrypted prop", async () => {
// default to off in server wk
mockClient.getClientWellKnown.mockReturnValue({
@ -96,6 +116,53 @@ describe("<CreateRoomDialog />", () => {
expect(getE2eeEnableToggleIsDisabled()).toBeFalsy();
});
it("should use defaultEncrypted prop when it is false", async () => {
// default to off in server wk
mockClient.getClientWellKnown.mockReturnValue({
"io.element.e2ee": {
default: true,
},
});
// but pass defaultEncrypted prop
getComponent({ defaultEncrypted: false });
await flushPromises();
// encryption disabled
expect(getE2eeEnableToggleInputElement()).not.toBeChecked();
// not forced to off
expect(getE2eeEnableToggleIsDisabled()).toBeFalsy();
});
it("should override defaultEncrypted when server .well-known forces disabled encryption", async () => {
// force to off
mockClient.getClientWellKnown.mockReturnValue({
"io.element.e2ee": {
force_disable: true,
},
});
getComponent({ defaultEncrypted: true });
await flushPromises();
// server forces encryption to disabled, even though defaultEncrypted is false
expect(getE2eeEnableToggleInputElement()).not.toBeChecked();
expect(getE2eeEnableToggleIsDisabled()).toBeTruthy();
expect(
screen.getByText(
"Your server admin has disabled end-to-end encryption by default in private rooms & Direct Messages.",
),
);
});
it("should override defaultEncrypted when server forces enabled encryption", async () => {
mockClient.doesServerForceEncryptionForPreset.mockResolvedValue(true);
getComponent({ defaultEncrypted: false });
await flushPromises();
// server forces encryption to enabled, even though defaultEncrypted is true
expect(getE2eeEnableToggleInputElement()).toBeChecked();
expect(getE2eeEnableToggleIsDisabled()).toBeTruthy();
expect(screen.getByText("Your server requires encryption to be enabled in private rooms."));
});
it("should enable encryption toggle and disable field when server forces encryption", async () => {
mockClient.doesServerForceEncryptionForPreset.mockResolvedValue(true);
getComponent();