prefs = @user.preferences
- el1 = XML::Node.new 'preferences'
+ el1 = XML::Node.new "preferences"
prefs.each do |pref|
el1 << pref.to_xml_node
# update the entire set of preferences
def update
- old_preferences = @user.preferences.reduce({}) do |preferences,preference|
+ old_preferences = @user.preferences.each_with_object({}) do |preference, preferences|
preferences[preference.k] = preference
- preferences
end
new_preferences = {}
doc = XML::Parser.string(request.raw_post).parse
- doc.find('//preferences/preference').each do |pt|
+ doc.find("//preferences/preference").each do |pt|
if preference = old_preferences.delete(pt["k"])
preference.v = pt["v"]
elsif new_preferences.include?(pt["k"])
- raise OSM::APIDuplicatePreferenceError.new(pt["k"])
+ fail OSM::APIDuplicatePreferenceError.new(pt["k"])
else
preference = @user.preferences.build(:k => pt["k"], :v => pt["v"])
end
new_preferences[preference.k] = preference
end
- old_preferences.each_value do |preference|
- preference.delete
- end
+ old_preferences.each_value(&:delete)
- new_preferences.each_value do |preference|
- preference.save!
- end
+ new_preferences.each_value(&:save!)
render :text => "", :content_type => "text/plain"
end