summaryrefslogtreecommitdiff
path: root/sample/openssl/smime_read.rb
blob: 17394f9b8d35ffc7bd3cea54600b4ff45a9d775c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
require 'optparse'
require 'openssl'
include OpenSSL

options = ARGV.getopts("c:k:C:")

cert_file = options["c"]
key_file  = options["k"]
ca_path   = options["C"]

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