2006-02-12 23:19:25 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
#
|
|
|
|
# A few very basic tests for the 'ts' time stamping authority command.
|
|
|
|
#
|
|
|
|
|
|
|
|
SH="/bin/sh"
|
2007-12-03 09:02:29 +00:00
|
|
|
if test "$OSTYPE" = msdosdjgpp; then
|
|
|
|
PATH="../apps\;$PATH"
|
|
|
|
else
|
|
|
|
PATH="../apps:$PATH"
|
|
|
|
fi
|
2006-02-12 23:19:25 +00:00
|
|
|
export SH PATH
|
|
|
|
|
|
|
|
OPENSSL_CONF="../CAtsa.cnf"
|
|
|
|
export OPENSSL_CONF
|
2015-04-08 14:07:39 -04:00
|
|
|
# Because that's what ../apps/CA.pl really looks at
|
2006-03-30 04:29:38 +00:00
|
|
|
SSLEAY_CONFIG="-config $OPENSSL_CONF"
|
2006-03-28 10:26:12 +00:00
|
|
|
export SSLEAY_CONFIG
|
2006-02-12 23:19:25 +00:00
|
|
|
|
2006-02-16 20:30:58 +00:00
|
|
|
OPENSSL="`pwd`/../util/opensslwrap.sh"
|
2006-02-16 20:20:24 +00:00
|
|
|
export OPENSSL
|
|
|
|
|
2006-02-12 23:19:25 +00:00
|
|
|
setup_dir () {
|
|
|
|
rm -rf tsa 2>/dev/null
|
|
|
|
mkdir tsa
|
|
|
|
cd ./tsa
|
|
|
|
}
|
|
|
|
|
|
|
|
clean_up_dir () {
|
|
|
|
cd ..
|
|
|
|
rm -rf tsa
|
|
|
|
}
|
|
|
|
|
|
|
|
create_ca () {
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating a new CA for the TSA tests
|
2006-11-07 16:21:16 +00:00
|
|
|
TSDNSECT=ts_ca_dn
|
|
|
|
export TSDNSECT
|
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl req -new -x509 -nodes \
|
2015-04-10 10:06:17 -04:00
|
|
|
-out tsaca.pem -keyout tsacakey.pem || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_tsa_cert () {
|
|
|
|
|
|
|
|
INDEX=$1
|
2006-11-07 16:21:16 +00:00
|
|
|
export INDEX
|
2006-02-12 23:19:25 +00:00
|
|
|
EXT=$2
|
2006-11-07 16:21:16 +00:00
|
|
|
TSDNSECT=ts_cert_dn
|
|
|
|
export TSDNSECT
|
2006-02-12 23:19:25 +00:00
|
|
|
|
2006-11-07 16:21:16 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl req -new \
|
2015-04-10 10:06:17 -04:00
|
|
|
-out tsa_req${INDEX}.pem -keyout tsa_key${INDEX}.pem || exit 1
|
|
|
|
echo using extension $EXT
|
2006-11-07 16:21:16 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl x509 -req \
|
|
|
|
-in tsa_req${INDEX}.pem -out tsa_cert${INDEX}.pem \
|
|
|
|
-CA tsaca.pem -CAkey tsacakey.pem -CAcreateserial \
|
2015-04-10 10:06:17 -04:00
|
|
|
-extfile $OPENSSL_CONF -extensions $EXT || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
print_request () {
|
|
|
|
|
2006-02-16 20:20:24 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -query -in $1 -text
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_time_stamp_request1 () {
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -query -data ../testtsa -policy tsa_policy1 -cert -out req1.tsq || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_time_stamp_request2 () {
|
|
|
|
|
2006-02-16 20:20:24 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -query -data ../testtsa -policy tsa_policy2 -no_nonce \
|
2015-04-10 10:06:17 -04:00
|
|
|
-out req2.tsq || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_time_stamp_request3 () {
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -query -data ../CAtsa.cnf -no_nonce -out req3.tsq || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
print_response () {
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $1 -text || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_time_stamp_response () {
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -section $3 -queryfile $1 -out $2 || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
time_stamp_response_token_test () {
|
|
|
|
|
|
|
|
RESPONSE2=$2.copy.tsr
|
|
|
|
TOKEN_DER=$2.token.der
|
2015-04-10 10:06:17 -04:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $2 -out $TOKEN_DER -token_out || exit 1
|
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $TOKEN_DER -token_in -out $RESPONSE2 || exit 1
|
|
|
|
cmp $RESPONSE2 $2 || exit 1
|
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $2 -text -token_out || exit 1
|
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $TOKEN_DER -token_in -text -token_out || exit 1
|
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -queryfile $1 -text -token_out || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
verify_time_stamp_response () {
|
|
|
|
|
2006-11-07 16:21:16 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -verify -queryfile $1 -in $2 -CAfile tsaca.pem \
|
2015-04-10 10:06:17 -04:00
|
|
|
-untrusted tsa_cert1.pem || exit 1
|
2006-11-07 16:21:16 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -verify -data $3 -in $2 -CAfile tsaca.pem \
|
2015-04-10 10:06:17 -04:00
|
|
|
-untrusted tsa_cert1.pem || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
verify_time_stamp_token () {
|
|
|
|
|
|
|
|
# create the token from the response first
|
2015-04-10 10:06:17 -04:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $2 -out $2.token -token_out || exit 1
|
2006-02-16 20:20:24 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -verify -queryfile $1 -in $2.token -token_in \
|
2015-04-10 10:06:17 -04:00
|
|
|
-CAfile tsaca.pem -untrusted tsa_cert1.pem || exit 1
|
2006-02-16 20:20:24 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -verify -data $3 -in $2.token -token_in \
|
2015-04-10 10:06:17 -04:00
|
|
|
-CAfile tsaca.pem -untrusted tsa_cert1.pem || exit 1
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
verify_time_stamp_response_fail () {
|
|
|
|
|
2006-11-07 16:21:16 +00:00
|
|
|
../../util/shlib_wrap.sh ../../apps/openssl ts -verify -queryfile $1 -in $2 -CAfile tsaca.pem \
|
2015-04-10 10:06:17 -04:00
|
|
|
-untrusted tsa_cert1.pem && exit 1
|
|
|
|
echo ok
|
2006-02-12 23:19:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# main functions
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo setting up TSA test directory
|
2006-02-12 23:19:25 +00:00
|
|
|
setup_dir
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating CA for TSA tests
|
2006-02-12 23:19:25 +00:00
|
|
|
create_ca
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating tsa_cert1.pem TSA server cert
|
2006-02-12 23:19:25 +00:00
|
|
|
create_tsa_cert 1 tsa_cert
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating tsa_cert2.pem non-TSA server cert
|
2006-02-12 23:19:25 +00:00
|
|
|
create_tsa_cert 2 non_tsa_cert
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating req1.req time stamp request for file testtsa
|
2006-02-12 23:19:25 +00:00
|
|
|
create_time_stamp_request1
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo printing req1.req
|
2006-02-12 23:19:25 +00:00
|
|
|
print_request req1.tsq
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo generating valid response for req1.req
|
2006-02-12 23:19:25 +00:00
|
|
|
create_time_stamp_response req1.tsq resp1.tsr tsa_config1
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo printing response
|
2006-02-12 23:19:25 +00:00
|
|
|
print_response resp1.tsr
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo verifying valid response
|
2006-02-12 23:19:25 +00:00
|
|
|
verify_time_stamp_response req1.tsq resp1.tsr ../testtsa
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo verifying valid token
|
2006-02-12 23:19:25 +00:00
|
|
|
verify_time_stamp_token req1.tsq resp1.tsr ../testtsa
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating req2.req time stamp request for file testtsa
|
2006-02-12 23:19:25 +00:00
|
|
|
create_time_stamp_request2
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo printing req2.req
|
2006-02-12 23:19:25 +00:00
|
|
|
print_request req2.tsq
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo generating valid response for req2.req
|
2006-02-12 23:19:25 +00:00
|
|
|
create_time_stamp_response req2.tsq resp2.tsr tsa_config1
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo checking -token_in and -token_out options with -reply
|
2006-02-12 23:19:25 +00:00
|
|
|
time_stamp_response_token_test req2.tsq resp2.tsr
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo printing response
|
2006-02-12 23:19:25 +00:00
|
|
|
print_response resp2.tsr
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo verifying valid response
|
2006-02-12 23:19:25 +00:00
|
|
|
verify_time_stamp_response req2.tsq resp2.tsr ../testtsa
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo verifying response against wrong request, it should fail
|
2006-02-12 23:19:25 +00:00
|
|
|
verify_time_stamp_response_fail req1.tsq resp2.tsr
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo verifying response against wrong request, it should fail
|
2006-02-12 23:19:25 +00:00
|
|
|
verify_time_stamp_response_fail req2.tsq resp1.tsr
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo creating req3.req time stamp request for file CAtsa.cnf
|
2006-02-12 23:19:25 +00:00
|
|
|
create_time_stamp_request3
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo printing req3.req
|
2006-02-12 23:19:25 +00:00
|
|
|
print_request req3.tsq
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo verifying response against wrong request, it should fail
|
2006-02-12 23:19:25 +00:00
|
|
|
verify_time_stamp_response_fail req3.tsq resp1.tsr
|
|
|
|
|
2015-04-10 10:06:17 -04:00
|
|
|
echo cleaning up
|
2006-02-12 23:19:25 +00:00
|
|
|
clean_up_dir
|
|
|
|
|
|
|
|
exit 0
|