lib/geocoder/lookups/mapquest.rb in geocoder-1.1.8 vs lib/geocoder/lookups/mapquest.rb in geocoder-1.1.9

- old
+ new

@@ -8,17 +8,17 @@ def name "Mapquest" end def required_api_key_parts - [] + ["key"] end def query_url(query) - key = configuration.api_key - domain = key ? "www" : "open" - url = "#{protocol}://#{domain}.mapquestapi.com/geocoding/v1/#{search_type(query)}?" + domain = configuration[:licensed] ? "www" : "open" + version = configuration[:version] || 1 + url = "#{protocol}://#{domain}.mapquestapi.com/geocoding/v#{version}/#{search_type(query)}?" url + url_query_string(query) end private # --------------------------------------------------------------- @@ -32,12 +32,28 @@ params[:key] = CGI.unescape(key) end params.merge(super) end + # http://www.mapquestapi.com/geocoding/status_codes.html + # http://open.mapquestapi.com/geocoding/status_codes.html def results(query) return [] unless doc = fetch_data(query) - doc["results"][0]['locations'] + return doc["results"][0]['locations'] if doc['info']['statuscode'] == 0 # A successful geocode call + + messages = doc['info']['messages'].join + + case doc['info']['statuscode'] + when 400 # Error with input + raise_error(Geocoder::InvalidRequest, messages) || + warn("Mapquest Geocoding API error: #{messages}") + when 403 # Key related error + raise_error(Geocoder::InvalidApiKey, messages) || + warn("Mapquest Geocoding API error: #{messages}") + when 500 # Unknown error + raise_error(Geocoder::Error, messages) || + warn("Mapquest Geocoding API error: #{messages}") + end end end end