Blame apps/openssl.cnf

Packit c4476c
#
Packit c4476c
# OpenSSL example configuration file.
Packit c4476c
# This is mostly being used for generation of certificate requests.
Packit c4476c
#
Packit c4476c
Packit c4476c
# Note that you can include other files from the main configuration
Packit c4476c
# file using the .include directive.
Packit c4476c
#.include filename
Packit c4476c
Packit c4476c
# This definition stops the following lines choking if HOME isn't
Packit c4476c
# defined.
Packit c4476c
HOME			= .
Packit c4476c
Packit c4476c
# Extra OBJECT IDENTIFIER info:
Packit c4476c
#oid_file		= $ENV::HOME/.oid
Packit c4476c
oid_section		= new_oids
Packit c4476c
Packit c4476c
# To use this configuration file with the "-extfile" option of the
Packit c4476c
# "openssl x509" utility, name here the section containing the
Packit c4476c
# X.509v3 extensions to use:
Packit c4476c
# extensions		=
Packit c4476c
# (Alternatively, use a configuration file that has only
Packit c4476c
# X.509v3 extensions in its main [= default] section.)
Packit c4476c
Packit c4476c
# Load default TLS policy configuration
Packit c4476c
Packit c4476c
openssl_conf = default_modules
Packit c4476c
Packit c4476c
[ default_modules ]
Packit c4476c
Packit c4476c
ssl_conf = ssl_module
Packit c4476c
Packit c4476c
[ ssl_module ]
Packit c4476c
Packit c4476c
system_default = crypto_policy
Packit c4476c
Packit c4476c
[ crypto_policy ]
Packit c4476c
Packit c4476c
.include /etc/crypto-policies/back-ends/opensslcnf.config
Packit c4476c
Packit c4476c
[ new_oids ]
Packit c4476c
Packit c4476c
# We can add new OIDs in here for use by 'ca', 'req' and 'ts'.
Packit c4476c
# Add a simple OID like this:
Packit c4476c
# testoid1=1.2.3.4
Packit c4476c
# Or use config file substitution like this:
Packit c4476c
# testoid2=${testoid1}.5.6
Packit c4476c
Packit c4476c
# Policies used by the TSA examples.
Packit c4476c
tsa_policy1 = 1.2.3.4.1
Packit c4476c
tsa_policy2 = 1.2.3.4.5.6
Packit c4476c
tsa_policy3 = 1.2.3.4.5.7
Packit c4476c
Packit c4476c
####################################################################
Packit c4476c
[ ca ]
Packit c4476c
default_ca	= CA_default		# The default ca section
Packit c4476c
Packit c4476c
####################################################################
Packit c4476c
[ CA_default ]
Packit c4476c
Packit c4476c
dir		= /etc/pki/CA		# Where everything is kept
Packit c4476c
certs		= $dir/certs		# Where the issued certs are kept
Packit c4476c
crl_dir		= $dir/crl		# Where the issued crl are kept
Packit c4476c
database	= $dir/index.txt	# database index file.
Packit c4476c
#unique_subject	= no			# Set to 'no' to allow creation of
Packit c4476c
					# several certs with same subject.
Packit c4476c
new_certs_dir	= $dir/newcerts		# default place for new certs.
Packit c4476c
Packit c4476c
certificate	= $dir/cacert.pem 	# The CA certificate
Packit c4476c
serial		= $dir/serial 		# The current serial number
Packit c4476c
crlnumber	= $dir/crlnumber	# the current crl number
Packit c4476c
					# must be commented out to leave a V1 CRL
