X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/e1b205913c9afd6b41684add7308cef4613112e2..b91b514cf22f04910c83b6dcc254908ed37d7413:/app/models/node.rb?ds=sidebyside diff --git a/app/models/node.rb b/app/models/node.rb index d152be6d3..e7058a5ad 100644 --- a/app/models/node.rb +++ b/app/models/node.rb @@ -2,6 +2,7 @@ class Node < ActiveRecord::Base require 'xml/libxml' include GeoRecord + include ConsistencyValidations set_table_name 'current_nodes' @@ -131,16 +132,18 @@ class Node < ActiveRecord::Base end end - def delete_with_history(user) + # Should probably be renamed delete_from to come in line with update + def delete_with_history(new_node, user) if self.visible + check_consistency(self, new_node, user) 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.changeset_id = new_node.changeset_id + self.visible = 0 + save_with_history! end else raise OSM::APIAlreadyDeletedError.new @@ -148,12 +151,10 @@ class Node < ActiveRecord::Base end def update_from(new_node, user) - if new_node.version != version - raise OSM::APIVersionMismatchError.new(new_node.version, version) - end + check_consistency(self, new_node, user) - # FIXME logic need looked at - self.changeset_id = user.id + # FIXME logic needs to be double checked + self.changeset_id = new_node.changeset_id self.latitude = new_node.latitude self.longitude = new_node.longitude self.tags = new_node.tags @@ -196,7 +197,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