summaryrefslogtreecommitdiff
path: root/sample/openssl/smime_read.rb
blob: 0f08f54f7e2b4827d15b6701c5de14d8fa113c3e (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 'getopts'
require 'openssl'
include OpenSSL

getopts nil, "c:", "k:", "C:"

cert_file = $OPT_c
key_file  = $OPT_k
ca_path   = $OPT_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