Coder Social home page Coder Social logo

yurokle / valid_email Goto Github PK

View Code? Open in Web Editor NEW

This project forked from hallelujah/valid_email

0.0 1.0 0.0 152 KB

Active Model Validations for Email using mail gem

Home Page: http://my.rails-royce.org/2010/07/21/email-validation-in-ruby-on-rails-without-regexp/

License: MIT License

Ruby 100.00%

valid_email's Introduction

Purpose

It validates email for application use (registering a new account for example)

Usage

In your Gemfile :

gem 'valid_email'

In your code :

require 'valid_email'
class Person
  include ActiveModel::Validations
  attr_accessor :name, :email

  validates :name, :presence => true, :length => { :maximum => 100 }
  validates :email, :presence => true, :email => true
end


p = Person.new
p.name = "hallelujah"
p.email = "[email protected]"
p.valid? # => true

p.email = "john@doe"
p.valid? # => false

p.email = "John Does <[email protected]>"
p.valid? # => false

You can check if email domain has MX record :

validates :email, :email => {:mx => true, :message => I18n.t('validations.errors.models.user.invalid_email')}

Or

validates :email, :email => {:message => I18n.t('validations.errors.models.user.invalid_email')}, :mx => {:message => I18n.t('validations.errors.models.user.invalid_mx')}

Alternatively, you can check if an email domain has a MX or A record by using :mx_with_fallback instead of :mx.

You can detect disposable accounts

validates :email, :email => {:ban_disposable_email => true, :message => I18n.t('validations.errors.models.user.invalid_email')}

If you don't want the MX validator stuff, just require the right file

require 'valid_email/email_validator'

Or in your Gemfile

gem 'valid_email', :require => 'valid_email/email_validator'

Usage outside of model validation

There is a chance that you want to use e-mail validator outside of model validation.
If that's the case, you can use the following methods:

ValidateEmail.valid?('[email protected]') # You can optionally pass a hash of options, same as validator
ValidateEmail.mx_valid?('[email protected]')
ValidateEmail.mx_valid_with_fallback?('[email protected]')
ValidateEmail.valid?('[email protected]')

Load it (and not the rails extensions) with

gem 'valid_email', require: 'valid_email/validate_email'

String and Nil object extensions

There is also a String and Nil class extension, if you require the gem in this way in Gemfile:

gem 'valid_email', require: ['valid_email/all_with_extensions']

You will be able to use the following methods:

nil.email? # => false
"[email protected]".email? # => May return true if it exists. It accepts a hash of options like ValidateEmail.valid?

Code Status

  • Build Status

Credits

  • Ramihajamalala Hery hery[at]rails-royce.org
  • Fire-Dragon-DoL francesco.belladonna[at]gmail.com
  • dush dusanek[at]iquest.cz
  • MIke Carter mike[at]mcarter.me
  • Heng heng[at]reamaze.com
  • Marco Perrando mperrando[at]soluzioninrete.it
  • Jörg Thalheim joerg[at]higgsboson.tk
  • Andrey Deryabin deriabin[at]gmail.com
  • Nicholas Rutherford nick.rutherford[at]gmail.com
  • Oleg Shur workshur[at]gmail.com
  • Joel Chippindale joel[at]joelchippindale.com
  • Sami Haahtinen sami[at]haahtinen.name
  • Jean Boussier jean.boussier[at]gmail.com

Note on Patches/Pull Requests

  • Fork the project.

  • Make your feature addition or bug fix.

  • Add tests for it. This is important so I don’t break it in a future version unintentionally.

  • Commit, do not mess with rakefile, version, or history. (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)

  • Send me a pull request. Bonus points for topic branches.

Copyright

Copyright © 2011 Ramihajamalala Hery. See LICENSE for details

valid_email's People

Contributors

aderyabin avatar byroot avatar dush avatar fire-dragon-dol avatar hallelujah avatar mic92 avatar michaelcarter avatar mocoso avatar nruth avatar olleolleolle avatar ressu avatar workshur avatar yurokle avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.