X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/c76e60f052051a35fe7e9044969337cd88e5b1fd..898cc828dd1f1167f85abbf35c8e3f0ed640ac1e:/app/controllers/user_preference_controller.rb?ds=sidebyside diff --git a/app/controllers/user_preference_controller.rb b/app/controllers/user_preference_controller.rb index 3b56c257b..377e78313 100644 --- a/app/controllers/user_preference_controller.rb +++ b/app/controllers/user_preference_controller.rb @@ -1,6 +1,9 @@ # Update and read user preferences, which are arbitrayr key/val pairs class UserPreferenceController < ApplicationController + skip_before_filter :verify_authenticity_token before_filter :authorize + before_filter :require_allow_read_prefs, :only => [:read_one, :read] + before_filter :require_allow_write_prefs, :except => [:read_one, :read] def read_one pref = UserPreference.find(@user.id, params[:preference_key]) @@ -52,8 +55,11 @@ class UserPreferenceController < ApplicationController # update the entire set of preferences def update - p = XML::Parser.new - p.string = request.raw_post + begin + p = XML::Parser.string(request.raw_post) + rescue LibXML::XML::Error, ArgumentError => ex + raise OSM::APIBadXMLError.new("preferences", xml, ex.message) + end doc = p.parse prefs = []