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
|