Packit c4476c
crl		= $dir/crl.pem 		# The current CRL
Packit c4476c
private_key	= $dir/private/cakey.pem# The private key
Packit c4476c
Packit c4476c
x509_extensions	= usr_cert		# The extensions to add to the cert
Packit c4476c
Packit c4476c
# Comment out the following two lines for the "traditional"
Packit c4476c
# (and highly broken) format.
Packit c4476c
name_opt 	= ca_default		# Subject Name options
Packit c4476c
cert_opt 	= ca_default		# Certificate field options
Packit c4476c
Packit c4476c
# Extension copying option: use with caution.
Packit c4476c
# copy_extensions = copy
Packit c4476c
Packit c4476c
# Extensions to add to a CRL. Note: Netscape communicator chokes on V2 CRLs
Packit c4476c
# so this is commented out by default to leave a V1 CRL.
Packit c4476c
# crlnumber must also be commented out to leave a V1 CRL.
Packit c4476c
# crl_extensions	= crl_ext
Packit c4476c
Packit c4476c
default_days	= 365			# how long to certify for
Packit c4476c
default_crl_days= 30			# how long before next CRL
Packit c4476c
default_md	= sha256		# use SHA-256 by default
Packit c4476c
preserve	= no			# keep passed DN ordering
Packit c4476c
Packit c4476c
# A few difference way of specifying how similar the request should look
Packit c4476c
# For type CA, the listed attributes must be the same, and the optional
Packit c4476c
# and supplied fields are just that :-)
Packit c4476c
policy		= policy_match
Packit c4476c
Packit c4476c
# For the CA policy
Packit c4476c
[ policy_match ]
Packit c4476c
countryName		= match
Packit c4476c
stateOrProvinceName	= match
Packit c4476c
organizationName	= match
Packit c4476c
organizationalUnitName	= optional
Packit c4476c
commonName		= supplied
Packit c4476c
emailAddress		= optional
Packit c4476c
Packit c4476c
# For the 'anything' policy
Packit c4476c
# At this point in time, you must list all acceptable 'object'
Packit c4476c
# types.
Packit c4476c
[ policy_anything ]
Packit c4476c
countryName		= optional
Packit c4476c
stateOrProvinceName	= optional
Packit c4476c
localityName		= optional
Packit c4476c
organizationName	= optional
Packit c4476c
organizationalUnitName	= optional
Packit c4476c
commonName		= supplied
Packit c4476c
emailAddress		= optional
Packit c4476c
Packit c4476c
####################################################################
Packit c4476c
[ req ]
Packit c4476c
default_bits		= 2048
Packit c4476c
default_md		= sha256
Packit c4476c
default_keyfile 	= privkey.pem
Packit c4476c
distinguished_name	= req_distinguished_name
Packit c4476c
attributes		= req_attributes
Packit c4476c
x509_extensions	= v3_ca	# The extensions to add to the self signed cert
Packit c4476c
Packit c4476c
# Passwords for private keys if not present they will be prompted for
Packit c4476c
# input_password = secret
Packit c4476c
# output_password = secret
Packit c4476c
Packit c4476c
# This sets a mask for permitted string types. There are several options.
Packit c4476c
# default: PrintableString, T61String, BMPString.
Packit c4476c
# pkix	 : PrintableString, BMPString (PKIX recommendation before 2004)
Packit c4476c
# utf8only: only UTF8Strings (PKIX recommendation after 2004).
Packit c4476c
# nombstr : PrintableString, T61String (no BMPStrings or UTF8Strings).
Packit c4476c
# MASK:XXXX a literal mask value.
Packit c4476c
# WARNING: ancient versions of Netscape crash on BMPStrings or UTF8Strings.
Packit c4476c
string_mask = utf8only
Packit c4476c
Packit c4476c
# req_extensions = v3_req # The extensions to add to a certificate request
Packit c4476c
Packit c4476c
[ req_distinguished_name ]
Packit c4476c
countryName			= Country Name (2 letter code)
Packit c4476c
countryName_default		= XX
Packit c4476c
countryName_min			= 2
Packit c4476c
countryName_max			= 2
Packit c4476c
Packit c4476c
stateOrProvinceName		= State or Province Name (full name)
Packit c4476c
#stateOrProvinceName_default	= Default Province
Packit c4476c
Packit c4476c
localityName			= Locality Name (eg, city)
Packit c4476c
localityName_default		= Default City
Packit c4476c
Packit c4476c
0.organizationName		= Organization Name (eg, company)
Packit c4476c
0.organizationName_default	= Default Company Ltd
Packit c4476c
Packit c4476c
# we can do this but it is not needed normally :-)
Packit c4476c
#1.organizationName		= Second Organization Name (eg, company)
Packit c4476c
#1.organizationName_default	= World Wide Web Pty Ltd
Packit c4476c
Packit c4476c
organizationalUnitName		= Organizational Unit Name (eg, section)
Packit c4476c
#organizationalUnitName_default	=
Packit c4476c
Packit c4476c
commonName			= Common Name (eg, your name or your server\'s hostname)
Packit c4476c
commonName_max			= 64
Packit c4476c
Packit c4476c
emailAddress			= Email Address
Packit c4476c
emailAddress_max		= 64
Packit c4476c
Packit c4476c
# SET-ex3			= SET extension number 3
Packit c4476c
Packit c4476c
[ req_attributes ]
Packit c4476c
challengePassword		= A challenge password
Packit c4476c
challengePassword_min		= 4
Packit c4476c
challengePassword_max		= 20
Packit c4476c
Packit c4476c
unstructuredName		= An optional company name
Packit c4476c
Packit c4476c
[ usr_cert ]
Packit c4476c
Packit c4476c
# These extensions are added when 'ca' signs a request.
Packit c4476c
Packit c4476c
# This goes against PKIX guidelines but some CAs do it and some software
Packit c4476c
# requires this to avoid interpreting an end user certificate as a CA.
Packit c4476c
Packit c4476c
basicConstraints=CA:FALSE
Packit c4476c
Packit c4476c
# Here are some examples of the usage of nsCertType. If it is omitted
Packit c4476c
# the certificate can be used for anything *except* object signing.
Packit c4476c
Packit c4476c
# This is OK for an SSL server.
Packit c4476c
# nsCertType			= server
Packit c4476c
Packit c4476c
# For an object signing certificate this would be used.
Packit c4476c
# nsCertType = objsign
Packit c4476c
Packit c4476c
# For normal client use this is typical
Packit c4476c
# nsCertType = client, email
Packit c4476c
Packit c4476c
# and for everything including object signing:
Packit c4476c
# nsCertType = client, email, objsign
Packit c4476c
Packit c4476c
# This is typical in keyUsage for a client certificate.
Packit c4476c
# keyUsage = nonRepudiation, digitalSignature, keyEncipherment
Packit c4476c
Packit c4476c
# This will be displayed in Netscape's comment listbox.
Packit c4476c
nsComment			= "OpenSSL Generated Certificate"
Packit c4476c
Packit c4476c
# PKIX recommendations harmless if included in all certificates.
Packit c4476c
subjectKeyIdentifier=hash
Packit c4476c
authorityKeyIdentifier=keyid,issuer
Packit c4476c
Packit c4476c
# This stuff is for subjectAltName and issuerAltname.
Packit c4476c
# Import the email address.
Packit c4476c
# subjectAltName=email:copy
Packit c4476c
# An alternative to produce certificates that aren't
Packit c4476c
# deprecated according to PKIX.
Packit c4476c
# subjectAltName=email:move
Packit c4476c
Packit c4476c
# Copy subject details
Packit c4476c
# issuerAltName=issuer:copy
Packit c4476c
Packit c4476c
#nsCaRevocationUrl		= http://www.domain.dom/ca-crl.pem
Packit c4476c
#nsBaseUrl
Packit c4476c
#nsRevocationUrl
Packit c4476c
#nsRenewalUrl
Packit c4476c
#nsCaPolicyUrl
Packit c4476c
#nsSslServerName
Packit c4476c
Packit c4476c
# This is required for TSA certificates.
Packit c4476c
# extendedKeyUsage = critical,timeStamping
Packit c4476c
Packit c4476c
[ v3_req ]
Packit c4476c
Packit c4476c
# Extensions to add to a certificate request
Packit c4476c
Packit c4476c
basicConstraints = CA:FALSE
Packit c4476c
keyUsage = nonRepudiation, digitalSignature, keyEncipherment
Packit c4476c
Packit c4476c
[ v3_ca ]
Packit c4476c
Packit c4476c
Packit c4476c
# Extensions for a typical CA
Packit c4476c
Packit c4476c
Packit c4476c
# PKIX recommendation.
Packit c4476c
Packit c4476c
subjectKeyIdentifier=hash
Packit c4476c
Packit c4476c
authorityKeyIdentifier=keyid:always,issuer
Packit c4476c
Packit c4476c
basicConstraints = critical,CA:true
Packit c4476c
Packit c4476c
# Key usage: this is typical for a CA certificate. However since it will
Packit c4476c
# prevent it being used as an test self-signed certificate it is best
Packit c4476c
# left out by default.
Packit c4476c
# keyUsage = cRLSign, keyCertSign
Packit c4476c
Packit c4476c
# Some might want this also
Packit c4476c
# nsCertType = sslCA, emailCA
Packit c4476c
Packit c4476c
# Include email address in subject alt name: another PKIX recommendation
Packit c4476c
# subjectAltName=email:copy
Packit c4476c
# Copy issuer details
Packit c4476c
# issuerAltName=issuer:copy
Packit c4476c
Packit c4476c
# DER hex encoding of an extension: beware experts only!
Packit c4476c
# obj=DER:02:03
Packit c4476c
# Where 'obj' is a standard or added object
Packit c4476c
# You can even override a supported extension:
Packit c4476c
# basicConstraints= critical, DER:30:03:01:01:FF
Packit c4476c
Packit c4476c
[ crl_ext ]
Packit c4476c
Packit c4476c
# CRL extensions.
Packit c4476c
# Only issuerAltName and authorityKeyIdentifier make any sense in a CRL.
Packit c4476c
Packit c4476c
# issuerAltName=issuer:copy
Packit c4476c
authorityKeyIdentifier=keyid:always
Packit c4476c
Packit c4476c
[ proxy_cert_ext ]
Packit c4476c
# These extensions should be added when creating a proxy certificate
Packit c4476c
Packit c4476c
# This goes against PKIX guidelines but some CAs do it and some software
Packit c4476c
# requires this to avoid interpreting an end user certificate as a CA.
Packit c4476c
Packit c4476c
basicConstraints=CA:FALSE
Packit c4476c
Packit c4476c
# Here are some examples of the usage of nsCertType. If it is omitted
Packit c4476c
# the certificate can be used for anything *except* object signing.
Packit c4476c
Packit c4476c
# This is OK for an SSL server.
Packit c4476c
# nsCertType			= server
Packit c4476c
Packit c4476c
# For an object signing certificate this would be used.
Packit c4476c
# nsCertType = objsign
Packit c4476c
Packit c4476c
# For normal client use this is typical
Packit c4476c
# nsCertType = client, email
Packit c4476c
Packit c4476c
# and for everything including object signing:
Packit c4476c
# nsCertType = client, email, objsign
Packit c4476c
Packit c4476c
# This is typical in keyUsage for a client certificate.
Packit c4476c
# keyUsage = nonRepudiation, digitalSignature, keyEncipherment
Packit c4476c
Packit c4476c
# This will be displayed in Netscape's comment listbox.
Packit c4476c
nsComment			= "OpenSSL Generated Certificate"
Packit c4476c
Packit c4476c
# PKIX recommendations harmless if included in all certificates.
Packit c4476c
subjectKeyIdentifier=hash
Packit c4476c
authorityKeyIdentifier=keyid,issuer
Packit c4476c
Packit c4476c
# This stuff is for subjectAltName and issuerAltname.
Packit c4476c
# Import the email address.
Packit c4476c
# subjectAltName=email:copy
Packit c4476c
# An alternative to produce certificates that aren't
Packit c4476c
# deprecated according to PKIX.
Packit c4476c
# subjectAltName=email:move
Packit c4476c
Packit c4476c
# Copy subject details
Packit c4476c
# issuerAltName=issuer:copy
Packit c4476c
Packit c4476c
#nsCaRevocationUrl		= http://www.domain.dom/ca-crl.pem
Packit c4476c
#nsBaseUrl
Packit c4476c
#nsRevocationUrl
Packit c4476c
#nsRenewalUrl
Packit c4476c
#nsCaPolicyUrl
Packit c4476c
#nsSslServerName
Packit c4476c
Packit c4476c
# This really needs to be in place for it to be a proxy certificate.
Packit c4476c
proxyCertInfo=critical,language:id-ppl-anyLanguage,pathlen:3,policy:foo
Packit c4476c
Packit c4476c
####################################################################
Packit c4476c
[ tsa ]
Packit c4476c
Packit c4476c
default_tsa = tsa_config1	# the default TSA section
Packit c4476c
Packit c4476c
[ tsa_config1 ]
Packit c4476c
Packit c4476c
# These are used by the TSA reply generation only.
Packit c4476c
dir		= /etc/pki/CA		# TSA root directory
Packit c4476c
serial		= $dir/tsaserial	# The current serial number (mandatory)
Packit c4476c
crypto_device	= builtin		# OpenSSL engine to use for signing
Packit c4476c
signer_cert	= $dir/tsacert.pem 	# The TSA signing certificate
Packit c4476c
					# (optional)
Packit c4476c
certs		= $dir/cacert.pem	# Certificate chain to include in reply
Packit c4476c
					# (optional)
Packit c4476c
signer_key	= $dir/private/tsakey.pem # The TSA private key (optional)
Packit c4476c
signer_digest  = sha256			# Signing digest to use. (Optional)
Packit c4476c
default_policy	= tsa_policy1		# Policy if request did not specify it
Packit c4476c
					# (optional)
Packit c4476c
other_policies	= tsa_policy2, tsa_policy3	# acceptable policies (optional)
Packit c4476c
digests     = sha1, sha256, sha384, sha512  # Acceptable message digests (mandatory)
Packit c4476c
accuracy	= secs:1, millisecs:500, microsecs:100	# (optional)
Packit c4476c
clock_precision_digits  = 0	# number of digits after dot. (optional)
Packit c4476c
ordering		= yes	# Is ordering defined for timestamps?
Packit c4476c
				# (optional, default: no)
Packit c4476c
tsa_name		= yes	# Must the TSA name be included in the reply?
Packit c4476c
				# (optional, default: no)
Packit c4476c
ess_cert_id_chain	= no	# Must the ESS cert id chain be included?
Packit c4476c
				# (optional, default: no)
Packit c4476c
ess_cert_id_alg		= sha1	# algorithm to compute certificate
Packit c4476c
				# identifier (optional, default: sha1)