adding the controller code to be able to get a specific version of a node, way or...
authorShaun McDonald <shaun@shaunmcdonald.me.uk>
Wed, 8 Oct 2008 18:03:41 +0000 (18:03 +0000)
committerShaun McDonald <shaun@shaunmcdonald.me.uk>
Wed, 8 Oct 2008 18:03:41 +0000 (18:03 +0000)
app/controllers/old_node_controller.rb
app/controllers/old_relation_controller.rb
app/controllers/old_way_controller.rb
app/controllers/relation_controller.rb
app/models/node.rb
app/models/relation.rb
lib/osm.rb

index e27898336361832ed193c9d1b3c8de04ddb14a41..8c43941ec61b0404634da02a834fe59d0281328a 100644 (file)
@@ -22,4 +22,19 @@ class OldNodeController < ApplicationController
       render :nothing => true, :status => :internal_server_error
     end
   end
+  
+  def version
+    begin
+      old_node = OldNode.find(:first, :conditions => {:id => params[:id], :version => params[:version]} )
+
+      doc = OSM::API.new.get_xml_doc
+      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
+  end
 end
index 0b5aa89be885f18c03cf83c46097778efc839610..9307ee1ce4a8c61b5d6d29bd08f09dda14893f47 100644 (file)
@@ -2,6 +2,7 @@ class OldRelationController < ApplicationController
   require 'xml/libxml'
 
   session :off
+  before_filter :check_read_availability
   after_filter :compress_output
 
   def history
@@ -20,4 +21,19 @@ class OldRelationController < ApplicationController
       render :nothing => true, :status => :internal_server_error
     end
   end
+  
+  def version
+    begin
+      old_relation = OldRelation.find(:first, :conditions => {:id => params[:id], :version => params[:version]} )
+
+      doc = OSM::API.new.get_xml_doc
+      doc.root << old_relation.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 => :internetal_service_error
+    end
+  end
 end
index e72c97a0078022650a8484d08c070b7d67fed6c7..6cd8c8f22aaf23f8c6cbe00ed9299ec31ee1e8e8 100644 (file)
@@ -22,4 +22,19 @@ class OldWayController < ApplicationController
       render :nothing => true, :status => :internal_server_error
     end
   end
+  
+  def version
+    begin
+      old_way = OldWay.find(:first, :conditions => {:id => params[:id], :version => params[:version]} )
+      
+      doc = OSM::API.new.get_xml_doc
+      doc.root << old_way.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
+  end
 end
index b38d90c02b07b569ba0572d92307e2b6eca5f712..d87905059ea37c8c791266fe0305de5a45c109bc 100644 (file)
@@ -46,6 +46,7 @@ class RelationController < ApplicationController
   end
 
   def update
+    logger.debug request.raw_post
     begin
       relation = Relation.find(params[:id])
       new_relation = Relation.from_xml(request.raw_post)
index d152be6d302eb881345a37b1962f2e09ced7e6d4..a25a19f703e14f266031264d2c3f566ea93255a3 100644 (file)
@@ -134,13 +134,13 @@ class Node < ActiveRecord::Base
   def delete_with_history(user)
     if self.visible
       if WayNode.find(:first, :joins => "INNER JOIN current_ways ON current_ways.id = current_way_nodes.id", :conditions => [ "current_ways.visible = 1 AND current_way_nodes.node_id = ?", self.id ])
-       raise OSM::APIPreconditionFailedError.new
+        raise OSM::APIPreconditionFailedError.new
       elsif RelationMember.find(:first, :joins => "INNER JOIN current_relations ON current_relations.id=current_relation_members.id", :conditions => [ "visible = 1 AND member_type='node' and member_id=?", self.id])
-       raise OSM::APIPreconditionFailedError.new
+        raise OSM::APIPreconditionFailedError.new
       else
-       self.user_id = user.id
-       self.visible = 0
-       save_with_history!
+        self.user_id = user.id
+        self.visible = 0
+        save_with_history!
       end
     else
       raise OSM::APIAlreadyDeletedError.new
@@ -150,10 +150,14 @@ class Node < ActiveRecord::Base
   def update_from(new_node, user)
     if new_node.version != version
       raise OSM::APIVersionMismatchError.new(new_node.version, version)
+    elsif new_node.changeset.user_id != user.id
+      raise OSM::APIUserChangesetMismatchError.new
+    elsif not new_node.changeset.open?
+      raise OSM::APIChangesetAlreadyClosedError.new
     end
 
     # FIXME logic need looked at
-    self.changeset_id = user.id
+    self.changeset_id = new_node.changeset_id
     self.latitude = new_node.latitude 
     self.longitude = new_node.longitude
     self.tags = new_node.tags
@@ -196,7 +200,6 @@ class Node < ActiveRecord::Base
 
     el1['visible'] = self.visible.to_s
     el1['timestamp'] = self.timestamp.xmlschema
-    el1['version'] = self.version.to_s
     return el1
   end
 
index 658cf06f379e72d63e98045131884047ddc0fe1e..93f0001da0f7bd3119321bf8fc5612389a521bab 100644 (file)
@@ -246,7 +246,7 @@ class Relation < ActiveRecord::Base
     else
       # FIXME need to deal with changeset etc
       #self.user_id = user.id
-      self.changeset = new_relation.changeset
+      self.changeset_id = new_relation.changeset_id
       self.tags = new_relation.tags
       self.members = new_relation.members
       self.visible = true
index 3ddf10f989c0572a48b3480059b419417d7e5756..e0e83845ea4b33ece2dda45f0c0ff3368d73feee 100644 (file)
@@ -57,7 +57,7 @@ module OSM
 
     def render_opts
       { :text => "Version mismatch: Provided " + provided.to_s +
-       ", server had: " + latest.to_s, :status => :bad_request }
+      ", server had: " + latest.to_s, :status => :conflict }
     end
   end