Add a flag to allow the API to be placed in read-only mode.
[rails.git] / app / controllers / node_controller.rb
1 class NodeController < ApplicationController
2   require 'xml/libxml'
3
4   before_filter :authorize, :only => [:create, :update, :delete]
5   before_filter :check_availability, :only => [:create, :update, :delete]
6   after_filter :compress_output
7
8   def create
9     if request.put?
10       node = Node.from_xml(request.raw_post, true)
11
12       if node
13         node.user_id = @user.id
14         node.visible = true
15
16         if node.save_with_history
17           render :text => node.id.to_s, :content_type => "text/plain"
18         else
19           render :nothing => true, :status => :internal_server_error
20         end
21       else
22         render :nothing => true, :status => :bad_request
23       end
24     else
25       render :nothing => true, :status => :method_not_allowed
26     end
27   end
28
29   def read
30     begin
31       node = Node.find(params[:id])
32
33       if node.visible
34         render :text => node.to_xml.to_s, :content_type => "text/xml"
35        else
36         render :nothing => true, :status => :gone
37       end
38     rescue ActiveRecord::RecordNotFound
39       render :nothing => true, :status => :not_found
40     rescue
41       render :nothing => true, :status => :internal_server_error
42     end
43   end
44
45   def update
46     begin
47       node = Node.find(params[:id])
48
49       if node.visible
50         new_node = Node.from_xml(request.raw_post)
51
52         if new_node and new_node.id == node.id
53           node.user_id = @user.id
54           node.latitude = new_node.latitude 
55           node.longitude = new_node.longitude
56           node.tags = new_node.tags
57
58           if node.save_with_history
59             render :nothing => true
60           else
61             render :nothing => true, :status => :internal_server_error
62           end
63         else
64           render :nothing => true, :status => :bad_request
65         end
66       else
67         render :nothing => true, :status => :gone
68       end
69     rescue ActiveRecord::RecordNotFound
70       render :nothing => true, :status => :not_found
71     rescue
72       render :nothing => true, :status => :internal_server_error
73     end
74   end
75
76   def delete
77     begin
78       node = Node.find(params[:id])
79
80       if node.visible
81         if Segment.find(:first, :conditions => [ "visible = 1 and (node_a = ? or node_b = ?)", node.id, node.id])
82           render :nothing => true, :status => :precondition_failed
83         else
84           node.user_id = @user.id
85           node.visible = 0
86           node.save_with_history
87           render :nothing => true
88         end
89       else
90         render :nothing => true, :status => :gone
91       end
92     rescue ActiveRecord::RecordNotFound
93       render :nothing => true, :status => :not_found
94     rescue
95       render :nothing => true, :status => :internal_server_error
96     end
97   end
98
99   def nodes
100     ids = params['nodes'].split(',').collect { |n| n.to_i }
101
102     if ids.length > 0
103       doc = OSM::API.new.get_xml_doc
104
105       Node.find(ids).each do |node|
106         doc.root << node.to_xml_node
107       end 
108
109       render :text => doc.to_s, :content_type => "text/xml"
110     else
111       render :nothing => true, :status => :bad_request
112     end
113   end
114 end