aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKasper Timm Hansen <kaspth@gmail.com>2015-09-06 17:55:50 +0200
committerKasper Timm Hansen <kaspth@gmail.com>2015-09-08 20:27:05 +0200
commit39882c49dcb099d764788b00c64e629003235d63 (patch)
treeb9a73452df4878a7ed1865a7f2d59466fc3c97e7
parent94b313db8d672a57ad5deb63203e334fe1184b84 (diff)
downloadrails-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.rb31
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)