2007-12-24 02:31:23 -05:00
|
|
|
require 'optparse'
|
2003-07-23 12:12:24 -04:00
|
|
|
require 'openssl'
|
|
|
|
include OpenSSL
|
|
|
|
|
2007-12-24 02:31:23 -05:00
|
|
|
options = ARGV.getopts("c:k:C:")
|
2003-07-23 12:12:24 -04:00
|
|
|
|
2007-12-24 02:31:23 -05:00
|
|
|
cert_file = options["c"]
|
|
|
|
key_file = options["k"]
|
|
|
|
ca_path = options["C"]
|
2003-07-23 12:12:24 -04:00
|
|
|
|
|
|
|
data = $stdin.read
|
|
|
|
|
|
|
|
cert = X509::Certificate.new(File::read(cert_file))
|
|
|
|
key = PKey::RSA.new(File::read(key_file))
|
|
|
|
p7enc = PKCS7::read_smime(data)
|
|
|
|
data = p7enc.decrypt(key, cert)
|
|
|
|
|
|
|
|
store = X509::Store.new
|
|
|
|
store.add_path(ca_path)
|
|
|
|
p7sig = PKCS7::read_smime(data)
|
|
|
|
if p7sig.verify([], store)
|
|
|
|
puts p7sig.data
|
|
|
|
end
|