diff options
author | Jon Leighton <j@jonathanleighton.com> | 2011-09-12 10:11:39 -0700 |
---|---|---|
committer | Jon Leighton <j@jonathanleighton.com> | 2011-09-12 10:11:39 -0700 |
commit | 8397a564cb03dec8bd3d083f3376ecdd439dbb70 (patch) | |
tree | 7d7299d979bf2197c7b3ecf343474bbb70857461 /activeresource/lib/active_resource | |
parent | 11fa70dd0903a75f2a507dd609ea640e8ec99373 (diff) | |
parent | a06d17480ff533fbc375df219a4e70886fb4899b (diff) | |
download | rails-8397a564cb03dec8bd3d083f3376ecdd439dbb70.tar.gz rails-8397a564cb03dec8bd3d083f3376ecdd439dbb70.tar.bz2 rails-8397a564cb03dec8bd3d083f3376ecdd439dbb70.zip |
Merge pull request #2678 from jmileham/ares_content_length_bug
ActiveResource shouldn't rely on the presence of Content-Length
Diffstat (limited to 'activeresource/lib/active_resource')
-rw-r--r-- | activeresource/lib/active_resource/base.rb | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/activeresource/lib/active_resource/base.rb b/activeresource/lib/active_resource/base.rb index 990d9a38dd..1ffd83b91d 100644 --- a/activeresource/lib/active_resource/base.rb +++ b/activeresource/lib/active_resource/base.rb @@ -1357,7 +1357,9 @@ module ActiveResource end def load_attributes_from_response(response) - if !response['Content-Length'].blank? && response['Content-Length'] != "0" && !response.body.nil? && response.body.strip.size > 0 + if (response_code_allows_body?(response.code) && + (response['Content-Length'].nil? || response['Content-Length'] != "0") && + !response.body.nil? && response.body.strip.size > 0) load(self.class.format.decode(response.body), true) @persisted = true end @@ -1381,6 +1383,12 @@ module ActiveResource end private + + # Determine whether the response is allowed to have a body per HTTP 1.1 spec section 4.4.1 + def response_code_allows_body?(c) + !((100..199).include?(c) || [204,304].include?(c)) + end + # Tries to find a resource for a given collection name; if it fails, then the resource is created def find_or_create_resource_for_collection(name) find_or_create_resource_for(ActiveSupport::Inflector.singularize(name.to_s)) |