]> git.openstreetmap.org Git - rails.git/blob - app/controllers/user_preference_controller.rb
Strip illegal characters from member roles in AMF uploads
[rails.git] / app / controllers / user_preference_controller.rb
1 # Update and read user preferences, which are arbitrayr key/val pairs
2 class UserPreferenceController < ApplicationController
3   skip_before_filter :verify_authenticity_token
4   before_filter :authorize
5   before_filter :require_allow_read_prefs, :only => [:read_one, :read]
6   before_filter :require_allow_write_prefs, :except => [:read_one, :read]
7   around_filter :api_call_handle_error
8
9   ##
10   # return all the preferences as an XML document
11   def read
12     doc = OSM::API.new.get_xml_doc
13
14     prefs = @user.preferences
15
16     el1 = XML::Node.new 'preferences'
17
18     prefs.each do |pref|
19       el1 <<  pref.to_xml_node
20     end
21
22     doc.root << el1
23     render :text => doc.to_s, :content_type => "text/xml"
24   end
25
26   ##
27   # return the value for a single preference
28   def read_one
29     pref = UserPreference.find(@user.id, params[:preference_key])
30
31     render :text => pref.v.to_s, :content_type => "text/plain"
32   end
33
34   # update the entire set of preferences
35   def update
36     old_preferences = @user.preferences.reduce({}) do |preferences,preference|
37       preferences[preference.k] = preference
38       preferences
39     end
40
41     new_preferences = {}
42
43     doc = XML::Parser.string(request.raw_post).parse
44
45     doc.find('//preferences/preference').each do |pt|
46       if preference = old_preferences.delete(pt["k"])
47         preference.v = pt["v"]
48       elsif new_preferences.include?(pt["k"])
49         raise OSM::APIDuplicatePreferenceError.new(pt["k"])
50       else
51         preference = @user.preferences.build(:k => pt["k"], :v => pt["v"])
52       end
53
54       new_preferences[preference.k] = preference
55     end
56
57     old_preferences.each_value do |preference|
58       preference.delete
59     end
60
61     new_preferences.each_value do |preference|
62       preference.save!
63     end
64
65     render :text => "", :content_type => "text/plain"
66   end
67
68   ##
69   # update the value of a single preference
70   def update_one
71     begin
72       pref = UserPreference.find(@user.id, params[:preference_key])
73     rescue ActiveRecord::RecordNotFound 
74       pref = UserPreference.new
75       pref.user = @user
76       pref.k = params[:preference_key]
77     end
78
79     pref.v = request.raw_post.chomp
80     pref.save!
81
82     render :text => "", :content_type => "text/plain"
83   end
84
85   ##
86   # delete a single preference
87   def delete_one
88     UserPreference.find(@user.id, params[:preference_key]).delete
89
90     render :text => "", :content_type => "text/plain"
91   end
92 end