Sha256: 52489c29a89f029696ceb38220da73c25c2f17e89ae57e08648d40de1ac281ab

Contents?: true

Size: 747 Bytes

Versions: 4

Compression:

Stored size: 747 Bytes

Contents

# frozen_string_literal: true

class DeviseTokenAuthEmailValidator < ActiveModel::EachValidator
  EMAIL_REGEXP = /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\z/i

  class << self
    def validate?(email)
      email =~ EMAIL_REGEXP
    end
  end

  def validate_each(record, attribute, value)
    unless DeviseTokenAuthEmailValidator.validate?(value)
      record.errors.add(attribute, email_invalid_message)
    end
  end

  private

  def email_invalid_message
    # Try strictly set message:
    message = options[:message]

    if message.nil?
      # Try DeviceTokenAuth translations or fallback to ActiveModel translations
      message = I18n.t(:'errors.messages.not_email', default: :'errors.messages.invalid')
    end

    message
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
devise_token_auth-1.2.5 app/validators/devise_token_auth_email_validator.rb
devise_token_auth-1.2.4 app/validators/devise_token_auth_email_validator.rb
devise_token_auth-1.2.2 app/validators/devise_token_auth_email_validator.rb
devise_token_auth-1.2.1 app/validators/devise_token_auth_email_validator.rb