2009-11-10 13:27:43 -02:00
|
|
|
require "digest/sha2"
|
|
|
|
|
|
|
|
module Devise
|
|
|
|
module Encryptors
|
|
|
|
# = Sha512
|
|
|
|
# Uses the Sha512 hash algorithm to encrypt passwords.
|
2010-01-08 23:19:57 +01:00
|
|
|
class Sha512 < Base
|
2009-11-10 13:27:43 -02:00
|
|
|
|
|
|
|
# Gererates a default password digest based on salt, pepper and the
|
|
|
|
# incoming password.
|
|
|
|
def self.digest(password, stretches, salt, pepper)
|
|
|
|
digest = pepper
|
|
|
|
stretches.times { digest = self.secure_digest(salt, digest, password, pepper) }
|
|
|
|
digest
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
# Generate a Sha512 digest joining args. Generated token is something like
|
|
|
|
# --arg1--arg2--arg3--argN--
|
|
|
|
def self.secure_digest(*tokens)
|
|
|
|
::Digest::SHA512.hexdigest('--' << tokens.flatten.join('--') << '--')
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|