mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
c9dc0164b8
* NEWS, {ext,test,sample}/openssl: Import Ruby/OpenSSL 2.0.0.beta.1. ext/openssl is now converted into a default gem. The full commit history since r55538 can be found at: https://github.com/ruby/openssl/compare/08e1881f5663...v2.0.0.beta.1 [Feature #9612] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56027 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
54 lines
1.1 KiB
Ruby
54 lines
1.1 KiB
Ruby
#!/usr/bin/env ruby
|
|
require 'openssl'
|
|
|
|
def crypt_by_password(alg, pass, salt, text)
|
|
puts "--Setup--"
|
|
puts %(cipher alg: "#{alg}")
|
|
puts %(plain text: "#{text}")
|
|
puts %(password: "#{pass}")
|
|
puts %(salt: "#{salt}")
|
|
puts
|
|
|
|
puts "--Encrypting--"
|
|
enc = OpenSSL::Cipher.new(alg)
|
|
enc.encrypt
|
|
enc.pkcs5_keyivgen(pass, salt)
|
|
cipher = enc.update(text)
|
|
cipher << enc.final
|
|
puts %(encrypted text: #{cipher.inspect})
|
|
puts
|
|
|
|
puts "--Decrypting--"
|
|
dec = OpenSSL::Cipher.new(alg)
|
|
dec.decrypt
|
|
dec.pkcs5_keyivgen(pass, salt)
|
|
plain = dec.update(cipher)
|
|
plain << dec.final
|
|
puts %(decrypted text: "#{plain}")
|
|
puts
|
|
end
|
|
|
|
def ciphers
|
|
ciphers = OpenSSL::Cipher.ciphers.sort
|
|
ciphers.each{|i|
|
|
if i.upcase != i && ciphers.include?(i.upcase)
|
|
ciphers.delete(i)
|
|
end
|
|
}
|
|
return ciphers
|
|
end
|
|
|
|
puts "Supported ciphers in #{OpenSSL::OPENSSL_VERSION}:"
|
|
ciphers.each_with_index{|name, i|
|
|
printf("%-15s", name)
|
|
puts if (i + 1) % 5 == 0
|
|
}
|
|
puts
|
|
puts
|
|
|
|
alg = ARGV.shift || ciphers.first
|
|
pass = "secret password"
|
|
salt = "8 octets" # or nil
|
|
text = "abcdefghijklmnopqrstuvwxyz"
|
|
|
|
crypt_by_password(alg, pass, salt, text)
|