root["generator"] = GENERATOR
root["copyright"] = COPYRIGHT_OWNER
root["attribution"] = ATTRIBUTION_URL
- root["license"] = LICENSE_URL
+ root["license"] = LICENSE_URL
doc.root = root
doc
end
end
def self.ip_to_country(ip_address)
- Timer.timeout(4) do
- ipinfo = Quova::IpInfo.new(ip_address) if defined?(QUOVA_USERNAME)
-
- if ipinfo && ipinfo.status == Quova::SUCCESS
- country = ipinfo.country_code
- else
- country = http_client.get("http://api.hostip.info/country.php?ip=#{ip_address}").body
- country = "GB" if country == "UK"
- end
+ ipinfo = geoip_database.country(ip_address) if defined?(GEOIP_DATABASE)
- return country.upcase
+ if ipinfo
+ country = ipinfo.country_code2
+ else
+ country = http_client.get("http://api.hostip.info/country.php?ip=#{ip_address}").body
+ country = "GB" if country == "UK"
end
- return nil
+ return country
rescue StandardError
return nil
end
def self.ip_location(ip_address)
code = OSM.ip_to_country(ip_address)
- if code && country = Country.find_by_code(code)
+ if code && country = Country.find(code)
return { :minlon => country.min_lon, :minlat => country.min_lat, :maxlon => country.max_lon, :maxlat => country.max_lat }
end
@http_client ||= Faraday.new
end
- # Set the HTTP client to use
- def self.http_client=(client)
- @http_client = client
+ # Return the GeoIP database handle
+ def self.geoip_database
+ @geoip_database ||= GeoIP.new(GEOIP_DATABASE) if defined?(GEOIP_DATABASE)
end
end