Add some debug messages

This commit is contained in:
Alex Sherman 2020-11-23 18:07:01 +05:00
parent f01e59d95a
commit 3943628716
3 changed files with 13 additions and 5 deletions

View file

@ -14,7 +14,9 @@ module Authorization
end end
def can_access_registrar_area_sign_in_page? def can_access_registrar_area_sign_in_page?
Rails.logger.info "Checking if Auth::RestrictedIp.enabled: #{self.class.enabled?}"
return true unless self.class.enabled? return true unless self.class.enabled?
Rails.logger.info "Checking if registrar area accessible, result: #{WhiteIp.registrar_area.include_ip?(ip)}"
WhiteIp.registrar_area.include_ip?(ip) WhiteIp.registrar_area.include_ip?(ip)
end end

View file

@ -137,7 +137,8 @@ class Registrar < ApplicationRecord
def api_ip_white?(ip) def api_ip_white?(ip)
return true unless Setting.api_ip_whitelist_enabled return true unless Setting.api_ip_whitelist_enabled
white_ips.api.pluck(:ipv4, :ipv6).flatten.include?(ip) # white_ips.api.pluck(:ipv4, :ipv6).flatten.include?(ip)
white_ips.api.include_ip?(ip)
end end
# Audit log is needed, therefore no raw SQL # Audit log is needed, therefore no raw SQL

View file

@ -41,21 +41,26 @@ class WhiteIp < ApplicationRecord
class << self class << self
# rubocop:disable Style/CaseEquality # rubocop:disable Style/CaseEquality
def include_ip?(ip) def include_ip?(ip)
Rails.logger.info "Checking if whitelist includes ip:#{ip}" Rails.logger.info "Checking if whitelist includes ip: #{ip}"
return false if ip.blank? return false if ip.blank?
where(id: ids_including(ip)).any? result = where(id: ids_including(ip)).any?
Rails.logger.info "Result is: #{result}"
result
end end
def ids_including(ip) def ids_including(ip)
Rails.logger.info "Checking ip #{ip}"
ipv4 = ipv6 = [] ipv4 = ipv6 = []
if check_ip4(ip).present? if check_ip4(ip).present?
ipv4 = select { |white_ip| IPAddr.new(white_ip.ipv4, Socket::AF_INET) === check_ip4(ip) } ipv4 = select { |white_ip| IPAddr.new(white_ip.ipv4, Socket::AF_INET) === check_ip4(ip) }
end end
if check_ip6(ip).present? if check_ip6(ip).present?
ipv6 = select { |white_ip| IPAddr.new(white_ip.ipv6, Socket::AF_INET6) === check_ip6 } ipv6 = select { |white_ip| IPAddr.new(white_ip.ipv6, Socket::AF_INET6) === check_ip6(ip) }
end end
(ipv4 + ipv6).pluck(:id).flatten.uniq result = (ipv4 + ipv6).pluck(:id).flatten.uniq
Rails.logger.info "Result is #{result}"
result
end end
# rubocop:enable Style/CaseEquality # rubocop:enable Style/CaseEquality