diff options
| author | Patrick J Cherry <patrick@bytemark.co.uk> | 2012-11-26 17:05:04 +0000 | 
|---|---|---|
| committer | Patrick J Cherry <patrick@bytemark.co.uk> | 2012-11-26 17:05:04 +0000 | 
| commit | f96143755ab9a5ff92c9116a449a820320f2d565 (patch) | |
| tree | 3a71a334b2a53571847a97ce785d23ef5fc1e34d | |
| parent | fc848abc8f5cb9452c7b929f6f1212d305b5cbdb (diff) | |
| parent | 8bcde22371f18b320ca03090d530b0c30d4cc4d7 (diff) | |
merge
| -rw-r--r-- | lib/mauve/source_list.rb | 24 | 
1 files changed, 13 insertions, 11 deletions
| diff --git a/lib/mauve/source_list.rb b/lib/mauve/source_list.rb index d1eafc6..4154821 100644 --- a/lib/mauve/source_list.rb +++ b/lib/mauve/source_list.rb @@ -1,6 +1,6 @@  # encoding: UTF-8  require 'log4r' -require 'ipaddr' +require 'ipaddress'  require 'uri'  require 'mauve/mauve_time'  require 'mauve/mauve_resolv' @@ -118,6 +118,7 @@ module Mauve          begin                  uri = URI.parse(host)            host = uri.host unless uri.host.nil? +          host = $1 if host =~ /^\[([0-9a-f:]+)\]$/i          rescue URI::InvalidURIError => ex            # ugh            logger.warn "Did not recognise URI #{host}" @@ -125,10 +126,11 @@ module Mauve        end        host_as_ip = nil +        begin -        host_as_ip = IPAddr.new(host) +        host_as_ip = IPAddress.parse(host)        rescue ArgumentError -        # Rescue IPAddr argument errors, i.e. host is not an IP address. +        # Rescue IPAddress argument errors, i.e. host is not an IP address.        end        return true if self.list.any? do |l| @@ -137,8 +139,8 @@ module Mauve              host == l            when Regexp              host =~ l -          when IPAddr  -            host_as_ip.is_a?(IPAddr) and l.include?(host_as_ip) +          when IPAddress  +            host_as_ip.is_a?(l.class) and l.include?(host_as_ip)            else              false          end @@ -149,14 +151,14 @@ module Mauve        #        return false if true == Configuration.current.minimal_dns_lookups -      return false unless self.list.any?{|l| l.is_a?(IPAddr)} +      return false unless self.list.any?{|l| l.is_a?(IPAddress)} -      ips = MauveResolv.get_ips_for(host).collect{|i| IPAddr.new(i)} +      ips = MauveResolv.get_ips_for(host).collect{|i| IPAddress.parse(i)}        return false if ips.empty? -      return self.list.select{|i| i.is_a?(IPAddr)}.any? do |list_ip|  -        ips.any?{|ip| list_ip.include?(ip)} +      return self.list.select{|i| i.is_a?(IPAddress)}.any? do |list_ip| +        ips.any?{|ip| ip.is_a?(list_ip.class) and list_ip.include?(ip) }        end        return false @@ -186,7 +188,7 @@ module Mauve          new_list = (url_list + @list).collect do |host|             if host.is_a?(String) -            [host] + MauveResolv.get_ips_for(host).collect{|i| IPAddr.new(i)} +            [host] + MauveResolv.get_ips_for(host).collect{|i| IPAddress.parse(i)}            else              host            end @@ -214,7 +216,7 @@ module Mauve              gsub(/\*/, "[0-9a-z\\-]+") +              "\\.?$")        elsif h.is_a?(String) and h =~ /^[0-9a-f\.:]+(\/\d+)?$/i -        IPAddr.new(h) +        IPAddress.parse(h)        elsif h.is_a?(String) and h =~ /^\/(.*)\/$/          Regexp.new($1)        elsif h.is_a?(String) or h.is_a?(Regexp) | 
