X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/343e01bb86da6b346e035796121aba033bb26c29..f0b5776389bff72fd88cc3e628945fd6c0554f1e:/app/controllers/way_controller.rb diff --git a/app/controllers/way_controller.rb b/app/controllers/way_controller.rb index acc8a5d0c..dca9241a6 100644 --- a/app/controllers/way_controller.rb +++ b/app/controllers/way_controller.rb @@ -1,26 +1,26 @@ -class WayController < ApplicationController +class WayController < ApplicationController require 'xml/libxml' before_filter :authorize after_filter :compress_output - + def create + response.headers["Content-Type"] = 'text/xml' if request.put? way = Way.from_xml(request.raw_post, true) if way way.user_id = @user.id + unless way.preconditions_ok? # are the segments (and their nodes) visible? - render :nothing => true, :status => 412 + render :nothing => true, :status => HTTP_PRECONDITION_FAILED return end if way.save_with_history render :text => way.id.to_s - return else render :nothing => true, :status => 500 - return end return else @@ -32,7 +32,7 @@ class WayController < ApplicationController render :nothing => true, :status => 500 # something went very wrong end - def full + def full unless Way.exists?(params[:id]) render :nothing => true, :status => 404 return @@ -41,42 +41,44 @@ class WayController < ApplicationController way = Way.find(params[:id]) unless way.visible - render :nothing => true, :status => 410 - return + render :nothing => true, :status => 410 + return end - # In future, we might want to do all the data fetch in one step - seg_ids = way.segs + [-1] - segments = Segment.find_by_sql "select * from current_segments where visible = 1 and id IN (#{seg_ids.join(',')})" - - node_ids = segments.collect {|segment| segment.node_a } - node_ids += segments.collect {|segment| segment.node_b } - node_ids += [-1] - nodes = Node.find(:all, :conditions => "visible = 1 AND id IN (#{node_ids.join(',')})") - - # Render - doc = OSM::API.new.get_xml_doc - nodes.each do |node| - doc.root << node.to_xml_node() - end - segments.each do |segment| - doc.root << segment.to_xml_node() - end - doc.root << way.to_xml_node() + # In future, we might want to do all the data fetch in one step + seg_ids = way.segs + [-1] + segments = Segment.find_by_sql "select * from current_segments where visible = 1 and id IN (#{seg_ids.join(',')})" + + node_ids = segments.collect {|segment| segment.node_a } + node_ids += segments.collect {|segment| segment.node_b } + node_ids += [-1] + nodes = Node.find(:all, :conditions => "visible = 1 AND id IN (#{node_ids.join(',')})") + + # Render + doc = OSM::API.new.get_xml_doc + nodes.each do |node| + doc.root << node.to_xml_node() + end + segments.each do |segment| + doc.root << segment.to_xml_node() + end + doc.root << way.to_xml_node() render :text => doc.to_s end - def rest + def rest + response.headers["Content-Type"] = 'text/xml' unless Way.exists?(params[:id]) render :nothing => true, :status => 404 return end way = Way.find(params[:id]) + case request.method - when :get + when :get unless way.visible render :nothing => true, :status => 410 return @@ -84,38 +86,37 @@ class WayController < ApplicationController render :text => way.to_xml.to_s when :delete - unless way.visible + if way.visible + way.user_id = @user.id + way.visible = false + way.save_with_history + render :nothing => true + else render :nothing => true, :status => 410 - return end - way.visible = false - way.save_with_history - render :nothing => true - return when :put - way = Way.from_xml(request.raw_post) + new_way = Way.from_xml(request.raw_post) - if way - way_in_db = Way.find(way.id) - if way_in_db - way_in_db.user_id = @user.id - way_in_db.tags = way.tags - way_in_db.segs = way.segs - way_in_db.timestamp = way.timestamp - way_in_db.visible = true - if way_in_db.save_with_history - render :text => way.id - else - render :nothing => true, :status => 500 - end + if new_way + unless new_way.preconditions_ok? # are the segments (and their nodes) visible? + render :nothing => true, :status => HTTP_PRECONDITION_FAILED return + end + + way.user_id = @user.id + way.tags = new_way.tags + way.segs = new_way.segs + way.timestamp = new_way.timestamp + way.visible = true + + if way.id == new_way.id and way.save_with_history + render :nothing => true else - render :nothing => true, :status => 404 # way doesn't exist yet + render :nothing => true, :status => 500 end else render :nothing => true, :status => 400 # if we got here the doc didnt parse - return end end end @@ -128,7 +129,22 @@ class WayController < ApplicationController doc = OSM::API.new.get_xml_doc waylist.each do |way| doc.root << way.to_xml_node - end + end + render :text => doc.to_s + else + render :nothing => true, :status => 400 + end + end + + def ways_for_segment + response.headers["Content-Type"] = 'text/xml' + wayids = WaySegment.find(:all, :conditions => ['segment_id = ?', params[:id]]).collect { |ws| ws.id }.uniq + if wayids.length > 0 + waylist = Way.find(wayids) + doc = OSM::API.new.get_xml_doc + waylist.each do |way| + doc.root << way.to_xml_node + end render :text => doc.to_s else render :nothing => true, :status => 400