When building an application, it is critical to ensure that the users who are signing up for services or products are real users. By using Auth0, email verification services are provided out of the box; however, wouldn't it be better if verification emails didn't have to be sent at all? By using a combination of Kickbox and Auth0 Hooks, user email addresses can be validated without sending any emails.
How does Kickbox work?
Kickbox is an email technology company with products that help verify email addresses and prevent fake sign-ups applications.
To create a free account, we can visit the Kickbox sign-up page.
"Kickbox ensures we only send email to real users and helps us separate the low-quality addresses from high-value contacts."
Tweet This
Preparing an Auth0 Tenant to Integrate with Kickbox
To demonstrate the integration of Kickbox with Auth0, we are going to use an existing Auth0 Tenant.
If you haven't already done so, sign up for a free Auth0 account here.
Since we don’t want an email verification to be sent any more, we need to deactivate that option in the tenant. On the left sidebar of the Auth0 Dashboard, let's click on Emails first and then on Templates to get to the Email Templates section. In this section, the Verification Email template should be selected by default. Find the Status toggle and turn it off.
We are now ready to add an Auth0 hook and integrate Kickbox.
Kickbox Sendex™ Email Quality
As stated in the Kickbox documentation, Kickbox provides us with a Sendex value which is an indicator of the quality of an email address. The existence or syntactical correctness of an email address does not indicate its quality. For example, john.smith@example.com
can generally be seen as a higher quality email address than sdfsdfsdf@example.com
.
Kickbox uses a number of algorithms, derived from the millions of email transactions it performs each hour, to determine the overall quality of an email address. These are some of the characteristics Kickbox considers when classifying the quality of an email address:
Is the email address similar to a known, high-quality, valid email address? The Kickbox platform is always evaluating and learning what patterns good email addresses employ. Its evolving data is used to provide insight into the overall quality of a given address.
Is the email address domain a commercial domain (example:
acme.com
) or a personal domain (example: yahoo.com
)?Does the email address appear to be associated with a role (example:
postmaster@example.com
) instead of a person (example:bob.smith@example.com
)?
The Sendex value ranges from a 0
(no quality) to 1
(excellent quality). The value of a good Sendex score depends on the specific purpose of the application. For a transactional email the following criteria may be applied:
1.00 - 0.55 = Good
0.54 - 0.20 = Fair
0.19 - 0.00 = Poor
While the Sendex code is useful to verify the quality of an email address, using it in a pre-registration hook could be problematic. In our case, we will want to validate the authenticity of the email, not the quality. To achieve this, Kickbox provides us with other useful information. We will use two of the properties that are provided by Kickbox to validate the email:
The
result
property will tell us if this email will actually be delivered or if it's from a risky source. In our case, we will validate that this email is notundeliverable
.The
disposable
property will tell us if this email comes from a service that offers disposable email addresses.
Using these two properties with a pre-registration hook, we'll determine if we'll either create the user account or send an error at the moment of the sign-up.
Building an Auth0 Hook
Auth0 Hooks allow us to customize the behavior of Auth0 using Node.js code that is executed against extensibility points (which are comparable to webhooks that come with a server). Hooks give us modularity when configuring our Auth0 implementation and extend the functionality of base Auth0 features.
On the left sidebar in the Auth0 Dashboard, let's click on Hooks. In the Hooks page, we will find different places where we can add a hook in the user login or sign-up life cycle. The one we are interested in is the Pre User Registration hook. We want to verify a user email before they register into our system.
To create a new hook, let's do the following:
Click on the Create New Hook button.
Give the hook a name.
Select "Pre User Registration" from the "Hook" drop-down field.
Click on the "Create" button.
Our newly created Auth0 hook will be shown under the "Pre User Registration" section with a green dot before its name. To edit it, let's click on the pencil button in the row below it.
We are taken to the Webtask editor where we can easily edit our hook logic within the Auth0 Dashboard. In here, we will be able to edit the code that gets executed every time a new user registers. We can add new metadata to our users and return this or we can throw an error which will prevent the user registration.
We can remove all the default code that is there to start with an empty hook. The first thing that we will need is the function that will be executed upon a new user registration:
module.exports = function(user, context, callback) {};
When our code execution is done, it will need to return the callback
function with either an error or a valid response. So let’s add this:
module.exports = function(user, context, callback) {
const response = {};
response.user = user;
callback(null, response);
};
In order to connect to the Kickbox service, we will need to do a GET
request using the Node request
module. We can add that at the top of our code just before the module.exports
:
const request = require("request");
module.exports = function(user, context, callback) {
// ...
};
The Kickbox email verification API is fairly simple to use. We simply make a GET
call to the following endpoint:
https://api.kickbox.com/v2/verify?email=<email>&apikey=<API_KEY>
In the URL above, <email>
is the address that we want to verify and <API_KEY>
is our Kickbox API key.
Let’s build the GET
request:
const request = require("request");
module.exports = function(user, context, callback) {
const response = {};
response.user = user;
const API_KEY = context.webtask.secrets.KICKBOX_API_KEY;
const email = user.email;
const url = `https://api.kickbox.com/v2/verify?timeout=6000&email=${email}&apikey=${API_KEY}`;
request.get({ url }, function(err, resp, body) {
// Process the response and send back the callback
callback(null, response);
});
};
Now, we will automatically reject any email address that comes from a disposable email service or email addresses that are known to be undeliverable:
const request = require("request");
module.exports = function(user, context, callback) {
const response = {};
response.user = user;
const API_KEY = context.webtask.secrets.KICKBOX_API_KEY;
const email = user.email;
const url = `https://api.kickbox.com/v2/verify?timeout=6000&email=${email}&apikey=${API_KEY}`;
request.get({ url }, function(err, resp, body) {
body = JSON.parse(body);
// Add the user_metadata property if not present already
if (!response.user.user_metadata) response.user.user_metadata = {};
if (body.result != "undeliverable" && !body.disposable) {
// Good email
console.log("This email is valid, run the callback");
callback(null, response);
} else {
console.log("Probably not a valid email address");
callback(`Access Denied by Kickbox server. (${body.sendex})`);
}
});
};
In this case, we are looking at the Sendex score only. If the Sendex score is over 0.75
, we assume that the email address is safe and good to go. There are various other checks that we could make to decide if we want to accept the user or not.
Using this code will send back a generic error message to the end-user on the Auth0 Universal Login page when the user is trying to sign up with an invalid email.
"Auth0 Hooks are a new extensibility mechanism in Auth0 that allows us to customize the behavior of the Auth0 platform using Node.js."
Tweet This
Taking the User Experience One Step Further
This workflow may not create the most user-friendly experience. In order to show a more meaningful message, we could use the Auth0 Hosted Pages editor. Now that we have access to the Kickbox email data, we could still let our users login but we could perform email verification if we are feeling unsure. There are many other options that we can add to this workflow from here on. There is no limit at what we can do using the Auth0 hooks! I encourage everyone to give them a try.
About Auth0
Auth0 by Okta takes a modern approach to customer identity and enables organizations to provide secure access to any application, for any user. Auth0 is a highly customizable platform that is as simple as development teams want, and as flexible as they need. Safeguarding billions of login transactions each month, Auth0 delivers convenience, privacy, and security so customers can focus on innovation. For more information, visit https://auth0.com.