Sha256: 633bf72f3c0575a7ee05a150f622d5b94b34af81c6d5d73c847eee9a446c6b3a

Contents?: true

Size: 1.64 KB

Versions: 43

Compression:

Stored size: 1.64 KB

Contents

# frozen_string_literal: true

module Doorkeeper
  module SecretStoring
    ##
    # Plain text secret storing, which is the default
    # but also provides fallback lookup if
    # other secret storing mechanisms are enabled.
    class BCrypt < Base
      ##
      # Return the value to be stored by the database
      # @param plain_secret The plain secret input / generated
      def self.transform_secret(plain_secret)
        ::BCrypt::Password.create(plain_secret.to_s)
      end

      ##
      # Securely compare the given +input+ value with a +stored+ value
      # processed by +transform_secret+.
      def self.secret_matches?(input, stored)
        ::BCrypt::Password.new(stored.to_s) == input.to_s
      rescue ::BCrypt::Errors::InvalidHash
        false
      end

      ##
      # Determines whether this strategy supports restoring
      # secrets from the database. This allows detecting users
      # trying to use a non-restorable strategy with +reuse_access_tokens+.
      def self.allows_restoring_secrets?
        false
      end

      ##
      # Determines what secrets this strategy is applicable for
      def self.validate_for(model)
        unless model.to_sym == :application
          raise ArgumentError,
                "'#{name}' can only be used for storing application secrets."
        end

        unless bcrypt_present?
          raise ArgumentError,
                "'#{name}' requires the 'bcrypt' gem being loaded."
        end

        true
      end

      ##
      # Test if we can require the BCrypt gem
      def self.bcrypt_present?
        require "bcrypt"
        true
      rescue LoadError
        false
      end
    end
  end
end

Version data entries

43 entries across 43 versions & 1 rubygems

Version Path
doorkeeper-5.8.1 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.8.0 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.7.1 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.7.0 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.9 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.8 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.7 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.6 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.5 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.4 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.3 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.2 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.1 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.0 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.0.rc2 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.6.0.rc1 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.5.4 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.5.3 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.5.2 lib/doorkeeper/secret_storing/bcrypt.rb
doorkeeper-5.5.1 lib/doorkeeper/secret_storing/bcrypt.rb