Make the multi-get calls throw 400 errors on invalid input
Also refactor ways and relations to use the same structure as nodes
This commit is contained in:
parent
ec9634d865
commit
a1a5706203
3 changed files with 31 additions and 23 deletions
|
@ -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
|
||||
|
|
|
@ -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
|
||||
|
||||
Relation.find(ids).each do |relation|
|
||||
doc.root << relation.to_xml_node
|
||||
end
|
||||
|
||||
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
|
||||
if ids.length == 0
|
||||
raise OSM::APIBadUserInput.new("No relations were given to search for")
|
||||
end
|
||||
|
||||
doc = OSM::API.new.get_xml_doc
|
||||
|
||||
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
|
||||
|
|
|
@ -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
|
||||
|
||||
render :text => doc.to_s, :content_type => "text/xml"
|
||||
else
|
||||
render :text => "", :status => :bad_request
|
||||
if ids.length == 0
|
||||
raise OSM::APIBadUserInput.new("No ways were given to search for")
|
||||
end
|
||||
|
||||
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
|
||||
|
||||
##
|
||||
|
|
Loading…
Add table
Reference in a new issue