# Create a node from XML.
def create
- if request.put?
- node = Node.from_xml(request.raw_post, true)
- # FIXME remove debug
- logger.debug request.raw_post
- logger.debug node
-
- if node
- node.version = 0
- #node.changeset_id = node.changeset
- node.visible = true
- node.save_with_history!
+ begin
+ if request.put?
+ node = Node.from_xml(request.raw_post, true)
- render :text => node.id.to_s, :content_type => "text/plain"
+ if node
+ node.create_with_history @user
+ render :text => node.id.to_s, :content_type => "text/plain"
+ else
+ render :nothing => true, :status => :bad_request
+ end
else
- render :nothing => true, :status => :bad_request
+ render :nothing => true, :status => :method_not_allowed
end
- else
- render :nothing => true, :status => :method_not_allowed
+ rescue OSM::APIError => ex
+ render ex.render_opts
end
end
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 OSM::APIError => ex
+ render ex.render_opts
rescue ActiveRecord::RecordNotFound
render :nothing => true, :status => :not_found
end
def delete
begin
node = Node.find(params[:id])
+ new_node = Node.from_xml(request.raw_post)
# FIXME we no longer care about the user, (or maybe we want to check
# that the user of the changeset is the same user as is making this
# little change?) we really care about the
# changeset which must be open, and that the version that we have been
# given is the one that is currently stored in the database
- node.delete_with_history(@user)
-
- render :nothing => true
+
+ if new_node and new_node.id == node.id
+ node.delete_with_history(new_node, @user)
+ render :nothing => true
+ else
+ render :nothing => true, :status => :bad_request
+ end
rescue ActiveRecord::RecordNotFound
render :nothing => true, :status => :not_found
rescue OSM::APIError => ex