Sha256: ff3efad859dc4f1565c01f153fde38216a012651bd5eb4e9095ba556e9e60515
Contents?: true
Size: 715 Bytes
Versions: 37
Compression:
Stored size: 715 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
37 entries across 34 versions & 3 rubygems