1
0
mirror of https://github.com/kakwa/uts-server synced 2025-01-09 21:24:29 +01:00

Merge branch 'master' into PKCS11_SUPPORT

This commit is contained in:
kakwa 2017-06-21 21:11:35 +02:00
commit e5ec34539f
2 changed files with 53 additions and 154 deletions

View File

@ -1,86 +1,20 @@
#
# This config is used by the Time Stamp Authority tests.
#
RANDFILE = ./.rnd
# Extra OBJECT IDENTIFIER info:
oid_section = new_oids
TSDNSECT = ts_cert_dn
INDEX = 1
[ new_oids ]
# Policies used by the TSA tests.
tsa_policy1 = 1.2.3.4.1
tsa_policy2 = 1.2.3.4.5.6
tsa_policy3 = 1.2.3.4.5.7
#---------------------------------------------------------------------- #----------------------------------------------------------------------
[ ca ] #
default_ca = CA_default # The default ca section # Properties needed for a Time-Stamp Authority (TSA) certificates
#
[ CA_default ]
dir = ./demoCA
certs = $dir/certs # Where the issued certs are kept
database = $dir/index.txt # database index file.
new_certs_dir = $dir/newcerts # default place for new certs.
certificate = $dir/cacert.pem # The CA certificate
serial = $dir/serial # The current serial number
private_key = $dir/private/cakey.pem# The private key
RANDFILE = $dir/private/.rand # private random number file
default_days = 365 # how long to certify for
default_md = sha1 # which md to use.
preserve = no # keep passed DN ordering
policy = policy_match
# For the CA policy
[ policy_match ]
countryName = supplied
stateOrProvinceName = supplied
organizationName = supplied
organizationalUnitName = optional
commonName = supplied
emailAddress = optional
#---------------------------------------------------------------------- #----------------------------------------------------------------------
[ req ]
default_bits = 4096
default_md = sha1
distinguished_name = $ENV::TSDNSECT
encrypt_rsa_key = no
prompt = no
# attributes = req_attributes
x509_extensions = v3_ca # The extentions to add to the self signed cert
string_mask = nombstr DN_SECTION=dn_ca
CN=DEFAULT
[ ts_ca_dn ]
countryName = FR
stateOrProvinceName = Paris
localityName = Paris
organizationName = UTS-SERVER test
commonName = ca1
[ ts_cert_dn ]
countryName = FR
stateOrProvinceName = Paris
localityName = Paris
organizationName = UTS-SERVER test
commonName = tsa$ENV::INDEX
# Extensions required to a TSA certificate
[ tsa_cert ] [ tsa_cert ]
# TSA server cert is not a CA cert. # TSA server cert is not a CA cert, disabling CA role
basicConstraints=CA:FALSE basicConstraints=CA:FALSE
# The following key usage flags are needed for TSA server certificates. # The following key usage flags are mandatory for TSA server certificates.
# This parameters set the main specificities of a TSA certificate
keyUsage = nonRepudiation, digitalSignature keyUsage = nonRepudiation, digitalSignature
extendedKeyUsage = critical,timeStamping extendedKeyUsage = critical,timeStamping
@ -88,76 +22,43 @@ extendedKeyUsage = critical,timeStamping
subjectKeyIdentifier=hash subjectKeyIdentifier=hash
authorityKeyIdentifier=keyid,issuer:always authorityKeyIdentifier=keyid,issuer:always
[ non_tsa_cert ]
# This is not a CA cert and not a TSA cert, either (timeStamping usage missing) #----------------------------------------------------------------------
basicConstraints=CA:FALSE #
# Other Properties for the CA and non-tsa certificates
#
#----------------------------------------------------------------------
# The following key usage flags are needed for TSA server certificates. # OpenSSL parameters for certificate requests generation
keyUsage = nonRepudiation, digitalSignature [ req ]
# timeStamping is not supported by this certificate default_bits = 4096
# extendedKeyUsage = critical,timeStamping default_md = sha512
distinguished_name = $ENV::DN_SECTION
encrypt_rsa_key = no
prompt = no
# The extentions to add to the self signed cert
x509_extensions = v3_ca
# PKIX recommendations harmless if included in all certificates. # Common properties of the CA
subjectKeyIdentifier=hash [ dn_ca ]
authorityKeyIdentifier=keyid,issuer:always countryName = FR
stateOrProvinceName = Paris
[ v3_req ] localityName = Paris
organizationName = UTS-SERVER CA
# Extensions to add to a certificate request
basicConstraints = CA:FALSE
keyUsage = nonRepudiation, digitalSignature
[ v3_ca ]
# Extensions for a typical CA # Extensions for a typical CA
[ v3_ca ]
subjectKeyIdentifier=hash subjectKeyIdentifier=hash
authorityKeyIdentifier=keyid:always,issuer:always authorityKeyIdentifier=keyid:always,issuer:always
basicConstraints = critical,CA:true basicConstraints = critical,CA:true
keyUsage = cRLSign, keyCertSign keyUsage = cRLSign, keyCertSign
#---------------------------------------------------------------------- # Common properties of all the certificates (CN, OU, etc...)
[ tsa ] [ dn_cert ]
countryName = FR
default_tsa = tsa_config1 # the default TSA section stateOrProvinceName = Paris
localityName = Paris
[ tsa_config1 ] organizationName = UTS-SERVER test
# CN is passed through environment variable "CN"
# These are used by the TSA reply generation only. commonName = $ENV::CN
dir = . # TSA root directory
serial = $dir/tsa_serial # The current serial number (mandatory)
signer_cert = $dir/tsa_cert1.pem # The TSA signing certificate
# (optional)
certs = $dir/tsaca.pem # Certificate chain to include in reply
# (optional)
signer_key = $dir/tsa_key1.pem # The TSA private key (optional)
default_policy = tsa_policy1 # Policy if request did not specify it
# (optional)
other_policies = tsa_policy2, tsa_policy3 # acceptable policies (optional)
digests = md5, sha1 # Acceptable message digests (mandatory)
accuracy = secs:1, millisecs:500, microsecs:100 # (optional)
ordering = yes # Is ordering defined for timestamps?
# (optional, default: no)
tsa_name = yes # Must the TSA name be included in the reply?
# (optional, default: no)
ess_cert_id_chain = yes # Must the ESS cert id chain be included?
# (optional, default: no)
[ tsa_config2 ]
# This configuration uses a certificate which doesn't have timeStamping usage.
# These are used by the TSA reply generation only.
dir = . # TSA root directory
serial = $dir/tsa_serial # The current serial number (mandatory)
signer_cert = $dir/tsa_cert2.pem # The TSA signing certificate
# (optional)
certs = $dir/demoCA/cacert.pem# Certificate chain to include in reply
# (optional)
signer_key = $dir/tsa_key2.pem # The TSA private key (optional)
default_policy = tsa_policy1 # Policy if request did not specify it
# (optional)
other_policies = tsa_policy2, tsa_policy3 # acceptable policies (optional)
digests = md5, sha1 # Acceptable message digests (mandatory)

