Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/pull/4407'
Browse files Browse the repository at this point in the history
  • Loading branch information
tomhughes committed Dec 17, 2023
2 parents ad26794 + a4c23cd commit 1b675a6
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 0 deletions.
2 changes: 2 additions & 0 deletions app/controllers/users_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -355,6 +355,8 @@ def check_signup_allowed(email = nil)
domain_mx_servers(domain)
end

return true if Acl.allow_account_creation(request.remote_ip, :domain => domain, :mx => mx_servers)

blocked = Acl.no_account_creation(request.remote_ip, :domain => domain, :mx => mx_servers)

blocked ||= SIGNUP_IP_LIMITER && !SIGNUP_IP_LIMITER.allow?(request.remote_ip)
Expand Down
9 changes: 9 additions & 0 deletions app/models/acl.rb
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,15 @@ def self.no_account_creation(address, options = {})
match(address, options).exists?(:k => "no_account_creation")
end

def self.allow_account_creation(address, options = {})
acls = Acl.where("address >>= ?", address)
.and(Acl.where(:k => "allow_account_creation"))
acls = acls.and(Acl.where(:domain => options[:domain])) if options[:domain]
acls = acls.and(Acl.where(:mx => options[:mx])) if options[:mx]

!acls.empty?
end

def self.no_note_comment(address, domain = nil)
match(address, :domain => domain).exists?(:k => "no_note_comment")
end
Expand Down
13 changes: 13 additions & 0 deletions test/models/acl_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -27,4 +27,17 @@ def test_no_account_creation_by_mx
create(:acl, :mx => "mail.example.com", :k => "no_account_creation")
assert Acl.no_account_creation("192.168.1.1", :mx => "mail.example.com")
end

def test_allowed_account_creation
assert_not Acl.allow_account_creation("192.168.1.1", :domain => "example.com", :mx => "mail.example.com")
create(:acl, :address => "192.168.1.1", :domain => "example.com", :mx => "mail.example.com", :k => "allow_account_creation")

assert_not Acl.allow_account_creation("192.168.1.2")
assert Acl.allow_account_creation("192.168.1.1")

assert_not Acl.allow_account_creation("192.168.1.2", :domain => "example.com", :mx => "mail.example.com")
assert_not Acl.allow_account_creation("192.168.1.1", :domain => "example1.com", :mx => "mail.example.com")
assert_not Acl.allow_account_creation("192.168.1.1", :domain => "example.com", :mx => "mail1.example.com")
assert Acl.allow_account_creation("192.168.1.1", :domain => "example.com", :mx => "mail.example.com")
end
end

0 comments on commit 1b675a6

Please sign in to comment.