Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enforced end to end encryption is scary and too complicated for normal users #13537

Closed
mlaily opened this issue May 6, 2020 · 14 comments
Closed

Comments

@mlaily
Copy link

mlaily commented May 6, 2020

End to end encryption is hard to explain and justify to normal users.

It currently complicates things a lot, and adds the risk to lose data, which IMO is far more real and occurs far more often than the risk of the server spying on you...

Self-hosting Riot and Matrix already provides more security than other commercial chats.

If/Until end to end encryption can be more transparent to end users, home server admins and/or end users should have the ability to opt-out of it.

I think making this hassle mandatory is a sure way to slow down Matrix and Riot adoption for everybody, and I think it's a pity!

newlogin
newlogin2
login
nagging

Screenshot_20200506-103158

(I filed this under UX/UI bug because the problem is not e2ee, it's the way it currently impair usability)

(Since this issue impacts all the Riot applications, I'm only creating one for the web app, but I have the same concerns for the Android, iOS, and Desktop apps...)

Also see https://github.com/vector-im/riot-web/issues/8067, https://github.com/vector-im/riot-web/issues/9256, matrix-org/synapse#4401, matrix-org/synapse#4367, and others...

@mlaily mlaily changed the title End to end encryption is scary and too complicated for normal users Enforced end to end encryption is scary and too complicated for normal users May 6, 2020
@Bun-Bun
Copy link

Bun-Bun commented May 6, 2020

I agree completely.

E2E encryption is overly complex and is not needed for most situations. Having users permanently locked out of their data on my server is unacceptable.

@turt2live turt2live self-assigned this May 6, 2020
@squidink7
Copy link

Exactly, although I think the issue is not to turn it back off, but to make it indistinguishable from non e2e, and that means getting rid of the SSSS password, because many users have trouble remembering one password, and 2 is just overkill. Honestly from an end users point of view messengers like whatsapp and telegram are more secure, because e2e makes Riot feel like the kind of thing used by drug-dealers over the dark web (which was an actual quote from one of my friends who I convinced to move to Riot.)

@fti7
Copy link

fti7 commented May 7, 2020

Yesterday we also enabled Cross Signing on all our Team Accounts/Devices.
Allthought i really like the generall Cross Signing Feature (Thanks for that!) - The UI Flow is a pain.
Even my technical People didnt directly(intuitive) understand it and asked me several times what the UI now wants them to do....

E2EE is complex, why not invest time and money in a proper Migration/Setup Wizard? (Like Showing in which State you are (Wizard Steps), Description for non-tech People

Or for "Verify this Login" Dialog -
For several ones it wasnt clear that "Opening RiotX on Android" or using the Recovery Key approach are two different Options.
Why not have two Big Buttons with Description in front of it (Wizard) with the Options they can choose. With direct Instruction what they should do now (e.g. Open the App on the Phone - yes sounds silly, but there are non-tech people arround)

@benqrn
Copy link

benqrn commented May 11, 2020

The UI experience has come a long way, but not far enough for E2EE to be enabled by default and requiring all users to hang on to two separate passwords.

Non-savvy users will at some point need their password reset because they forgot it, and they're certainly not going to remember a second password that cannot be reset (or if they did save the recovery key, they lost it a long time ago).

Yes, making things easier comes at the expense of security, but if the goal is mass adoption, it needs to be simpler. Matrix still requires the typical user to have a technical understanding beyond what a typical messaging app requires.

Some suggestions;

  • Enforcing E2EE by default is an option the homeserver admin can toggle
  • Ability to disable E2EE encryption on a per-room basis
  • E2EE key backup is enabled by default and accessed by the account login by default, the user can then set a separate unique password for key backup if desired

@ptman
Copy link
Contributor

ptman commented May 12, 2020

e2ee can be disabled when creating a room, but not disabled after it has been enabled for a room

@benqrn
Copy link

benqrn commented May 12, 2020

e2ee can be disabled when creating a room, but not disabled after it has been enabled for a room

In riot-web, yes, but in the phone app, no.

The point though is that a user who does not understand the repercussions of having E2EE enabled, is somewhat likely to lose their message history if they do not set up key backup, or if they do set it up but then lose their key password. Those messages will be lost, and there is currently no option for server admin to help.

@MurzNN
Copy link
Contributor

MurzNN commented May 15, 2020

In matrix-org/matrix-spec-proposals#2544 I describe the problem, that can leak SSS passwords on server side for most regular users on homeserver, that use same password for both places. So current implementation with two passwords is not good for users. We can enforce fill different passwords, but this will be even worse for UX :(

@pv
Copy link

pv commented May 15, 2020

How do apps such as Signal manage with a single password? Is it just that because their apps basically never log out except on device changes, they rely on side channel assisted key exchange (as Riot cross-signing??) when activating new devices? And otherwise, they use an autogenerated backup "passphrase" so there's no room for user mistake?

@andrewhotlab
Copy link

@mlaily I'm absolutely with you about this. It's a shame to admit that for such a stupid "entry barrier" for newcomers, Matrix is losing a lot of potential users out there.
I think that at least element-web should leave the ability to disable these confusing messages after the user dismiss them for the first time (a sort of "do not ask me again" checkbox).

@dbkr
Copy link
Member

dbkr commented Sep 25, 2020

If/Until end to end encryption can be more transparent to end users, home server admins and/or end users should have the ability to opt-out of it.

element-hq/element-meta#1442 seems like it would alleviate these concerns, so I'm closing this in favour of that issue. Delayed SSSS setup should help too, removing the passphrase/key creation from the account setup flow.

@dbkr dbkr closed this as completed Sep 25, 2020
@mlaily
Copy link
Author

mlaily commented Sep 27, 2020

element-hq/element-meta#1442 seems like it would alleviate these concerns, so I'm closing this in favour of that issue.

This is disappointing. element-hq/element-meta#1442 is about preventing users from opting into e2ee, which is way stricter than simply allowing server admins to disable enforced e2ee by default (including e2ee setup) on their instance, which is what my issue is about...

I understand the eagerness to close issues about e2ee, but I feel like the root of the problem has still not been addressed yet.

EDIT: I hope you are right about delayed SSSS, and #13895 will be sufficient.

@tim-seoss
Copy link

@mlaily I would be interested to know your thoughts on #15416 and whether or not you think this would be sufficient to partly or wholly mitigate the problems?

@mlaily
Copy link
Author

mlaily commented Oct 9, 2020

@tim-seoss
Honestly, I'd rather have the ability to disable E2EE for users for who this feature is actually an anti-feature (and will be for as long as it isn't transparent, which I'm not even sure is possible), but any improvement on the UX is a step in the right direction.

In my opinion, the challenge is convincing people the trade offs of E2EE are actually worth it, when they don't think they need it, and they see simpler apps from the competition...

@mlaily
Copy link
Author

mlaily commented Nov 8, 2020

I know this issue is closed, but as a quick follow-up:

I hope you are right about delayed SSSS, and #13895 will be sufficient.

I no longer get verification prompts during a session! yay!

But I still get prompted to verify my session when signing in, though I have no use for this (maybe #15672):
image

I still get prompted to backup keys when signing out, though I don't use E2EE anywhere (#11684):
image

So it's better now, but unfortunately not sufficient, and I'm still stuck with Riot 1.5.15 for a little while longer...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests