Jeff Wong f4f8a293e7 FEATURE: Implement 2factor login TOTP
implemented review items.

Blocking previous codes - valid 2-factor auth tokens can only be authenticated once/30 seconds.
I played with updating the “last used” any time the token was attempted but that seemed to be overkill, and frustrating as to why a token would fail.
Translatable texts.
Move second factor logic to a helper class.
Move second factor specific controller endpoints to its own controller.
Move serialization logic for 2-factor details in admin user views.
Add a login ember component for de-duplication
Fix up code formatting
Change verbiage of google authenticator

add controller tests:
second factor controller tests
change email tests
change password tests
admin login tests

add qunit tests - password reset, preferences

fix: check for 2factor on change email controller
fix: email controller - only show second factor errors on attempt
fix: check against 'true' to enable second factor.

Add modal for explaining what 2fa with links to Google Authenticator/FreeOTP

add two factor to email signin link

rate limit if second factor token present

add rate limiter test for second factor attempts
2018-02-21 09:04:07 +08:00
..
2017-07-28 10:20:09 +09:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-08-16 10:38:11 -04:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-03-22 14:26:53 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-07-28 10:20:09 +09:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2016-12-12 17:29:54 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-10-06 11:13:01 +08:00
2018-02-20 14:28:58 +08:00
2016-12-22 16:46:53 +11:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2016-11-24 10:13:03 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-09-07 15:15:29 +02:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-08-29 10:48:22 -04:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-07-28 10:20:09 +09:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-03-22 14:26:53 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2017-08-16 10:38:11 -04:00
2018-02-20 14:28:58 +08:00
2018-02-21 09:04:07 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00
2018-02-20 14:28:58 +08:00