about summary refs log tree commit diff
path: root/app/validators/blacklisted_email_validator.rb
blob: eb66ad93d7b3e34079f6b8ca2c904b875094b8b0 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# frozen_string_literal: true

class BlacklistedEmailValidator < ActiveModel::Validator
  def validate(user)
    return if user.valid_invitation? || user.email.blank?

    @email = user.email

    user.errors.add(:email, :blocked) if blocked_email_provider?
    user.errors.add(:email, :taken) if blocked_canonical_email?
  end

  private

  def blocked_email_provider?
    disallowed_through_email_domain_block? || disallowed_through_configuration? || not_allowed_through_configuration?
  end

  def blocked_canonical_email?
    CanonicalEmailBlock.block?(@email)
  end

  def disallowed_through_email_domain_block?
    EmailDomainBlock.block?(@email)
  end

  def not_allowed_through_configuration?
    return false if Rails.configuration.x.email_domains_whitelist.blank?

    domains = Rails.configuration.x.email_domains_whitelist.gsub('.', '\.')
    regexp  = Regexp.new("@(.+\\.)?(#{domains})$", true)

    @email !~ regexp
  end

  def disallowed_through_configuration?
    return false if Rails.configuration.x.email_domains_blacklist.blank?

    domains = Rails.configuration.x.email_domains_blacklist.gsub('.', '\.')
    regexp  = Regexp.new("@(.+\\.)?(#{domains})", true)

    regexp.match?(@email)
  end
end