diff options
author | Michael Koziarski <michael@koziarski.com> | 2012-10-02 14:26:16 -0700 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2012-10-02 14:26:16 -0700 |
commit | 0a507925cfc54246dc7d329936f60f8f410c38b6 (patch) | |
tree | f97e4a6a7c36cdd5af7b82330b9414bd94cb6991 /activesupport/lib | |
parent | df08271f9c044b7614d70baf4b818f1a79f4a6e1 (diff) | |
parent | 0479bff32dfb26a420b9ab4e2c2e6c2ed17550a3 (diff) | |
download | rails-0a507925cfc54246dc7d329936f60f8f410c38b6.tar.gz rails-0a507925cfc54246dc7d329936f60f8f410c38b6.tar.bz2 rails-0a507925cfc54246dc7d329936f60f8f410c38b6.zip |
Merge pull request #6952 from NZKoz/key_generator
Add ActiveSupport::KeyGenerator as a simple wrapper around PBKDF2
Diffstat (limited to 'activesupport/lib')
-rw-r--r-- | activesupport/lib/active_support.rb | 1 | ||||
-rw-r--r-- | activesupport/lib/active_support/key_generator.rb | 23 |
2 files changed, 24 insertions, 0 deletions
diff --git a/activesupport/lib/active_support.rb b/activesupport/lib/active_support.rb index 41d77ab6c1..4e397ea110 100644 --- a/activesupport/lib/active_support.rb +++ b/activesupport/lib/active_support.rb @@ -48,6 +48,7 @@ module ActiveSupport autoload :Gzip autoload :Inflector autoload :JSON + autoload :KeyGenerator autoload :MessageEncryptor autoload :MessageVerifier autoload :Multibyte diff --git a/activesupport/lib/active_support/key_generator.rb b/activesupport/lib/active_support/key_generator.rb new file mode 100644 index 0000000000..04d170f801 --- /dev/null +++ b/activesupport/lib/active_support/key_generator.rb @@ -0,0 +1,23 @@ +require 'openssl' + +module ActiveSupport + # KeyGenerator is a simple wrapper around OpenSSL's implementation of PBKDF2 + # It can be used to derive a number of keys for various purposes from a given secret. + # This lets rails applications have a single secure secret, but avoid reusing that + # key in multiple incompatible contexts. + class KeyGenerator + def initialize(secret, options = {}) + @secret = secret + # The default iterations are higher than required for our key derivation uses + # on the off chance someone uses this for password storage + @iterations = options[:iterations] || 2**16 + end + + # Returns a derived key suitable for use. The default key_size is chosen + # to be compatible with the default settings of ActiveSupport::MessageVerifier. + # i.e. OpenSSL::Digest::SHA1#block_length + def generate_key(salt, key_size=64) + OpenSSL::PKCS5.pbkdf2_hmac_sha1(@secret, salt, @iterations, key_size) + end + end +end |