deep-email-validator-extended
Version:
Validates emails based on regex, common typos, disposable email blacklists, DNS records and SMTP server response.
76 lines (60 loc) • 1.97 kB
Markdown
//nodei.co/npm/deep-email-validator-extended.png)](https://nodei.co/npm/deep-email-validator-extended/)
Validates email addresses based on regex, common typos, disposable email blacklists, DNS records and SMTP server response.
- Validates email looks like an email i.e. contains an "@" and a "." to the right of it.
- Validates common typos e.g. example@gmaill.com using [mailcheck](https://github.com/mailcheck/mailcheck).
- Validates email was not generated by disposable email service using [disposable-email-domains](https://github.com/ivolo/disposable-email-domains).
- Validates MX records are present on DNS.
- Validates SMTP server is running.
- Validates mailbox exists on SMTP server.
- Native typescript support.
Compatible with nodejs only. Not browser ready.
Install like so
```
npm i deep-email-validator-extended --save
```
or with yarn
```
yarn add deep-email-validator-extended
```
Use like so
```typescript
import validate from 'deep-email-validator-extended'
const main = async () => {
let res = await validate('asdf@gmail.com')
// {
// "valid": false,
// "reason": "smtp",
// "validators": {
// "regex": {
// "valid": true
// },
// "typo": {
// "valid": true
// },
// "disposable": {
// "valid": true
// },
// "mx": {
// "valid": true
// },
// "smtp": {
// "valid": false,
// "reason": "Mailbox not found.",
// }
// }
// }
// Can also be called with these default options
await validate({
email: 'name@example.org',
sender: 'name@example.org',
validateRegex: true,
validateMx: true,
validateTypo: true,
validateDisposable: true,
validateSMTP: true,
})
}
```
[ ](https://github.com/meabed/deep-email-validator-extended/blob/master/src/options/options.ts#L1)
[![NPM](https: