Blame tests/p11-kit-trust.sh

Packit aea12f
#!/bin/sh
Packit aea12f
Packit aea12f
# Copyright (C) 2017 Red Hat, Inc.
Packit aea12f
#
Packit aea12f
# This file is part of p11-kit.
Packit aea12f
#
Packit aea12f
# p11-kit is free software; you can redistribute it and/or modify it
Packit aea12f
# under the terms of the GNU General Public License as published by the
Packit aea12f
# Free Software Foundation; either version 3 of the License, or (at
Packit aea12f
# your option) any later version.
Packit aea12f
#
Packit aea12f
# p11-kit is distributed in the hope that it will be useful, but
Packit aea12f
# WITHOUT ANY WARRANTY; without even the implied warranty of
Packit aea12f
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit aea12f
# General Public License for more details.
Packit aea12f
#
Packit aea12f
# You should have received a copy of the GNU General Public License
Packit aea12f
# along with GnuTLS; if not, write to the Free Software Foundation,
Packit aea12f
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Packit aea12f
Packit aea12f
#set -e
Packit aea12f
Packit aea12f
srcdir="${srcdir:-.}"
Packit aea12f
P11TOOL="${P11TOOL:-../src/p11tool${EXEEXT}}"
Packit aea12f
CERTTOOL="${CERTTOOL:-../src/certtool${EXEEXT}}"
Packit aea12f
DIFF="${DIFF:-diff}"
Packit aea12f
Packit aea12f
EXPORTED_FILE=out.$$.tmp
Packit aea12f
DER_FILE=out-der.$$.tmp
Packit aea12f
TMPFILE=out-tmp.$$.tmp
Packit aea12f
Packit aea12f
for lib in ${libdir} ${libdir}/pkcs11 /usr/lib64/pkcs11/ /usr/lib/pkcs11/ /usr/lib/x86_64-linux-gnu/pkcs11/;do
Packit aea12f
	if test -f "${lib}/p11-kit-trust.so"; then
Packit aea12f
		MODULE="${lib}/p11-kit-trust.so"
Packit aea12f
		echo "located ${MODULE}"
Packit aea12f
		break
Packit aea12f
	fi
Packit aea12f
done
Packit aea12f
Packit aea12f
if ! test -x "${P11TOOL}"; then
Packit aea12f
	echo "p11tool was not found"
Packit aea12f
	exit 77
Packit aea12f
fi
Packit aea12f
Packit aea12f
if ! test -f "${MODULE}"; then
Packit aea12f
	echo "p11-kit trust module was not found"
Packit aea12f
	exit 77
Packit aea12f
fi
Packit aea12f
Packit aea12f
TRUST_PATH="${srcdir}/p11-kit-trust-data/"
Packit aea12f
CACERT=${TRUST_PATH}/Example_Root_CA.pem
Packit aea12f
Packit aea12f
# Test whether a CA extracted from a trust store can retrieve stapled
Packit aea12f
# extensions.
Packit aea12f
Packit aea12f
OPTS="--provider ${MODULE} --provider-opts trusted,p11-kit:paths=\"${TRUST_PATH}\""
Packit aea12f
Packit aea12f
# Informational
Packit aea12f
${P11TOOL} --list-all-certs ${OPTS} 'pkcs11:'
Packit aea12f
Packit aea12f
Packit aea12f
####
Packit aea12f
# Test 1: Extract the CA certificate from store
Packit aea12f
Packit aea12f
${P11TOOL} --export 'pkcs11:object=Example%20CA' ${OPTS} --outder --outfile ${EXPORTED_FILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	echo "Exporting failed (1)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
${CERTTOOL} -i --infile ${CACERT} --outder --outfile ${DER_FILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	echo "Exporting failed (2)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
${DIFF} ${EXPORTED_FILE} ${DER_FILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	echo "Files ${EXPORTED_FILE} and ${DER_FILE} are not identical"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
rm -f ${EXPORTED_FILE} ${DER_FILE} ${TMPFILE}
Packit aea12f
Packit aea12f
echo "Root CA retrieval test passed..."
Packit aea12f
Packit aea12f
####
Packit aea12f
# Test 2: Extract the certificate from store with the stapled data
Packit aea12f
Packit aea12f
${P11TOOL} --export-stapled 'pkcs11:object=Example%20CA' ${OPTS} --outder --outfile ${EXPORTED_FILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	echo "Exporting failed (3)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
${CERTTOOL} -i --infile ${CACERT} --outder --outfile ${DER_FILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	echo "Exporting failed (4)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
${DIFF} ${EXPORTED_FILE} ${DER_FILE}
Packit aea12f
if test "$?" = "0"; then
Packit aea12f
	echo "Files are identical; no extensions were stapled"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
${CERTTOOL} -i --inder --infile ${EXPORTED_FILE} --outfile ${TMPFILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	echo "PEM converting failed"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
grep -i "Name Constraints" ${TMPFILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	cat ${TMPFILE}
Packit aea12f
	echo "No name constraints found (1)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
grep -i "Permitted" ${TMPFILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	cat ${TMPFILE}
Packit aea12f
	echo "No name constraints found (2)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
grep -i "DNSname: example.com" ${TMPFILE}
Packit aea12f
if test "$?" != "0"; then
Packit aea12f
	cat ${TMPFILE}
Packit aea12f
	echo "No name constraints found (3)"
Packit aea12f
	exit 1
Packit aea12f
fi
Packit aea12f
Packit aea12f
echo "Root CA with stapled extensions retrieval test passed..."
Packit aea12f
Packit aea12f
rm -f ${EXPORTED_FILE} ${DER_FILE} ${TMPFILE}
Packit aea12f
exit 0