lynndylanhurley/devise_token_auth

View on GitHub
app/validators/devise_token_auth_email_validator.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
# 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