Sha256: cc3982cb5b1ac87b1dbba4201736bc785f2dc7ed5969c21cf6d1ddc13c832d6f

Contents?: true

Size: 1.27 KB

Versions: 7

Compression:

Stored size: 1.27 KB

Contents

require "digest/sha2"

module Sorcery
  # The activate_sorcery method has a custom_crypto_provider configuration option. This allows you to use any type of encryption you like.
  # Just create a class with a class level encrypt and matches? method. See example below.
  #
  # === Example
  #
  #   class MyAwesomeEncryptionMethod
  #     def self.encrypt(*tokens)
  #       # the tokens passed will be an array of objects, what type of object is irrelevant,
  #       # just do what you need to do with them and return a single encrypted string.
  #       # for example, you will most likely join all of the objects into a single string and then encrypt that string
  #     end
  #
  #     def self.matches?(crypted, *tokens)
  #       # return true if the crypted string matches the tokens.
  #       # depending on your algorithm you might decrypt the string then compare it to the token, or you might
  #       # encrypt the tokens and make sure it matches the crypted string, its up to you
  #     end
  #   end
  module CryptoProviders
    # = Sha256
    #
    # Uses the Sha256 hash algorithm to encrypt passwords.
    class SHA256
      include Common
      class << self
        def secure_digest(digest)
          Digest::SHA256.hexdigest(digest)
        end
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
sorcery-0.5.21 lib/sorcery/crypto_providers/sha256.rb
sorcery-0.5.2 lib/sorcery/crypto_providers/sha256.rb
sorcery-0.5.1 lib/sorcery/crypto_providers/sha256.rb
sorcery-0.5.0 lib/sorcery/crypto_providers/sha256.rb
sorcery-0.4.2 lib/sorcery/crypto_providers/sha256.rb
sorcery-0.4.1 lib/sorcery/crypto_providers/sha256.rb
sorcery-0.4.0 lib/sorcery/crypto_providers/sha256.rb