From: Gabriel Ebner Date: Mon, 12 May 2008 21:05:11 +0000 (+0000) Subject: api06: Move version-checking into the models, raising an exception on mismatch X-Git-Tag: live~7577^2~343 X-Git-Url: https://git.openstreetmap.org/rails.git/commitdiff_plain/86b4d1bc2c05a68053c7485217144a7fcf8ef4e8?ds=sidebyside api06: Move version-checking into the models, raising an exception on mismatch (still not implemented for delete requests though.) --- diff --git a/app/controllers/node_controller.rb b/app/controllers/node_controller.rb index fa6759c3b..379ee77c9 100644 --- a/app/controllers/node_controller.rb +++ b/app/controllers/node_controller.rb @@ -49,10 +49,6 @@ class NodeController < ApplicationController begin node = Node.find(params[:id]) new_node = Node.from_xml(request.raw_post) - if new_node.version != node.version - render :text => "Version mismatch: Provided " + new_node.version.to_s + ", server had: " + node.version.to_s, :status => :bad_request - return - end if new_node and new_node.id == node.id node.update_from(new_node, @user) @@ -60,6 +56,9 @@ class NodeController < ApplicationController else render :nothing => true, :status => :bad_request end + rescue OSM::APIVersionMismatchError ex + render :text => "Version mismatch: Provided " + ex.provided.to_s + + ", server had: " + ex.latest.to_s, :status => :bad_request rescue ActiveRecord::RecordNotFound render :nothing => true, :status => :not_found end diff --git a/app/controllers/relation_controller.rb b/app/controllers/relation_controller.rb index d7b9de13c..dabf6eaa8 100644 --- a/app/controllers/relation_controller.rb +++ b/app/controllers/relation_controller.rb @@ -64,6 +64,9 @@ class RelationController < ApplicationController render :nothing => true, :status => :not_found rescue OSM::APIPreconditionFailedError render :text => "", :status => :precondition_failed + rescue OSM::APIVersionMismatchError => ex + render :text => "Version mismatch: Provided " + ex.provided.to_s + + ", server had: " + ex.latest.to_s, :status => :bad_request rescue render :nothing => true, :status => :internal_server_error end diff --git a/app/controllers/way_controller.rb b/app/controllers/way_controller.rb index d3a1b039f..b22d35d0b 100644 --- a/app/controllers/way_controller.rb +++ b/app/controllers/way_controller.rb @@ -49,11 +49,6 @@ class WayController < ApplicationController begin way = Way.find(params[:id]) new_way = Way.from_xml(request.raw_post) - if new_way.version != way.version - render :text => "Version mismatch: Provided " + new_way.version.to_s + ", server had: " + way.version.to_s, :status => :bad_request - return - end - if new_way and new_way.id == way.id way.update_from(new_way, @user) @@ -63,6 +58,9 @@ class WayController < ApplicationController end rescue OSM::APIPreconditionFailedError render :text => "", :status => :precondition_failed + rescue OSM::APIVersionMismatchError => ex + render :text => "Version mismatch: Provided " + ex.provided.to_s + + ", server had: " + ex.latest.to_s, :status => :bad_request rescue ActiveRecord::RecordNotFound render :nothing => true, :status => :not_found end diff --git a/app/models/node.rb b/app/models/node.rb index 5f4133819..b027f2fd4 100644 --- a/app/models/node.rb +++ b/app/models/node.rb @@ -140,6 +140,10 @@ class Node < GeoRecord end def update_from(new_node, user) + if new_node.version != version + raise OSM::APIVersionMismatchError.new(new_node.version, version) + end + self.user_id = user.id self.latitude = new_node.latitude self.longitude = new_node.longitude diff --git a/app/models/relation.rb b/app/models/relation.rb index b7cb0f15b..984732c71 100644 --- a/app/models/relation.rb +++ b/app/models/relation.rb @@ -224,6 +224,8 @@ class Relation < ActiveRecord::Base def update_from(new_relation, user) if !new_relation.preconditions_ok? raise OSM::APIPreconditionFailedError.new + elsif new_relation.version != version + raise OSM::APIVersionMismatchError.new(new_relation.version, version) else self.user_id = user.id self.tags = new_relation.tags diff --git a/app/models/way.rb b/app/models/way.rb index de69f7565..a6192e2d7 100644 --- a/app/models/way.rb +++ b/app/models/way.rb @@ -199,6 +199,8 @@ class Way < ActiveRecord::Base def update_from(new_way, user) if !new_way.preconditions_ok? raise OSM::APIPreconditionFailedError.new + elsif new_way.version != version + raise OSM::APIVersionMismatchError.new(new_way.version, version) else self.user_id = user.id self.tags = new_way.tags diff --git a/lib/osm.rb b/lib/osm.rb index bd9351026..a8cb103d2 100644 --- a/lib/osm.rb +++ b/lib/osm.rb @@ -24,6 +24,15 @@ module OSM class APIAlreadyDeletedError < APIError end + # Raised when the provided version is not equal to the latest in the db. + class APIVersionMismatchError < APIError + def initialize(provided, latest) + @provided, @latest = provided, latest + end + + attr_reader :provided, :latest + end + # Helper methods for going to/from mercator and lat/lng. class Mercator include Math