Django package to detect ~890 domains used by disposable email services
Project description
=============================== django-disposable-email-checker
Django package to detect between ~890 & ~8,600 domains used by disposable email services. You can validate any email against our internal list of ~890 domains used by disposable email services. Optionally you can also check each domain against the Block-Disposable-Email.com API, covering ~8,600 domains.
This code was initially developed at: https://github.com/aaronbassett/DisposableEmailChecker However PyPI ownership has been transferred to https://github.com/jheld/DisposableEmailChecker and as such all future contributions are expected to be made to the new github repo.
Setup
Install the disposable email checker from PyPI
pip install django-disposable-email-checker
The disposable email checker comes with a list of ~890 emails. If you would like to provide your own email list create a function which returns a list of domains to block.
from disposable_email_checker.emails import email_domain_loader
def custom_email_domain_loader():
# Anyone still using AOL will be too much of a customer service burden
return [
"aol.com",
] + email_domain_loader()
Then add the complete path including function name to your settings
DEC_LOADER = "my.package.custom_email_domain_loader"
If you would like to use the BDE integration add your API key to your Django settings
BDEA_APIKEY = "abcnotarealkey123"
optionally you can configure the BDE API timeout in seconds (default 5)
BDEA_TIMEOUT = 2
A default error message can be set globally for the validation checking (this is optional and if
left blank it will default to _('Blocked email provider.')
):
BDEA_MESSAGE = '<blocked email message>'
Adding to your models
Once you have completed setup add the DisposableEmailField
to your models.
from django.db import models
from disposable_email_checker.fields import DisposableEmailField
class MyModel(models.Model):
email = DisposableEmailField()
The DisposableEmailField
has a few optional arguments
- whitelist - A list of emails which will always be allowed. Defaults
to
[]
- message - The error message used by ValidationError if validation
fails. Defaults to
_('Blocked email provider.')
- code - The error code used by ValidationError if validation fails. Defaults to "invalid".
Using the validator
If you want to use the validator by itself
from django.core.exceptions import ValidationError
from disposable_email_checker.validators import validate_disposable_email
email = "emailaddress@readmetest.com" # replace with your own value
try:
validate_disposable_email(email)
except ValidationError:
pass
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file django-disposable-email-checker-2.0.3a1.tar.gz
.
File metadata
- Download URL: django-disposable-email-checker-2.0.3a1.tar.gz
- Upload date:
- Size: 16.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 04e637089fb767435b5a3aefb694469b54a1beb9aa99cd833f1cc2cf2240389e |
|
MD5 | 4b38862956945bb0696095772cc7ccdd |
|
BLAKE2b-256 | 01d957bd5a39e808556c4f3df949e53570529b94029ed50bb67c015cd8d5fd1a |
File details
Details for the file django_disposable_email_checker-2.0.3a1-py3-none-any.whl
.
File metadata
- Download URL: django_disposable_email_checker-2.0.3a1-py3-none-any.whl
- Upload date:
- Size: 14.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 40bd991b8556da3fd0f493c22fb30848bea6ad8f32f4723680d829af9e2b70f3 |
|
MD5 | 7b7e09c4d85b9f00128a6aca1466c095 |
|
BLAKE2b-256 | 61224ec9ca6382865869ec94707a8d9c78036bcd007e98db3d6a3b8799b6b0ea |