Email Checker is a Python-based CLI and Dockerized tool for validating email addresses β individually or in batches. It detects disposable email domains (updated automatically from a public source), integrates with cron for scheduled tasks, and runs smoothly in local and containerized environments.
- β Validate a single email address from the CLI or Docker
- π Batch check emails from CSV files (
/input/*.csv) - α½1 Update and store disposable domains for validation
- π Scheduled updates via cron (built-in)
- π³ Docker-ready for isolated use or integration
- π» Easy to install and use via
pipormake
The complete source code is available on GitHub.
Feel free to explore, contribute, or fork the project.
pip install email-checker-mv pip uninstall email-checker-mv| Command | Description |
|---|---|
check_email someone@example.com |
β Check a single email (default output) |
check_email someone@example.com -S |
β Check a single email (short output) |
check_email someone@example.com -F |
β Check a single email (full output) |
check_batch |
π Batch check .csv files in the input/ dir |
update_domains |
π Update the list of disposable domains |
set_user_config KEY=VAL |
βοΈ Set a runtime config variable |
get_user_config |
π§Ύ Show current user config values |
Disposable domains are fetched from Propaganistas/Laravel-Disposable-Email.
The check_batch command processes a CSV file located in the input/ directory and expects the following format:
- Delimiter: Must be a comma (
,) - Headers: Required columns are:
emailβ the email address to validatestatusβ must be one of the supported values below
Only rows with the appropriate status values will be processed. All others will be skipped.
| Status | Description |
|---|---|
check |
Check email with default verbosity |
check S |
Check email with short response |
check F |
Check email with full response |
undefined |
Alias for check, treated the same as check |
undefined S |
Alias for check S, runs with short verbosity |
undefined F |
Alias for check F, runs with full verbosity |
email,status
user1@example.com,check
user2@example.com,undefined
user3@example.com,check S
user4@example.com,undefined F
The output format is consistent across both check_email (CLI) and check_batch (CSV):
- When using CLI, results are printed to the terminal.
- When using batch, results are written to the
statuscolumn in the CSV file.
You can safely rerun the same CSV file β already processed rows (anything except check, check S, check F, etc.) will be skipped.
| Result Format | Meaning |
|---|---|
valid |
π₯ Address exists and accepts emails |
invalid|format |
β Invalid email format (regex check failed) |
invalid|non-ascii |
β Email contains non-ASCII characters |
invalid|disposable |
ποΈ Disposable/temporary email address |
invalid|mx |
π‘ No MX record found for the domain |
invalid|smtp no-code: <msg> |
π« SMTP connection was closed without a response |
invalid|smtp <cat_short> <code> |
βοΈ Default output: short type and SMTP code |
invalid|smtp <cat>|<code>|<msg_short> |
π§Ύ Short output: verbose type and short message |
invalid|smtp <cat>|<code>|<msg> |
π Full output: verbose type and full message |
π These formats apply both in CLI and in .csv batch processing.
| Code | Meaning |
|---|---|
HB / hard-bounce |
β Hard bounce β Address does not exist |
SB / soft-bounce |
|
PE / protocol-error |
π§© Protocol error β SMTP syntax or protocol failure |
UN / unknown |
β Unknown β Unclassified or unknown SMTP response |
NC / no-code |
π No code β Connection closed unexpectedly (no code) |
π Note:
check_batchrewrites the result to the "status" column in the output CSV file for each email.
Starting from version 0.4.0, you can dynamically modify runtime configuration parameters via CLI, manage.sh, or Makefile.
| Variable | Description |
|---|---|
MAX_EMAILS_PER_RUN |
Maximum number of emails to process in one batch run |
SMTP_FROM |
Sender email used for SMTP HELO/EHLO |
SMTP_TIMEOUT |
Timeout for each SMTP connection (in seconds) |
USE_EHLO |
Use EHLO instead of HELO in SMTP handshake (true/false) |
EHLO_DOMAIN |
Custom domain for EHLO header |
USE_RANDOM_FROM |
Randomize sender email (true/false) |
CUSTOM_FROM_DOMAIN |
Domain used for random@domain.com when USE_RANDOM_FROM=true |
DEBUG |
Enable verbose debug output (true/false) |
These can be set using:
# CLI
set_user_config USE_EHLO=true
# manage.sh
./manage.sh -set_user_config USE_RANDOM_FROM=true
# Makefile
make set_user_config key=DEBUG=trueTo view the current configuration:
# CLI
get_user_config
# manage.sh
./manage.sh -get_user_config
# Makefile
make get_user_configYou can control Docker using either make or manage.sh.
Before using it, ensure itβs executable:
chmod +x manage.sh| Command | Description |
|---|---|
./manage.sh -start |
π’ Start the container with build |
./manage.sh -stop |
π Stop the container |
./manage.sh -destroy |
|
./manage.sh -logs |
π Tail cron logs |
./manage.sh -batch |
π¬ Run batch email check |
./manage.sh -check someone@example.com |
β Run single email check |
./manage.sh -check someone@example.com -S |
β Run single email check (short output) |
./manage.sh -check someone@example.com -F |
β Run single email check (full output) |
./manage.sh -update |
π Update list of disposable domains |
./manage.sh -set_user_config KEY=VAL |
βοΈ Set a single user config parameter |
./manage.sh -get_user_config |
π§Ύ Show current user config |
./manage.sh -help |
βΉοΈ Show this help message |
Use
make helpto list all commands.
| Command | Description |
|---|---|
./manage.sh -start |
π’ Start the container with build |
./manage.sh -stop |
π Stop the container |
./manage.sh -destroy |
|
./manage.sh -logs |
π Tail cron logs |
./manage.sh -batch |
π¬ Run batch email check |
./manage.sh -check someone@example.com |
β Run single email check |
./manage.sh -check someone@example.com -S |
β Run single email check (short output) |
./manage.sh -check someone@example.com -F |
β Run single email check (full output) |
./manage.sh -update |
π Update list of disposable domains |
make set_user_config key=VAL |
βοΈ Set a single user config parameter |
make get_user_config |
π§Ύ Show current user config |
./manage.sh -help |
βΉοΈ Show this help message |
You can edit the cron configuration directly inside the running container using:
docker exec -it email_checker crontab -eThis allows advanced scheduling if needed.
This project is licensed under the MIT License.
InTester is a secure and transparent online knowledge assessment platform. It offers time-limited tests, anti-cheating measures, instant results with PDF certificates, and public test records β making it ideal for job seekers and recruiters alike.
DCT Sign is a blockchain-backed electronic signature platform that prioritizes privacy and data integrity. Users can securely sign documents without storing the original files, ensuring confidentiality and compliance with advanced e-signature standards.
Thank you for using Email Checker! Contributions and feedback are welcome.