4 $ if f$getsyi("cpu") .ge. 128 then __arch := AXP
5 $ exe_dir := sys$disk:[-.'__arch'.exe.apps]
8 $ reqcmd := mcr 'exe_dir'openssl req
9 $ x509cmd := mcr 'exe_dir'openssl x509 'digest'
10 $ verifycmd := mcr 'exe_dir'openssl verify
11 $ dummycnf := sys$disk:[-.apps]openssl-vms.cnf
13 $ CAkey="""keyCA.ss"""
14 $ CAcert="""certCA.ss"""
15 $ CAreq="""reqCA.ss"""
16 $ CAconf="""CAss.cnf"""
17 $ CAreq2="""req2CA.ss""" ! temp
22 $ Ucert="""certU.ss"""
25 $ write sys$output "make a certificate request using 'req'"
26 $ 'reqcmd' -config 'CAconf' -out 'CAreq' -keyout 'CAkey' -new ! -out err.ss
29 $ write sys$output "error using 'req' to generate a certificate request"
33 $ write sys$output "convert the certificate request into a self signed certificate using 'x509'"
34 $ define /user sys$output err.ss
35 $ 'x509cmd' "-CAcreateserial" -in 'CAreq' -days 30 -req -out 'CAcert' -signkey 'CAkey'
38 $ write sys$output "error using 'x509' to self sign a certificate request"
43 $ write sys$output "convert a certificate into a certificate request using 'x509'"
44 $ define /user sys$output err.ss
45 $ 'x509cmd' -in 'CAcert' -x509toreq -signkey 'CAkey' -out 'CAreq2'
48 $ write sys$output "error using 'x509' convert a certificate to a certificate request"
52 $ 'reqcmd' -config 'dummycnf' -verify -in 'CAreq' -noout
55 $ write sys$output "first generated request is invalid"
59 $ 'reqcmd' -config 'dummycnf' -verify -in 'CAreq2' -noout
62 $ write sys$output "second generated request is invalid"
66 $ 'verifycmd' "-CAfile" 'CAcert' 'CAcert'
69 $ write sys$output "first generated cert is invalid"
74 $ write sys$output "make another certificate request using 'req'"
75 $ define /user sys$output err.ss
76 $ 'reqcmd' -config 'Uconf' -out 'Ureq' -keyout 'Ukey' -new
79 $ write sys$output "error using 'req' to generate a certificate request"
84 $ write sys$output "sign certificate request with the just created CA via 'x509'"
85 $ define /user sys$output err.ss
86 $ 'x509cmd' "-CAcreateserial" -in 'Ureq' -days 30 -req -out 'Ucert' "-CA" 'CAcert' "-CAkey" 'CAkey'
89 $ write sys$output "error using 'x509' to sign a certificate request"
93 $ 'verifycmd' "-CAfile" 'CAcert' 'Ucert'
95 $ write sys$output "Certificate details"
96 $ 'x509cmd' -subject -issuer -startdate -enddate -noout -in 'Ucert'
99 $ write sys$output "The generated CA certificate is ",CAcert
100 $ write sys$output "The generated CA private key is ",CAkey
102 $ write sys$output "The generated user certificate is ",Ucert
103 $ write sys$output "The generated user private key is ",Ukey
105 $ if f$search("err.ss;*") .nes. "" then delete err.ss;*