| At line 1 changed one line | 
| In CrushFTP version 10 we can integrate our One Time Password (__[OTP|OTP Settings]__) based authentication feature with Google's and Microsoft's software-based token device __Google Authenticator and Microsoft Authenticator__, using Time based OTP (TOTP). The user can register a QR code into Google Authenticator or Microsoft Authenticator app.\\ | 
| CrushFTP has One Time Password (__[OTP/MFA|OTP Settings]__) based authentication feature with Authenticator software-based token device (__Google Authenticator__ and __Microsoft Authenticator__), etc, using Time based OTP (TOTP) / MFA. The user can register a QR code into their Authenticator app.\\ | 
| At line 3 changed 2 lines | 
| !!Server side configuration\\ | 
| You will need to enable one of our __[OTP|OTP Settings]__ methods, using SMS or Mail based OTP, and enable the __Validated logins__ checkbox. The user needs to be able to log in at least once, without OTP, or with the other __[OTP|OTP Settings]__ settings.\\ | 
| !!1. Server side configuration\\ | 
| The config needs the URL set to __SMTP__ and the checkbox for __Validated Logins__ enabled.\\ | 
| At line 8 changed one line | 
| The second step is to configure the user account with __Two Factor Authentication__\\ | 
| Next enable the two factor __QR code generator__ which will appear in the user's __User Options__ menu when they are logged in.\\ | 
| At line 10 changed one line | 
| [attachments|servercfg002.png]\\ | 
| [attachments|enable_two_factor.png]\\ | 
| * You can also force two factor registration, then the user has no choice but to enroll in it at their next login.  Set the customization flag __Two Factor: force Authenticator setup__ to true.  See the mini animated gif of the process below.\\ | 
| At line 12 changed one line | 
| and enable the two factor __QR code generator__ which will appear in the user's __User Options__ menu when they are logged in.\\ | 
| !!2. Client / token device configuration\\ | 
| The user will need to log in normally, generate the QR code from the client UI __User Options__ menu.\\ | 
| At line 14 changed one line | 
| [attachments|servercfg003.png]\\ | 
| [attachments|qr_otp.png]\\ | 
| At line 16 changed 2 lines | 
| !!Client / token device configuration\\ | 
| The user will need to log normally, generate the QR code from the client UI __User Options__ menu.\\ | 
| __This part must be done within 30 seconds or the QR code becomes invalid.__\\ | 
| 1.) Once they are ready and have the Authenticator app open on their mobile device, they click __Ready To Scan__.\\ | 
| 2.) Choose to scan the QR code, point the device towards the screen, and let it read in the QR code.\\ | 
| 3.) Next click __Confirm__ to save the same code to the server's user configuration.\\ | 
| At line 19 changed one line | 
| [attachments|servercfg004.png]\\ | 
| Google Authenticator\\ | 
| [{Image src='tokencfg002.png' width='272px' height='..' align='left'}]  [{Image src='tokencfg003.png' width='272px' height='..' align='left'}]\\ | 
| At line 21 changed 3 lines | 
| Then open __Authenticator__ on the mobile device, set up new account, choose barcode, point the device towards the screen, read in the QR code. Then save the user settings by clicking the __Confirm__ button in the UI. \\ | 
| \\ | 
| [{Image src='tokencfg001.png' width='272px' height='..' align='left'}]  [{Image src='tokencfg002.png' width='272px' height='..' align='left'}]  [{Image src='tokencfg003.png' width='272px' height='..' align='left'}]\\ | 
| Microsoft Authenticator\\ | 
| [{Image src='IMG_2500.jpg' width='272px' height='..' align='left'}]  [{Image src='IMG_2501.jpg' width='272px' height='..' align='left'}]  [{Image src='IMG_2502.jpg' width='272px' height='..' align='left'}]\\ | 
| At line 25 changed one line | 
| __WARNING:__ the QR code is valid for one minute, if the time window is missed you will need to generate new, or it will not save. Once a secret key has been saved from the QR code, and confirmed, it can only be reset by a server administrator.  Its a one time process.\\ | 
| __WARNING:__ the QR code is valid for 30 seconds, if the time window is missed you will need to generate new, or it will not save. Once a secret key has been saved from the QR code, and confirmed, it can only be reset by a server administrator.  It's a one-time process.\\ | 
| At line 29 changed 2 lines | 
| !!Possible scenarios regarding the cooperation of admin and the end-user: | 
|  | 
| !!3. Possible scenarios regarding the cooperation of admin and the end-user:\\ | 
| \\ | 
| At line 32 changed one line | 
|  | 
| \\ | 
| At line 34 changed 2 lines | 
| -in the User Manager -> user -> Webinterface -> Available customizations section the "Enable two factor registration" is set to True. This can be enabled on the "default" template account or on the group template account so all other users will inherit the setting from the template user.\\ | 
| -on Preferences -> General Settings -> OTP section the "Validated Logins" option must be enabled (A on the first screenshot)\\ | 
| -in the User Manager -> user -> Webinterface -> Available customizations section the __Enable two factor registration__ is set to True. This can be enabled on the __default__ template account or on the group template account so all other users will inherit the setting from the template user.\\ | 
| -on Preferences -> General Settings -> OTP section the __Validated Logins__ option must be enabled (A on the first screenshot)\\ | 
| At line 40 changed 2 lines | 
| The option of "Google Authenticator Auto Enable" on Preferences -> General Settings -> OTP section is enabled (B on the first screenshot). | 
| In User Manager the "Two factor OTP/SMS authentication" option is disabled. | 
| The option of __Google Authenticator Auto Enable__ on Preferences -> General Settings -> OTP section is enabled (B on the first screenshot). | 
| In User Manager the __Two factor OTP/SMS authentication__ option is disabled. | 
| At line 43 changed 2 lines | 
| The end-user logs in with username and password, and initializing the "Setup of 2 factor auth" via the User Options button, scans the QR code, and hits the Confirm button. | 
| In the background, CrushFTP writes the Two factor authentication Secret to the user account and takes care of enabling the "Two factor OTP/SMS authentication" option for the user. | 
| The end-user logs in with username and password, and initializes the __Setup of 2 factor auth__ via the User Options button, scans the QR code, and hits the Confirm button. | 
| In the background, CrushFTP writes the Two factor authentication Secret to the user account and takes care of enabling the __Two factor OTP/SMS authentication__ option for the user. | 
| At line 47 changed 2 lines | 
| The option of "Google Authenticator Auto Enable" on Preferences -> General Settings -> OTP section is left in disabled state. | 
| In User Manager the "Two factor OTP/SMS authentication" option is enabled by the admin. | 
| The option of __Google Authenticator Auto Enable__ on Preferences -> General Settings -> OTP section is left in disabled state. | 
| In User Manager the __Two factor OTP/SMS authentication__ option is enabled by the admin. | 
| At line 53 changed 2 lines | 
| The option of "Google Authenticator Auto Enable" on Preferences -> General Settings -> OTP section is left in disabled state. | 
| In User Manager the user doesn't have the "Two factor OTP/SMS authentication" option enabled | 
| The option of __Google Authenticator Auto Enable__ on Preferences -> General Settings -> OTP section is left in disabled state. | 
| In User Manager the user doesn't have the __Two factor OTP/SMS authentication__ option enabled | 
| At line 56 changed 2 lines | 
| The end-user logs in with username and password, and initializing the Setup of 2 factor auth via the User Optons button, scans the QR code, and hits the Confirm button. | 
| In the background CrushFTP writes the Two factor authentication Secret to the user account, but the Admin needs to activate the "Two factor OTP/SMS authentication" option for the user. | 
| The end-user logs in with username and password, and initializes the Setup of 2 factor auth via the User Options button, scans the QR code, and hits the Confirm button. | 
| In the background, CrushFTP writes the Two-factor authentication Secret to the user account, but the Admin needs to activate the __Two factor OTP/SMS authentication__ option for the user. | 
| At line 60 changed one line | 
| __[DMZ|DMZ]__ - Main node scenario: on Preferences -> General Settings -> OTP section the "Validated Logins" option must be enabled on the DMZ node, so the DMZ gives the two-factor authentication to the Main node. | 
| __[DMZ|DMZ]__ - Main node scenario: on Preferences -> General Settings -> OTP section the __Validated Logins__ option must be enabled on the DMZ node, so the DMZ gives the two-factor authentication to the Main node. | 
| \\ | 
| ---- | 
| \\ | 
| Google Authenticator for Webinterface logins only, enrolling is not possible via FTP, SFTP. | 
| A hidden flag in __prefs.XML__ controls for which protocols OTP should be enabled by default | 
| {{{ | 
| <twofactor_secret_auto_otp_enable_protocols>ftp,ftps,sftp,http,https,webdav</twofactor_secret_auto_otp_enable_protocols> | 
| }}} | 
| \\ |