X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/e799022131f3e833179e9058060ec5e136ed2edd..023e95f1bc6945dc1d20f3d228b126b12992bc0a:/app/controllers/old_node_controller.rb diff --git a/app/controllers/old_node_controller.rb b/app/controllers/old_node_controller.rb index 99e0b5675..2590fd24a 100644 --- a/app/controllers/old_node_controller.rb +++ b/app/controllers/old_node_controller.rb @@ -1,22 +1,45 @@ class OldNodeController < ApplicationController + require 'xml/libxml' + + session :off + before_filter :check_api_readable + after_filter :compress_output def history - response.headers["Content-Type"] = 'application/xml' - node = Node.find(params[:id]) + begin + node = Node.find(params[:id]) - unless node - render :nothing => true, :staus => 404 - return - end + doc = OSM::API.new.get_xml_doc - doc = get_xml_doc + node.old_nodes.each do |old_node| + doc.root << old_node.to_xml_node + end - node.old_nodes.each do |old_node| - doc.root << old_node.to_xml_node + render :text => doc.to_s, :content_type => "text/xml" + rescue ActiveRecord::RecordNotFound + render :nothing => true, :status => :not_found + rescue + render :nothing => true, :status => :internal_server_error end - - render :text => doc.to_s end + + def version + begin + old_node = OldNode.find(:first, :conditions => {:id => params[:id], :version => params[:version]} ) + if old_node.nil? + # (RecordNotFound is not raised with find :first...) + render :nothing => true, :status => :not_found + return + end + + response.headers['Last-Modified'] = old_node.timestamp.rfc822 + doc = OSM::API.new.get_xml_doc + doc.root << old_node.to_xml_node + render :text => doc.to_s, :content_type => "text/xml" + rescue + render :nothing => true, :status => :internal_server_error + end + end end