-
Notifications
You must be signed in to change notification settings - Fork 56
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
feat: introducing configurable options #1549
base: master
Are you sure you want to change the base?
Conversation
Signed-off-by: ernolf <[email protected]>
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #1549 +/- ##
============================================
- Coverage 42.63% 34.24% -8.40%
- Complexity 101 132 +31
============================================
Files 19 20 +1
Lines 326 476 +150
============================================
+ Hits 139 163 +24
- Misses 187 313 +126
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
…signature - Added missing IURLGenerator mock to SettingsControllerTest - Replaced Defaults instance with a mock to match constructor arguments Signed-off-by: ernolf <[email protected]>
…rTest - Added missing use statement for IURLGenerator - Ensured all required interfaces are properly mocked Signed-off-by: ernolf <[email protected]>
- Corrected method call to pass only the IUser argument as required by ITotp::createSecret Signed-off-by: ernolf <[email protected]>
- Updated files generated by npm run build to reflect recent changes Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
It has been questioned whether giving users the option to set the token length and hash algorithm might unnecessarily complicate things for them. It was considered whether these values should be predefined by the admin, like the secret length. In that case, the URL transmitted with the QR code would need to include these values. While the URL can indeed include the token length and hash algorithm along with the secret and issuer, very few TOTP apps actually take these parameters into account. For reference, see the description of the Key-Uri-Format in the Google Authenticator wiki. In my opinion, it is more important that TOTP works out-of-the-box with ALL TOTP apps. Therefore, it has been designed so that each new secret is ALWAYS set up with the default values, ensuring immediate compatibility with ALL TOTP apps. Users of advanced TOTP apps, such as Aegis, which allow customization of token length and hash algorithm settings, can now take advantage of these options individually. It is crucial that the values set for token length and/or hash algorithm in the UI are exactly mirrored in the TOTP app for the account. Besides the potential to increase security through a more advanced hash algorithm or a longer token length, the token can also be shortened to as few as 4 digits if desired. Technically, it is even possible to shorten the token length to 1, though this would be too easily compromised. However, a token length of 4 or 5 is still secure, as an attacker would not expect varying token lengths. The warning message is intentionally very generic and can/should certainly be improved, just like the final buttons. This was primarily about the functionality. The graphics and localization now need to be adjusted to fit the overall look of the Security Page, where, in my opinion, there is still much to improve since everyone seems to be doing their own thing. ernolf |
Signed-off-by: ernolf <[email protected]>
I have discussed the feature with the Nextcloud GmbH design lead and product management. Here are some key aspects to consider
I'd say include anything in the QR code string that an app could pick up, as long as it's ignored by the others and doesn't cause compatibility issues. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
First off thanks for your contribution @ernolf!
I just have a question or small thing to add to Christoph’s review: Is it possible to use our Vue components for the elements – e.g. the button looks like an old style.
Although I assume that the app in general needs to be ported over so it might be a separate issue @ChristophWurst?
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]> - enhance warning, error, and info messages for clarity - update mouse behavior for select fields to remove focus on mouseleave - adjust layout to place select fields vertically instead of horizontally - apply theme CSS colors for error, warning, and info messages
…r branch Signed-off-by: ernolf <[email protected]>
…s.vue Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
The colors (here yelow, blue and red) are defined in the css of your theme:
If any changes made, "Recreate QR-Code with custom settings" becomes clickable: Once clicked, a new QR Code is created and can be scanned: After verification with an OTP: The "Advanced Settings" button for subsequent changes is removed now, since it became redundant as it is much easier and safer to apply custom settings via the setup where it can be tested immediately with the OTP. If the QR-code is scanned with Free-OTP or Free-OTP+, the actual favicon wil be used as icon for the account. Since this PR makes it possible to enter a custom secret, #1439 could be closed too. TODO:
|
…syntax conflict Signed-off-by: ernolf <[email protected]>
Would there also be the possibility to set the secret and the other new options over the occ command on console ? |
I've already thought about it, but I wanted to do it in a PR that follows this one. It would build on the functions created here. |
@ernolf |
Just tested again. Impressive work! I'm afraid this goes a bit too far with the complexity. There are advanced settings for the user. This was defined as not acceptable
Could you find a compromise where only the admin needs to know about the advanced options? There are two use cases where I can see stronger options enforced
In both cases it's likely that the person setting up Nextcloud with TOTP could also tell the users which TOTP app they should use, an fine-tune the settings for the best default that work with the app. |
I have completely removed the previous approach, in which the settings could be changed by the user after the secret was created. I fully accepted the concerns about leaving these setting options to the user as they were, as it was possible for a user to render their TOTP unusable and, in the worst case, lock themselves out of their cloud. Everything is now set up in such a way that the default values set by the admin can be safely adopted for every app and it is impossible for the user to adopt incorrect settings, as every setting combination must first be authenticated with an OTP. There are also no dead ends or endless loops in which a user could get lost without being able to find their way out. The only thing that is missing in my opinion is a "Cancel" button, which practically does the same thing as reloading the page without TOTP being activated. The validity period of the one-time passwords can only be changed in a few apps and then again to a different extent from app to app. For this reason, I have refrained from setting a value by the admin, because the default value of 30 seconds is the only value that is supported by all devices. So if the admin is to set this and he sets a TTL of 15 seconds, for example, then as far as I know there is only one app that supports this and I am sure that a large number of admins whould be overwhelmed by this. That is why the only practical solution seemed to me to be the one presented in this approach. occ config:app:set --value=yes -- twofactor_totp enable_advanced_settings and if not explicitly enabled, then it is off. As you can see from the comments, there are also use cases where the user should not be able to see the settings at all, i.e. should not be able to deactivate their TOTP or create a new secret themselves. I imagine making this possible with an occ command and an additional column in the twofactor_totp_secrets database table. In such a case, the admin can then set all individual settings and provide the users with their own preconfigured TOTP devices and switch the visibility on and off individually for each user. |
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
Signed-off-by: ernolf <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So this is getting very complex now, way too complex even for people who know what they are doing. I also looked again into the original issue #26 to check what the requirements and issues are.
Some points:
- Even if it is behind a feature flag, I would like for the interface to be nice and easy. Otherwise it’s basically just going to be a feature that very few people use, but we need to maintain since it’s in the main app.
- If we want to have it as a "we are so secure" point (which is nice), it shouldn’t be behind a feature flag either.
- Ideal would be to just have 2 settings:
- "Default (SHA-1)" setting for compatibility with all OTP apps
- And then the "Enhanced security" setting which uses a better algo with some preset lengths which is also compatible with at least some apps (like Aegis, etc, list of which has to be mentioned next to the setting).
- And it should only be an admin setting as mentioned
Hi @jancborchardt, thank you for your reply
As far as I know, all TOTP apps meanwhile support all three hash algorithms supported by A second default value that the admin can set is the length of the secret. If the admin does not set anything, the standard length of 32 characters applies, which corresponds exactly to the depth of 160 bits recommended by the RFC. The RFC does not allow secrets below 128 bits. For a long time, however, only a 16-character secret was used, which corresponds to a bit depth of 80. So for a long time Then there are two more values:
So much for what the admin can set.
There are apps that support other one-time password token lengths outside of these options and allow other validity periods for the one-time passwords. For example, it is very convenient to work with one-time passwords of 4 digits that are valid for 15 seconds. And so that those who want to use this option also have the opportunity to do so, I have now developed the Advanced Settings, which allow the user to set this on an idiot-proof interface that does not allow the user to set or activate a single thing incorrectly.
It's no longer just about #26, because that's already been resolved as described in the first paragraph of this answer. It's also about #1439 and I've also solved #1407. The rest are features that I wished for a long time and used so far by hacking the code. I am not the type of user that creates feature requests, I create features if I want them and have thought about it a lot. That is what you get
Is that a subtle hint to fork my solution?
Very good! We agree on that point! Here I have a view of the setup window that is shown when you first log in, once with the advanced settings closed and once with the advanced settings opened I have shortened the labels to make it look simpler. I have also used the same names that are usually used in the TOTP apps so that a clear assignment is possible, although this is not necessary since everything is transmitted with the QR code. For an extended explanation of the labels and the associated select fields, I have made a :title that is displayed as a tooltip when you mouse over: example: <label :class="{ centered: center }"
for="digits"
:title="t('twofactor_totp', 'OTP token length')"
@mouseleave="onMouseLeave">
{{ t('twofactor_totp', 'Digits') }}
</label> that looks like this:
Before you get too fixated on "It's all too complex", I would suggest that I demonstrate the feature to you at the Nextcloud conference so that you can "feel" it. ernolf |
This is a better, safer approach to introducing configurable options as initially suggested in #1546
This pull request has changed significantly from the initial approach. Please go to #1549 (comment) for the description of the current, latest state.
This approach has been significantly improved and abandoned as it was here:
To ensure that users are not locked out by admin settings, in this approach the values for Token Length and Hash Algorithm can be set individually by each user:
New secrets are always created with the default values because these are supported in every TOTP app. If you use a high-quality TOTP app like Aegis, you can then adjust the values afterwards. This adjustment must be applied identical both here in the server and in the TOTP app.
The administrator still has the option to set the length of the secrte via occ though, as originally suggested in #1546 and described in the README.md:
Finally, the favicon URL is integrated into the setup URL (QR code) so that apps like FreeOTP that support it can use it as an icon for the account:
ernolf