Flask Boilerplate - Email Confirmation, Update Password
The article presents the latest authentication improvements added to the reference Flask Boilerplate: password recovery and email confirmation during the registration process.
data:image/s3,"s3://crabby-images/cd0cd/cd0cd0ef514f1f8f9cdd05a95193c32a92f94169" alt="Flask Codebase - Authentication Improvements."
Hello! This article presents the latest improvements provided to our reference Flask Codebase used by all Flask Dashboards (free & pro) provided by AppSeed. The product can be downloaded from Github and used for hobby & commercial products based on the permissive MIT license. For newcomers, Flask is a lightweight and popular web framework crafted on top of Python used for any kind of project and web apps: simple sites, APIs, microservices, or complex eCommerce solutions.
Thanks for reading! Here is the summary of recent update
- #1 - Confirmation email for registration (optional via config)
- #2 - Password recovery flow
Confirmation email for registration
This feature allows validating the email used by a user during a registration process. The flow is optional and by default is disabled. Let's visualize how it works.
Feature is inactive (default configuration)
- The user creates a new account
- The user is able to Sign IN without email confirmation
data:image/s3,"s3://crabby-images/bbf7e/bbf7e8c30e858852fd388e2f5f188aad7e23df39" alt="Flask Codebase Registration - No Email Confirmation"
This flow is the classic, simple Sign IN process. The problem that might occur is the pollution of the app with fake accounts.
Feature is active in configuration:
# apps/config.py - Partial Content
...
EMAIL_CONFIRMATION_REQUIRED = True # Default value: False
...
During the registration process the app checks if the feature is active and warns the user to activate his account via email:
data:image/s3,"s3://crabby-images/8f18b/8f18bd7dc36482dde3c56164846f77cee458bb83" alt="Flask Codebase - Registration Process"
If the registration is successful the user is informed about the result and invited to confirm the email address.
data:image/s3,"s3://crabby-images/00a96/00a968cf94ed3a96fe6b3521490a51ad40adfdf8" alt=""
The source code is licensed under MIT license and can be used by anyone without a source code credit to AppSeed,
Password Recovery
Registered users are able to update their passwords using a simple flow:
- The user should have an active account
- The user should have access to the email address
- The user completes his email address in the
forgot-password
page - The app sends a unique link using the provided email
- The User is able to update the password.
data:image/s3,"s3://crabby-images/276df/276dfadea2e09a9dc0e81da72f3007f49fe87f91" alt="Flask Codebase - Reset Password"
Reset Password - Confirm the email address
data:image/s3,"s3://crabby-images/b2691/b2691aa2c4d605192e498bcd0fff7c38a7a5e93d" alt="Flask Reset Password - Specify the Email"
Reset Password - Confirmation Page
data:image/s3,"s3://crabby-images/9591b/9591bea2148fc819d562ef464d44fe8ff6cb8c00" alt="Flask Reset Password - Set New Password"
If the operation is successful, the user is redirected to the Sign IN page:
data:image/s3,"s3://crabby-images/4f692/4f692970c5a89dd7c607aa9e67c6335bbf293447" alt="Flask Reset Password - Password Updated."
Thanks for reading! For more resources or support please access:
- Flask Codebase - Source Code
- Ask for support - free for registered users
- See more Flask Dashboards and Apps provided by AppSeed