Class: Authlogic::CryptoProviders::AES256
- Inherits:
-
Object
- Object
- Authlogic::CryptoProviders::AES256
- Defined in:
- lib/novelys_authlogic/crypto_providers/aes256.rb
Overview
This encryption method is reversible if you have the supplied key. So in order to use this encryption method you must supply it with a key first. In an initializer, or before your application initializes, you should do the following:
Authlogic::CryptoProviders::AES256.key = "my really long and unique key, preferrably a bunch of random characters"
My final comment is that this is a strong encryption method, but its main weakness is that its reversible. If you do not need to reverse the hash then you should consider Sha512 or BCrypt instead.
Keep your key in a safe place, some even say the key should be stored on a separate server. This won’t hurt performance because the only time it will try and access the key on the separate server is during initialization, which only happens once. The reasoning behind this is if someone does compromise your server they won’t have the key also. Basically, you don’t want to store the key with the lock.
Class Attribute Summary collapse
-
.key ⇒ Object
writeonly
Sets the attribute key.
Class Method Summary collapse
Class Attribute Details
.key=(value) ⇒ Object (writeonly)
Sets the attribute key
19 20 21 |
# File 'lib/novelys_authlogic/crypto_providers/aes256.rb', line 19 def key=(value) @key = value end |
Class Method Details
.encrypt(*tokens) ⇒ Object
21 22 23 24 25 |
# File 'lib/novelys_authlogic/crypto_providers/aes256.rb', line 21 def encrypt(*tokens) aes.encrypt aes.key = @key [aes.update(tokens.join) + aes.final].pack("m").chomp end |
.matches?(crypted, *tokens) ⇒ Boolean
27 28 29 30 31 32 33 |
# File 'lib/novelys_authlogic/crypto_providers/aes256.rb', line 27 def matches?(crypted, *tokens) aes.decrypt aes.key = @key (aes.update(crypted.unpack("m").first) + aes.final) == tokens.join rescue OpenSSL::CipherError false end |