Sha256: 9a5c45bfa131d943c25148fb42e56f74115ba56227586414a11efe74c0a088af

Contents?: true

Size: 1.19 KB

Versions: 237

Compression:

Stored size: 1.19 KB

Contents

require 'digest/md5'

module Rack
  module Auth
    module Digest
      # Rack::Auth::Digest::Nonce is the default nonce generator for the
      # Rack::Auth::Digest::MD5 authentication handler.
      #
      # +private_key+ needs to set to a constant string.
      #
      # +time_limit+ can be optionally set to an integer (number of seconds),
      # to limit the validity of the generated nonces.

      class Nonce

        class << self
          attr_accessor :private_key, :time_limit
        end

        def self.parse(string)
          new(*string.unpack("m*").first.split(' ', 2))
        end

        def initialize(timestamp = Time.now, given_digest = nil)
          @timestamp, @given_digest = timestamp.to_i, given_digest
        end

        def to_s
          [([ @timestamp, digest ] * ' ')].pack("m*").strip
        end

        def digest
          ::Digest::MD5.hexdigest([ @timestamp, self.class.private_key ] * ':')
        end

        def valid?
          digest == @given_digest
        end

        def stale?
          !self.class.time_limit.nil? && (@timestamp - Time.now.to_i) < self.class.time_limit
        end

        def fresh?
          !stale?
        end

      end
    end
  end
end

Version data entries

237 entries across 215 versions & 41 rubygems

Version Path
classiccms-0.7.5 vendor/bundle/gems/rack-1.4.1/lib/rack/auth/digest/nonce.rb
classiccms-0.7.4 vendor/bundle/gems/rack-1.4.1/lib/rack/auth/digest/nonce.rb
classiccms-0.7.3 vendor/bundle/gems/rack-1.4.1/lib/rack/auth/digest/nonce.rb
3mix-castronaut-0.5.0.2 vendor/rack/lib/rack/auth/digest/nonce.rb
kastner-rack-0.3.171 lib/rack/auth/digest/nonce.rb
kastner-rack-0.3.186 lib/rack/auth/digest/nonce.rb
kjvarga-rack-1.0.0 lib/rack/auth/digest/nonce.rb
masover-castronaut-0.4.4.4 vendor/rack/lib/rack/auth/digest/nonce.rb
masover-castronaut-0.4.4.5 vendor/rack/lib/rack/auth/digest/nonce.rb
masover-castronaut-0.5.0.1 vendor/rack/lib/rack/auth/digest/nonce.rb
p8-castronaut-0.6.1.1 vendor/rack/lib/rack/auth/digest/nonce.rb
qoobaa-rack-1.0.0.1 lib/rack/auth/digest/nonce.rb
qoobaa-rack-1.0.2 lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.2.0 vendor/rack/lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.2.5 vendor/rack/lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.3.0 vendor/rack/lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.3.5 vendor/rack/lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.3.6 vendor/rack/lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.4.1 vendor/rack/lib/rack/auth/digest/nonce.rb
relevance-castronaut-0.4.2 vendor/rack/lib/rack/auth/digest/nonce.rb