The project is in a healthy, maintained state
Validates email addresses with RFC 5322 syntax checking, MX record verification, disposable domain detection, and role-based address identification.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
 Dependencies
 Project Readme

philiprehberger-email_validator

Tests Gem Version Last updated

RFC-compliant email validation with MX record verification, disposable domain detection, normalization, and typo suggestions

Requirements

  • Ruby >= 3.1

Installation

Add to your Gemfile:

gem "philiprehberger-email_validator"

Or install directly:

gem install philiprehberger-email_validator

Usage

require "philiprehberger/email_validator"

Philiprehberger::EmailValidator.valid?("user@example.com")
# => true

Philiprehberger::EmailValidator.valid?("not-an-email")
# => false

Full Validation

result = Philiprehberger::EmailValidator.validate("user@example.com")
result.valid?    # => true
result.errors    # => []
result.warnings  # => []

result = Philiprehberger::EmailValidator.validate("admin@example.com")
result.valid?    # => true
result.warnings  # => ["address appears to be role-based"]

MX Record Verification

result = Philiprehberger::EmailValidator.validate("user@example.com", check_mx: true)
result.valid?  # => true (if domain has MX/A records)

Philiprehberger::EmailValidator.mx_valid?("example.com")
# => true

Disposable Domain Detection

Philiprehberger::EmailValidator.disposable?("user@mailinator.com")
# => true

result = Philiprehberger::EmailValidator.validate("user@mailinator.com", allow_disposable: false)
result.valid?  # => false
result.errors  # => ["disposable email domains are not allowed"]

Role-Based Address Detection

Philiprehberger::EmailValidator.role_based?("info@example.com")
# => true

Philiprehberger::EmailValidator.role_based?("alice@example.com")
# => false

Bulk Validation

emails = ["user@example.com", "invalid", "admin@example.com"]

results = Philiprehberger::EmailValidator.validate_all(emails, allow_disposable: false)
results[0].valid?  # => true
results[1].valid?  # => false

Philiprehberger::EmailValidator.valid_all?(["user@example.com", "alice@example.com"])
# => true

Custom Disposable Domain List

Philiprehberger::EmailValidator.configure do |config|
  config.add_disposable_domains(["custom-temp.com", "temp.org"])
  config.remove_disposable_domains(["mailinator.com"])
end

Philiprehberger::EmailValidator.disposable?("user@custom-temp.com")
# => true

Philiprehberger::EmailValidator.reset_configuration!

Email Normalization

Philiprehberger::EmailValidator.normalize("Jo.Hn+spam@Gmail.com")
# => "john@gmail.com"

Philiprehberger::EmailValidator.normalize("  USER+tag@Example.COM  ")
# => "user@example.com"

Typo Suggestion

Philiprehberger::EmailValidator.suggest("user@gmial.com")
# => { original: "user@gmial.com", suggested: "user@gmail.com" }

Philiprehberger::EmailValidator.suggest("user@gmail.com")
# => nil

Domain Info

Philiprehberger::EmailValidator.domain_info("user@mail.example.co.uk")
# => { domain: "mail.example.co.uk", tld: "uk" }

Philiprehberger::EmailValidator.domain_info("user@example.com", check_mx: true)
# => { domain: "example.com", tld: "com", mx_records: ["mail.example.com"] }

API

Method Description
EmailValidator.valid?(email) Quick syntax check, returns boolean
EmailValidator.validate(email, check_mx: false, allow_disposable: true) Full validation returning Result
EmailValidator.validate_all(emails, **opts) Bulk validation returning array of Results
EmailValidator.valid_all?(emails) Returns true only if all emails are valid
EmailValidator.mx_valid?(domain) Check if domain has MX or A records
EmailValidator.disposable?(email) Check if email uses a disposable domain
EmailValidator.role_based?(email) Detect role-based addresses (info@, admin@, etc.)
EmailValidator.configure { |config| ... } Configure custom disposable domain list
EmailValidator.reset_configuration! Reset configuration to defaults
EmailValidator.normalize(email) Normalize email (lowercase, remove aliases, Gmail dots)
EmailValidator.suggest(email) Suggest corrected domain for typos
EmailValidator.domain_info(email, check_mx: false) Extract domain metadata

Result

Method Description
#valid? True if no validation errors
#errors Array of error message strings
#warnings Array of warning message strings

Development

bundle install
bundle exec rspec
bundle exec rubocop

Support

If you find this project useful:

Star the repo

🐛 Report issues

💡 Suggest features

❤️ Sponsor development

🌐 All Open Source Projects

💻 GitHub Profile

🔗 LinkedIn Profile

License

MIT