-
Notifications
You must be signed in to change notification settings - Fork 45
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
Confirm OTP Token #72
Conversation
OK, I have resolved the main errors (#73), and updated the test suite for this change. |
Thanks for the PR. I merged the first one. Can you please rebase and make sure we have green test run? |
bc74ee1
to
6ca8906
Compare
OK, I have rebased. Waiting on the test run now. |
…ow" view to display link to form if otp is disabled;
…ing/enabling Two-Factor-Authentication (rather than separate otp_confirm_tokens);
…te unneeded values;
…it_otp_tokens to "lead_in";
… to "Verification Code";
…r Authentication form;
… than redirecting via otp_credential_path);
…t_confirm block (not needed);
… was enabled, and to check for actual page content rather than flash message content for reliability;
6ca8906
to
1e94af0
Compare
OK, the CI checks are passing now! Let me know if you have any additional requests/comments. |
Ah, sorry about that. I had added a "populate_otp!" method so that existing apps can populate the OTP auth and recovery secrets for each user (since existing users have skipped the create callback), but removed it to try to minimize the delta for this PR. It sounds like it may be necessary after all, though. I will reapply the change and update the README with instructions for existing apps so that you can test it out. |
Interesting. otp_tokens#show should only show the token and secret if otp_enabled? returns true for that user. Is OTP enabled in the database for this user (user.otp_enabled?)? Maybe somehow the otp_enabled boolean got set to "true" in the master branch? |
I'll double check |
@strouptl seems I faced the issue because it does enable OTP but it's not possible to disable it. When I go for disabling it sends me to an edit it seems but in database the |
Hi @strzibny, I just double checked, and it is working for me, so I am still thinking you must have enabled OTP somehow in the master branch. Perhaps it is indeed better to populate the OTP secrets as needed in the otp_tokens#edit action, though, as it would resolve potential confusion like this altogether. Here are the steps I followed, if you still want to verify them for the current issue you are seeing: First round (without populated secrets)
Second round (with populated secrets)
|
@strzibny, or are you wondering about how to disable OTP with the new functionality? In master, you do indeed use a form for both enabling and disabling OTP. However, with the new functionality, the edit action and the form it displays are only for enabling OTP. To disable OTP, you must click the "Reset your Two Factors Authentication status" button, which points to the "destroy" action. This follows the same workflow as AWS, where disabling 2FA == removing your secret, as well. |
# | ||
# Updates the status of OTP authentication | ||
# | ||
def update | ||
enabled = params[resource_name][:otp_enabled] == "1" | ||
if enabled ? resource.enable_otp! : resource.disable_otp! |
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.
I think is the broken behaviour I am seeing. Before your change you could temporarily disable OTP and I think we should preserve the functionality for the time being.
I confirm that completely removing it works and commented inline where I think it's broken for the simple 'disabling of OTP'. Any reason why it shouldn't stay there? |
I think the argument would be that there is no way to distinguish between temporarily and permantly disabling MFA. For example, a person could click "disable 2FA" intending to reenable it shortly, but then change authenticator devices, and then come back a month later to reenable OTP not realizing that they lost the secret. So we need to require a confirmation code anytime we enable OTP. And if this is the case, we might as well reset the secrets so that there is no confusion over whether you need to scan the QR code or not at the "Enable 2FA" form. Maybe the "Reset functionality" is the one that needs to change. Could we use the current button and destroy action for disabling OTP, and add a new "reset" action which resets your secrets and disables OTP, but then redirects you to the enable OTP form so that you can obtain your new QR Code/secret? |
We could do a fuller survey to see how others have handled this, but it looks to me like both AWS and Authy do not allow temporarily disabling MFA (i.e. they will always reset the secret). |
Yes that's fair. We'll just document the change and cancel it then. |
Sorry for the confusion. Are you still good with this solution? |
Yes, I am on board. But let's populate the secret on edit so nobody has to go running some code in the terminal (especially for production) |
Sounds good! I'll update the PR with the new functionality.
…On Mon, May 20, 2024 at 6:35 AM Josef Strzibny ***@***.***> wrote:
Yes, I am on board. But let's populate the secret on edit so nobody has to
go running some code in the terminal (especially for production)
—
Reply to this email directly, view it on GitHub
<#72 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AATPWQY52MOEUP2J2CBDYZDZDELJVAVCNFSM6AAAAABH4JVAD6VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCMJZGM3DMNRSGY>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
…e method to "populate_otp_secrets!", replace reset_otp_credentials! method with destroy_otp_secrets!, and remove "on create" callbacks for consistency;
…s for existing users from README (no longer needed);
…ce it includes counters and challenges as well);
Hi @strzibny, I have updated the PR so that the system operates on the assumption that nobody has OTP credentials unless they need them (i.e. by clicking "Enable..."). See details below, and let me know if you have any thoughts!
|
Looking good! As a last thing can you write an entry for https://github.com/wmlele/devise-otp/blob/master/CHANGELOG.md? I am missing last two versions but I'll update it retrospectively, you can put the new version as 'Unreleased'. I think we should mention all removed I18n keys as well as new ones, the new |
…ting OTP secrets as needed;
…scope singular; fix spelling issue in "Enable Two Factor Authentication" link; expand "Changes to Locales" description in CHANGELOG;
Done. |
Thank you @strouptl |
My pleasure! |
Hi there,
I think it is standard now to confirm that the user has properly configured the OTP token in their devise before enabling it. Otherwise, if they navigate away from the page without actually scanning the QR code or saving the recovery tokens, then they will be locked out of their account.
I have scaffolded a solution for this that simply asks you to enter a OTP successfully before actually enabling Two Factor Authentication. The key changes are as follows:
Please let me know if you like this solution. Also, please let me know if you have any information on the current status of the test suite: currently hitting an error and a number of deprecation notices with Rails 7.1.3/Ruby 3.2.3.
NOTE: this PR includes #73 .
Thanks!