Made way controller return text/xml instead of text/html. Fixes #450
[rails.git] / app / controllers / way_controller.rb
1 class WayController < ApplicationController
2   require 'xml/libxml'
3
4   before_filter :authorize
5   after_filter :compress_output
6
7   def create
8     response.headers["Content-Type"] = 'text/xml'
9     if request.put?
10       way = Way.from_xml(request.raw_post, true)
11
12       if way
13         way.user_id = @user.id
14         unless way.preconditions_ok? # are the segments (and their nodes) visible?
15           render :nothing => true, :status => 412
16           return
17         end
18
19         if way.save_with_history
20           render :text => way.id.to_s
21           return
22         else
23           render :nothing => true, :status => 500
24           return
25         end
26         return
27       else
28         render :nothing => true, :status => 400 # if we got here the doc didnt parse
29         return
30       end
31     end
32
33     render :nothing => true, :status => 500 # something went very wrong
34   end
35
36   def full
37     unless Way.exists?(params[:id])
38       render :nothing => true, :status => 404
39       return
40     end
41
42     way = Way.find(params[:id])
43
44     unless way.visible
45       render :nothing => true, :status => 410
46       return
47     end
48
49     # In future, we might want to do all the data fetch in one step
50     seg_ids = way.segs + [-1]
51     segments = Segment.find_by_sql "select * from current_segments where visible = 1 and id IN (#{seg_ids.join(',')})"
52
53     node_ids = segments.collect {|segment| segment.node_a }
54     node_ids += segments.collect {|segment| segment.node_b }
55     node_ids += [-1]
56     nodes = Node.find(:all, :conditions => "visible = 1 AND id IN (#{node_ids.join(',')})")
57
58     # Render
59     doc = OSM::API.new.get_xml_doc
60     nodes.each do |node|
61       doc.root << node.to_xml_node()
62     end
63     segments.each do |segment|
64       doc.root << segment.to_xml_node()
65     end
66     doc.root << way.to_xml_node()
67
68     render :text => doc.to_s
69   end
70
71   def rest
72     response.headers["Content-Type"] = 'text/xml'
73     unless Way.exists?(params[:id])
74       render :nothing => true, :status => 404
75       return
76     end
77
78     way = Way.find(params[:id])
79
80     case request.method
81
82     when :get
83       unless way.visible
84         render :nothing => true, :status => 410
85         return
86       end
87       render :text => way.to_xml.to_s
88
89     when :delete
90       unless way.visible
91         render :nothing => true, :status => 410
92         return
93       end
94
95       way.visible = false
96       way.save_with_history
97       render :nothing => true
98       return
99     when :put
100       way = Way.from_xml(request.raw_post)
101
102       if way
103         way_in_db = Way.find(way.id)
104         if way_in_db
105           way_in_db.user_id = @user.id
106           way_in_db.tags = way.tags
107           way_in_db.segs = way.segs
108           way_in_db.timestamp = way.timestamp
109           way_in_db.visible = true
110           if way_in_db.save_with_history
111             render :text => way.id
112           else
113             render :nothing => true, :status => 500
114           end
115           return
116         else
117           render :nothing => true, :status => 404 # way doesn't exist yet
118         end
119       else
120         render :nothing => true, :status => 400 # if we got here the doc didnt parse
121         return
122       end
123     end
124   end
125
126   def ways
127     response.headers["Content-Type"] = 'text/xml'
128     ids = params['ways'].split(',').collect {|w| w.to_i }
129     if ids.length > 0
130       waylist = Way.find(ids)
131       doc = OSM::API.new.get_xml_doc
132       waylist.each do |way|
133         doc.root << way.to_xml_node
134       end
135       render :text => doc.to_s
136     else
137       render :nothing => true, :status => 400
138     end
139   end
140
141 end