From: Paul Norman Date: Sat, 3 Aug 2013 10:20:46 +0000 (-0700) Subject: Make the multi-get calls throw 400 errors on invalid input X-Git-Tag: live~4821 X-Git-Url: https://git.openstreetmap.org/rails.git/commitdiff_plain/a1a5706203b80f819be25d1563008ecd3039fe6c?ds=sidebyside Make the multi-get calls throw 400 errors on invalid input Also refactor ways and relations to use the same structure as nodes --- diff --git a/app/controllers/node_controller.rb b/app/controllers/node_controller.rb index a172b2dd7..1e34bc10d 100644 --- a/app/controllers/node_controller.rb +++ b/app/controllers/node_controller.rb @@ -64,6 +64,10 @@ class NodeController < ApplicationController # Dump the details on many nodes whose ids are given in the "nodes" parameter. def nodes + if not params['nodes'] + raise OSM::APIBadUserInput.new("The parameter nodes is required, and must be of the form nodes=id[,id[,id...]]") + end + ids = params['nodes'].split(',').collect { |n| n.to_i } if ids.length == 0 diff --git a/app/controllers/relation_controller.rb b/app/controllers/relation_controller.rb index 39021218f..9e7466a4a 100644 --- a/app/controllers/relation_controller.rb +++ b/app/controllers/relation_controller.rb @@ -130,19 +130,23 @@ class RelationController < ApplicationController end def relations + if not params['relations'] + raise OSM::APIBadUserInput.new("The parameter relations is required, and must be of the form relations=id[,id[,id...]]") + end + ids = params['relations'].split(',').collect { |w| w.to_i } - if ids.length > 0 - doc = OSM::API.new.get_xml_doc + if ids.length == 0 + raise OSM::APIBadUserInput.new("No relations were given to search for") + end - Relation.find(ids).each do |relation| - doc.root << relation.to_xml_node - end + doc = OSM::API.new.get_xml_doc - render :text => doc.to_s, :content_type => "text/xml" - else - render :text => "You need to supply a comma separated list of ids.", :status => :bad_request + Relation.find(ids).each do |relation| + doc.root << relation.to_xml_node end + + render :text => doc.to_s, :content_type => "text/xml" end def relations_for_way diff --git a/app/controllers/way_controller.rb b/app/controllers/way_controller.rb index 6ea27deaf..2ce49b7e8 100644 --- a/app/controllers/way_controller.rb +++ b/app/controllers/way_controller.rb @@ -84,23 +84,23 @@ class WayController < ApplicationController end def ways - begin - ids = params['ways'].split(',').collect { |w| w.to_i } - rescue - ids = [] + if not params['ways'] + raise OSM::APIBadUserInput.new("The parameter ways is required, and must be of the form ways=id[,id[,id...]]") end - if ids.length > 0 - doc = OSM::API.new.get_xml_doc + ids = params['ways'].split(',').collect { |w| w.to_i } - Way.find(ids).each do |way| - doc.root << way.to_xml_node - end + if ids.length == 0 + raise OSM::APIBadUserInput.new("No ways were given to search for") + end - render :text => doc.to_s, :content_type => "text/xml" - else - render :text => "", :status => :bad_request + doc = OSM::API.new.get_xml_doc + + Way.find(ids).each do |way| + doc.root << way.to_xml_node end + + render :text => doc.to_s, :content_type => "text/xml" end ##