X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/898c47e647fbffcd0543b78033945b04f1b9aeae..9a9e13af901e9d66357135fb39b111fc9e26b3b2:/lib/osm.rb diff --git a/lib/osm.rb b/lib/osm.rb index cb23b0c97..50e31a7ff 100644 --- a/lib/osm.rb +++ b/lib/osm.rb @@ -446,7 +446,7 @@ module OSM end end - def self.IPLocation(ip_address) + def self.IPToCountry(ip_address) Timeout::timeout(4) do ipinfo = Quova::IpInfo.new(ip_address) @@ -458,14 +458,24 @@ module OSM country = "GB" if country == "UK" end end + + return country.upcase + end + + return nil + rescue Exception + return nil + end + + def self.IPLocation(ip_address) + code = OSM.IPToCountry(ip_address) - country = Country.find_by_code(country.upcase) + unless code.nil? + country = Country.find_by_code(code) return { :minlon => country.min_lon, :minlat => country.min_lat, :maxlon => country.max_lon, :maxlat => country.max_lat } end - return nil - rescue Exception return nil end @@ -498,5 +508,10 @@ module OSM return "#{tilesql} AND #{prefix}latitude BETWEEN #{minlat} AND #{maxlat} AND #{prefix}longitude BETWEEN #{minlon} AND #{maxlon}" end + def self.legal_text_for_country(country_code) + file_name = File.join(RAILS_ROOT, "config", "legales", country_code.to_s + ".yml") + file_name = File.join(RAILS_ROOT, "config", "legales", "GB.yml") unless File.exist? file_name + YAML::load_file(file_name) + end end