Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/micke/valid_email2
ActiveModel validation for email. Including MX lookup and disposable email blacklist
https://github.com/micke/valid_email2
Last synced: 4 months ago
JSON representation
ActiveModel validation for email. Including MX lookup and disposable email blacklist
- Host: GitHub
- URL: https://github.com/micke/valid_email2
- Owner: micke
- License: mit
- Created: 2013-07-11T09:55:39.000Z (over 11 years ago)
- Default Branch: main
- Last Pushed: 2024-10-23T23:35:52.000Z (4 months ago)
- Last Synced: 2024-10-24T07:18:46.921Z (4 months ago)
- Language: Ruby
- Size: 3.33 MB
- Stars: 658
- Watchers: 15
- Forks: 102
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-rails-gems - micke / valid_email2
README
# ValidEmail2
[](http://badge.fury.io/rb/valid_email2)Validate emails with the help of the `mail` gem instead of some clunky regexp.
Aditionally validate that the domain has a MX record.
Optionally validate against a static [list of disposable email services](config/disposable_email_domains.txt).
Optionally validate that the email is not subaddressed ([RFC5233](https://tools.ietf.org/html/rfc5233)).### Why?
There are lots of other gems and libraries that validates email addresses but most of them use some clunky regexp.
I also saw a need to be able to validate that the email address is not coming from a "disposable email" provider.### Is it production ready?
Yes, it is used in several production apps.
## Installation
Add this line to your application's Gemfile:
```ruby
gem "valid_email2"
```And then execute:
$ bundle
Or install it yourself as:
$ gem install valid_email2
## Usage
### Use with ActiveModel
If you just want to validate that it is a valid email address:
```ruby
class User < ActiveRecord::Base
validates :email, presence: true, 'valid_email_2/email': true
end
```To validate that the domain has an MX record or A record:
```ruby
validates :email, 'valid_email_2/email': { mx: true }
```To validate strictly that the domain has an MX record:
```ruby
validates :email, 'valid_email_2/email': { strict_mx: true }
```
`strict_mx` and `mx` both default to a 5 second timeout for DNS lookups.
To override this timeout, specify a `dns_timeout` option:
```ruby
validates :email, 'valid_email_2/email': { strict_mx: true, dns_timeout: 10 }
```Any checks that require DNS resolution will use the default `Resolv::DNS` nameservers for DNS lookups.
To override these, specify a `dns_nameserver` option:
```ruby
validates :email, 'valid_email_2/email': { mx: true, dns_nameserver: ['8.8.8.8', '8.8.4.4'] }
```To validate that the domain is not a disposable email (checks domain and MX server):
```ruby
validates :email, 'valid_email_2/email': { disposable: true }
```To validate that the domain is not a disposable email (checks domain only, does not check MX server):
```ruby
validates :email, 'valid_email_2/email': { disposable_domain: true }
```To validate that the domain is not a disposable email or a disposable email (checks domain and MX server) but allow-listed (under config/allow_listed_email_domains.yml):
```ruby
validates :email, 'valid_email_2/email': { disposable_with_allow_list: true }
```To validate that the domain is not a disposable email or a disposable email (checks domain only, does not check MX server) but allow-listed (under config/allow_listed_email_domains.yml):
```ruby
validates :email, 'valid_email_2/email': { disposable_domain_with_allow_list: true }
```To validate that the domain is not on the deny list (under config/deny_listed_email_domains.yml):
```ruby
validates :email, 'valid_email_2/email': { deny_list: true }
```To validate that email is not subaddressed:
```ruby
validates :email, 'valid_email_2/email': { disallow_subaddressing: true }
```To validate that email does not contain a dot anywhere before the @:
```ruby
validates :email, 'valid_email_2/email': { disallow_dotted: true }
```To validate create your own custom message:
```ruby
validates :email, 'valid_email_2/email': { message: "is not a valid email" }
```To allow multiple addresses separated by comma:
```ruby
validates :email, 'valid_email_2/email': { multiple: true }
```All together:
```ruby
validates :email, 'valid_email_2/email': { mx: true, disposable: true, disallow_subaddressing: true}
```> Note that this gem will let an empty email pass through so you will need to
> add `presence: true` if you require an email### Use without ActiveModel
```ruby
address = ValidEmail2::Address.new("[email protected]")
address.valid? => true
address.disposable? => false
address.valid_mx? => true
address.valid_strict_mx? => true
address.subaddressed? => false
```### Test environment
If you are validating `mx` then your specs will fail without an internet connection.
It is a good idea to stub out that validation in your test environment.
Do so by adding this in your `spec_helper`:
```ruby
config.before(:each) do
allow_any_instance_of(ValidEmail2::Address).to receive_messages(
valid_mx?: true,
valid_strict_mx?: true,
mx_server_is_in?: false
)
end
```## Requirements
This gem is tested against currently supported Ruby and Rails versions. For an up to date list, check the build matrix in the [workflow](.github/workflows/ci.yaml).
## Upgrading to v5.3.0
In version v5.3.0 the config directory files were renamed as follows:
`config/blacklisted_email_domains.yml` -> `config/deny_listed_email_domains.yml`
`config/whitelisted_email_domains.yml` -> `config/allow_listed_email_domains.yml`You won't need to make any changes yourself if you're installing this version for the first time. For individuals updating from earlier versions, make sure to update the file namings as per the above. In future versions this will be a breaking change.
## Upgrading to v3.0.0
In version v3.0.0 I decided to move __and__ rename the config files from the
vendor directory to the config directory. That means:`vendor/blacklist.yml` -> `config/blacklisted_email_domains.yml`
`vendor/whitelist.yml` -> `config/whitelisted_email_domains.yml`The `disposable` validation has been improved with a `mx` check. Apply the
stub, as noted in the Test environment section, if your tests have slowed
down or if they do not work without an internet connection.## Upgrading to v2.0.0
In version 1.0 of valid_email2 we only defined the `email` validator.
But since other gems also define a `email` validator this can cause some unintended
behaviours and emails that shouldn't be valid are regarded valid because the
wrong validator is used by rails.So in version 2.0 we decided to deprecate using the `email` validator directly
and instead define a `valid_email_2/email` validator to be sure that the correct
validator gets used.So this:
```ruby
validates :email, email: { mx: true, disposable: true }
```Becomes this:
```ruby
validates :email, 'valid_email_2/email': { mx: true, disposable: true }
```## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request