Sha256: 317f73b1e26c564c17ff29b49898bd9c7db55d576fec2f6106da248740bb0393

Contents?: true

Size: 838 Bytes

Versions: 8

Compression:

Stored size: 838 Bytes

Contents

module Net
  module SSH
    module Transport
      module KeyExpander
        # Generate a key value in accordance with the SSH2 specification.
        # (RFC4253 7.2. "Output from Key Exchange")
        def self.expand_key(bytes, start, options={})
          if bytes == 0
            return ""
          end

          k = start[0, bytes]
          return k if k.length >= bytes

          digester = options[:digester] or raise 'No digester supplied'
          shared   = options[:shared] or raise 'No shared secret supplied'
          hash     = options[:hash] or raise 'No hash supplied'

          while k.length < bytes
            step = digester.digest(shared + hash + k)
            bytes_needed = bytes - k.length
            k << step[0, bytes_needed]
          end

          return k
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 2 rubygems

Version Path
net-ssh-backports-6.3.6.backports lib/net/ssh/transport/key_expander.rb
net-ssh-backports-6.3.5.backports lib/net/ssh/transport/key_expander.rb
net-ssh-backports-6.3.4.backports lib/net/ssh/transport/key_expander.rb
net-ssh-backports-6.3.3.backports lib/net/ssh/transport/key_expander.rb
net-ssh-backports-6.3.2.backports lib/net/ssh/transport/key_expander.rb
net-ssh-backports-6.3.1.backports lib/net/ssh/transport/key_expander.rb
net-ssh-backports-6.3.0.backports lib/net/ssh/transport/key_expander.rb
net-ssh-6.3.0.beta1 lib/net/ssh/transport/key_expander.rb