require 'xml/libxml'
include GeoRecord
+ include ConsistencyValidations
set_table_name 'current_nodes'
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
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
self.visible = true
save_with_history!
end
+
+ def create_with_history(user)
+ check_create_consistency(self, user)
+ self.version = 0
+ self.visible = true
+ save_with_history!
+ end
def to_xml
doc = OSM::API.new.get_xml_doc
el1['visible'] = self.visible.to_s
el1['timestamp'] = self.timestamp.xmlschema
- el1['version'] = self.version.to_s
return el1
end