I’ve created ed2k hashing implementation using ruby. It’s not too slow and only use core library (openssl).
def file_ed2k(file_name, output_mode = "hash")
ed2k_block = 9500*1024 #ed2k block size is 9500 KiB
ed2k_hash = ""
file = File.open(file_name, 'rb')
file_size = file.stat.size #while at it, fetch the size of the file
while (block = file.read(ed2k_block)) do
ed2k_hash < < OpenSSL::Digest::MD4.digest(block) #hashes are concatenated md4 per block size for ed2k hash
end
ed2k_hash << OpenSSL::Digest::MD4.digest("") if file_size % ed2k_block == 0 #on size of modulo block size, append another md4 hash of a blank string
file.close
ed2k_hash = OpenSSL::Digest::MD4.hexdigest(ed2k_hash) #finally
return case output_mode #there are 2 modes, just the has, or complete with link.
when "hash"
ed2k_hash
when "link"
"ed2k://|file|#{File.basename(file_name)}|#{file_size}|#{ed2k_hash}|"
end
end
You can then call the file_ed2k method (or whatever you name it) to calculate a file’s ed2k hash. ed2k link generation was created to reduce amount of IO involved when reading the file(s).