aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/rails
diff options
context:
space:
mode:
authorSantiago Pastorino <santiago@wyeworks.com>2012-11-01 20:23:21 -0200
committerSantiago Pastorino <santiago@wyeworks.com>2012-11-03 14:57:54 -0200
commit851e8fe897633f095a0f39a91f8bc75eee7a76aa (patch)
tree22d5d2d4e4d35c2528790d756537b4e9fa590a4a /railties/lib/rails
parent47da5744741f0af668d2f915e09003be35dcce66 (diff)
downloadrails-851e8fe897633f095a0f39a91f8bc75eee7a76aa.tar.gz
rails-851e8fe897633f095a0f39a91f8bc75eee7a76aa.tar.bz2
rails-851e8fe897633f095a0f39a91f8bc75eee7a76aa.zip
Cache generated keys per KeyGenerator instance using salt + key_size
Diffstat (limited to 'railties/lib/rails')
-rw-r--r--railties/lib/rails/application.rb13
1 files changed, 8 insertions, 5 deletions
diff --git a/railties/lib/rails/application.rb b/railties/lib/rails/application.rb
index 3ec29e1dd6..f484e1737c 100644
--- a/railties/lib/rails/application.rb
+++ b/railties/lib/rails/application.rb
@@ -108,11 +108,14 @@ module Rails
def key_generator
# number of iterations selected based on consultation with the google security
# team. Details at https://github.com/rails/rails/pull/6952#issuecomment-7661220
- @key_generator ||= if config.secret_token_key
- ActiveSupport::KeyGenerator.new(config.secret_token_key, iterations: 1000)
- else
- ActiveSupport::DummyKeyGenerator.new(config.secret_token)
- end
+ @caching_key_generator ||= begin
+ if config.secret_token_key
+ key_generator = ActiveSupport::KeyGenerator.new(config.secret_token_key, iterations: 1000)
+ ActiveSupport::CachingKeyGenerator.new(key_generator)
+ else
+ ActiveSupport::DummyKeyGenerator.new(config.secret_token)
+ end
+ end
end
# Stores some of the Rails initial environment parameters which