Change the criticality of a number of X509 extentions, to match
the RFCs and real-world CAs/certs. This improve compatability with older browsers/clients.
This commit is contained in:
parent
a3107474f9
commit
d8f54c7c03
|
@ -29,12 +29,12 @@ def create_ca(o, cn, exp):
|
|||
cert.add_extensions([
|
||||
OpenSSL.crypto.X509Extension("basicConstraints", True,
|
||||
"CA:TRUE"),
|
||||
OpenSSL.crypto.X509Extension("nsCertType", True,
|
||||
OpenSSL.crypto.X509Extension("nsCertType", False,
|
||||
"sslCA"),
|
||||
OpenSSL.crypto.X509Extension("extendedKeyUsage", True,
|
||||
OpenSSL.crypto.X509Extension("extendedKeyUsage", False,
|
||||
"serverAuth,clientAuth,emailProtection,timeStamping,msCodeInd,msCodeCom,msCTLSign,msSGC,msEFS,nsSGC"
|
||||
),
|
||||
OpenSSL.crypto.X509Extension("keyUsage", False,
|
||||
OpenSSL.crypto.X509Extension("keyUsage", True,
|
||||
"keyCertSign, cRLSign"),
|
||||
OpenSSL.crypto.X509Extension("subjectKeyIdentifier", False, "hash",
|
||||
subject=cert),
|
||||
|
@ -67,7 +67,7 @@ def dummy_cert(privkey, cacert, commonname, sans):
|
|||
cert.set_serial_number(int(time.time()*10000))
|
||||
if ss:
|
||||
cert.set_version(2)
|
||||
cert.add_extensions([OpenSSL.crypto.X509Extension("subjectAltName", True, ss)])
|
||||
cert.add_extensions([OpenSSL.crypto.X509Extension("subjectAltName", False, ss)])
|
||||
cert.set_pubkey(cacert.get_pubkey())
|
||||
cert.sign(privkey, "sha1")
|
||||
return SSLCert(cert)
|
||||
|
|
Loading…
Reference in New Issue