diff options
author | Kasper Timm Hansen <kaspth@gmail.com> | 2015-09-06 17:55:50 +0200 |
---|---|---|
committer | Kasper Timm Hansen <kaspth@gmail.com> | 2015-09-08 20:27:05 +0200 |
commit | 39882c49dcb099d764788b00c64e629003235d63 (patch) | |
tree | b9a73452df4878a7ed1865a7f2d59466fc3c97e7 | |
parent | 94b313db8d672a57ad5deb63203e334fe1184b84 (diff) | |
download | rails-39882c49dcb099d764788b00c64e629003235d63.tar.gz rails-39882c49dcb099d764788b00c64e629003235d63.tar.bz2 rails-39882c49dcb099d764788b00c64e629003235d63.zip |
Add parse method to share deserialization logic.
Cuts down on the duplicated reading parts.
-rw-r--r-- | actionpack/lib/action_dispatch/middleware/cookies.rb | 31 |
1 files changed, 12 insertions, 19 deletions
diff --git a/actionpack/lib/action_dispatch/middleware/cookies.rb b/actionpack/lib/action_dispatch/middleware/cookies.rb index d863d84a1c..b27236d5fa 100644 --- a/actionpack/lib/action_dispatch/middleware/cookies.rb +++ b/actionpack/lib/action_dispatch/middleware/cookies.rb @@ -420,7 +420,9 @@ module ActionDispatch end def [](name) - @parent_jar[name.to_s] + if data = @parent_jar[name.to_s] + parse name, data + end end def []=(name, options) @@ -435,6 +437,7 @@ module ActionDispatch end private + def parse(name, data); data; end def commit(options); end end @@ -505,15 +508,11 @@ module ActionDispatch @verifier = ActiveSupport::MessageVerifier.new(secret, digest: digest, serializer: ActiveSupport::MessageEncryptor::NullSerializer) end - # Returns the value of the cookie by +name+ if it is untampered, - # returns +nil+ otherwise or if no such cookie exists. - def [](name) - if signed_message = @parent_jar[name] + private + def parse(name, signed_message) deserialize name, verify(signed_message) end - end - private def commit(options) options[:value] = @verifier.generate(serialize(options[:value])) @@ -534,11 +533,10 @@ module ActionDispatch class UpgradeLegacySignedCookieJar < SignedCookieJar #:nodoc: include VerifyAndUpgradeLegacySignedMessage - def [](name) - if signed_message = @parent_jar[name] + private + def parse(name, signed_message) deserialize(name, verify(signed_message)) || verify_and_upgrade_legacy_signed_message(name, signed_message) end - end end class EncryptedCookieJar < AbstractCookieJar # :nodoc: @@ -557,15 +555,11 @@ module ActionDispatch @encryptor = ActiveSupport::MessageEncryptor.new(secret, sign_secret, digest: digest, serializer: ActiveSupport::MessageEncryptor::NullSerializer) end - # Returns the value of the cookie by +name+ if it is untampered, - # returns +nil+ otherwise or if no such cookie exists. - def [](name) - if encrypted_message = @parent_jar[name] + private + def parse(name, encrypted_message) deserialize name, decrypt_and_verify(encrypted_message) end - end - private def commit(options) options[:value] = @encryptor.encrypt_and_sign(serialize(options[:value])) @@ -586,11 +580,10 @@ module ActionDispatch class UpgradeLegacyEncryptedCookieJar < EncryptedCookieJar #:nodoc: include VerifyAndUpgradeLegacySignedMessage - def [](name) - if encrypted_or_signed_message = @parent_jar[name] + private + def parse(name, encrypted_or_signed_message) deserialize(name, decrypt_and_verify(encrypted_or_signed_message)) || verify_and_upgrade_legacy_signed_message(name, encrypted_or_signed_message) end - end end def initialize(app) |