View File

@ -6,33 +6,32 @@ export OPENSSL_CONF="./CAtsa.cnf"
cd `dirname $0` cd `dirname $0`
error () { error () {
echo "TSA test failed!" >&2 echo "TSA test failed!" >&2
exit 1 exit 1
} }
create_ca () { create_ca () {
echo "Creating a new CA for the TSA tests..." echo "Creating a new CA for the TSA tests..."
TSDNSECT=ts_ca_dn CN="UTS-SERVER CA"
export TSDNSECT DN_SECTION="dn_ca"
export CN
export DN_SECTION
openssl req -new -x509 -nodes \ openssl req -new -x509 -nodes \
-out tsaca.pem -keyout tsacakey.pem -out tsaca.pem -keyout tsacakey.pem
test $? != 0 && error test $? != 0 && error
} }
create_tsa_cert () { create_tsa_cert () {
EXT=$3
INDEX=$1 INDEX=$2
export INDEX CN=$1; export CN
EXT=$2 DN_SECTION="dn_cert";export DN_SECTION
TSDNSECT=ts_cert_dn
export TSDNSECT
openssl req -new \ openssl req -new \
-out tsa_req${INDEX}.pem -keyout tsa_key${INDEX}.pem -out tsa_req${INDEX}.pem -keyout tsa_key${INDEX}.pem
test $? != 0 && error test $? != 0 && error
echo Using extension $EXT echo Using extension $EXT
openssl x509 -req \ openssl x509 -req \
-in tsa_req${INDEX}.pem -out tsa_cert${INDEX}.pem \ -in tsa_req${INDEX}.pem -out tsa_cert${INDEX}.pem \
@ -43,10 +42,9 @@ echo Using extension $EXT
create_cert () { create_cert () {
INDEX=$1 INDEX=$2
export INDEX export INDEX
TSDNSECT=ts_cert_dn DN_SECTION="dn_cert";export DN_SECTION
export TSDNSECT
openssl req -new \ openssl req -new \
-out tsa_req${INDEX}.pem -keyout ssl_key${INDEX}.pem -out tsa_req${INDEX}.pem -keyout ssl_key${INDEX}.pem
@ -63,12 +61,12 @@ echo "Creating CA for TSA tests..."
create_ca create_ca
echo "Creating tsa_cert1.pem TSA server cert..." echo "Creating tsa_cert1.pem TSA server cert..."
create_tsa_cert 1 tsa_cert create_tsa_cert "TSA CERT 1" 1 tsa_cert
echo "Creating tsa_cert2.pem TSA server cert..." echo "Creating tsa_cert2.pem TSA server cert..."
create_tsa_cert 2 tsa_cert create_tsa_cert "TSA CERT 2" 2 tsa_cert
echo "Creating ssl_keycerts1.pem for ssl" echo "Creating ssl_keycerts1.pem for ssl"
create_cert 1 create_cert "uts-server.example.org" 1
exit 0 exit 0