diff --git a/lib/geocoder/lookups/telize.rb b/lib/geocoder/lookups/telize.rb new file mode 100644 index 0000000000000000000000000000000000000000..c3befae5dfba182614d7f85f797bb8ea13ed852a --- /dev/null +++ b/lib/geocoder/lookups/telize.rb @@ -0,0 +1,48 @@ +require 'geocoder/lookups/base' +require 'geocoder/results/telize' + +module Geocoder::Lookup + class Telize < Base + + def name + "Telize" + end + + def query_url(query) + #currently doesn't support HTTPS + "http://www.telize.com/geoip/#{query.sanitized_text}" + end + + private # --------------------------------------------------------------- + + def parse_raw_data(raw_data) + raw_data.match(/^<html><title>404/) ? nil : super(raw_data) + end + + def results(query) + # don't look up a loopback address, just return the stored result + return [reserved_result(query.text)] if query.loopback_ip_address? + # note: Freegeoip.net returns plain text "Not Found" on bad request + (doc = fetch_data(query)) ? [doc] : [] + end + + def reserved_result(ip) + { + "ip" => ip, + "city" => "", + "region_code" => "", + "region_name" => "", + "metrocode" => "", + "zipcode" => "", + "latitude" => "0", + "longitude" => "0", + "country_name" => "Reserved", + "country_code" => "RD" + } + end + + def host + configuration[:host] || "telize.net" + end + end +end diff --git a/lib/geocoder/results/telize.rb b/lib/geocoder/results/telize.rb new file mode 100644 index 0000000000000000000000000000000000000000..84aec721e787d54efefc428f521ce249e73315f0 --- /dev/null +++ b/lib/geocoder/results/telize.rb @@ -0,0 +1,45 @@ +require 'geocoder/results/base' + +module Geocoder::Result + class Telize < Base + + def address(format = :full) + s = state_code.to_s == "" ? "" : ", #{state_code}" + "#{city}#{s} #{postal_code}, #{country}".sub(/^[ ,]*/, "") + end + + def city + @data['city'] + end + + def state + @data['region_name'] + end + + def state_code + @data['region_code'] + end + + def country + @data['country_name'] + end + + def country_code + @data['country_code'] + end + + def postal_code + @data['zipcode'] + end + + def self.response_attributes + %w[metrocode ip] + end + + response_attributes.each do |a| + define_method a do + @data[a] + end + end + end +end diff --git a/test/fixtures/telize_74_200_247_59 b/test/fixtures/telize_74_200_247_59 new file mode 100644 index 0000000000000000000000000000000000000000..78c7ce3e57bcf79534475006a19c0cbeba3422ad --- /dev/null +++ b/test/fixtures/telize_74_200_247_59 @@ -0,0 +1,12 @@ +{ + "city": "Plano", + "region_code": "TX", + "region_name": "Texas", + "metrocode": "623", + "zipcode": "75093", + "longitude": "-96.8134", + "country_name": "United States", + "country_code": "US", + "ip": "74.200.247.59", + "latitude": "33.0347" +} diff --git a/test/fixtures/telize_no_results b/test/fixtures/telize_no_results new file mode 100644 index 0000000000000000000000000000000000000000..2ac0915dd0c91079a1b0d2eb3fd3c21194e0a77a --- /dev/null +++ b/test/fixtures/telize_no_results @@ -0,0 +1 @@ +<html><title>404: Not Found</title><body>404: Not Found</body></html> diff --git a/test/unit/lookups/telize_test.rb b/test/unit/lookups/telize_test.rb new file mode 100644 index 0000000000000000000000000000000000000000..449ee1e2743423e3f6d524887b99bc25bfa97387 --- /dev/null +++ b/test/unit/lookups/telize_test.rb @@ -0,0 +1,20 @@ +# encoding: utf-8 +$: << File.join(File.dirname(__FILE__), "..", "..") +require 'test_helper' + +class TelizeTest < GeocoderTestCase + + def setup + Geocoder.configure(ip_lookup: :telize) + end + + def test_result_on_ip_address_search + result = Geocoder.search("74.200.247.59").first + assert result.is_a?(Geocoder::Result::Telize) + end + + def test_result_components + result = Geocoder.search("74.200.247.59").first + assert_equal "Plano, TX 75093, United States", result.address + end +end