SecurityEngineering/mozpkix-testing: Difference between revisions

m
 
(31 intermediate revisions by 3 users not shown)
Line 12: Line 12:
# Download Firefox 31 or later
# Download Firefox 31 or later
#* Browse to ftp://ftp.mozilla.org/pub/firefox/tinderbox-builds/
#* Browse to ftp://ftp.mozilla.org/pub/firefox/tinderbox-builds/
#* Scroll down to mozilla-central-<platform>-debug and select the folder that matches the platform you are working on.  
#* Scroll down to mozilla-central-<platform> and select the folder that matches the platform you are working on.  
#* Select the most recent build in the list.
#* Select the most recent build in the list.
#* Download by selecting the .tar.bz2 (Linux), .dmg (Mac), or .exe (Windows) file.
#* Download by selecting the .tar.bz2 (Linux), .dmg (Mac), or .exe (Windows) file.
#* After downloading, extract and run this debug browser, which will be called FirefoxNightlyDebug.
#* After downloading, extract and run this nightly browser, which will be called FirefoxNightly.
# mozilla::pkix should be enabled by default. Ensure that it is by doing the following:
# In Firefox 33 and later, mozilla::pkix is enabled by default, and there is no longer an about:config option to disable it.
# In Firefox 31 and Firefox 32 mozilla::pkix is enabled by default, and there is an about:config option that can be used to disable and enable it. In Firefox 31 and Firefox 32 you can ensure that mozilla::pkix is enabled by doing the following:
#* Open [http://kb.mozillazine.org/About:config about:config] in Firefox
#* Open [http://kb.mozillazine.org/About:config about:config] in Firefox
#* Locate the preference "security.use_mozillapkix_verification"
#* Locate the preference "security.use_mozillapkix_verification"
#* If it is true, nothing more needs to be done
#* If it is true, nothing more needs to be done
#* If it is false, set it to true
#* If it is false, set it to true
#* If it is not present, update to a more recent FirefoxNightlyDebug build
#* If it is not present, update to a more recent FirefoxNightly build
#* Clear your browser cache if you are going to browse to a site you visited with mozilla::pkix off
#* Clear your browser cache if you are going to browse to a site you visited with mozilla::pkix off
# Browse to various websites with known valid and expired/revoked/etc SSL certificates.  
# Browse to various websites with known valid and expired/revoked/etc SSL certificates.  
#* Note to CAs: Be sure to check EV status, and check chains through all currently-used intermediate certs.
#* Note to CAs: Be sure to check EV status, and check chains through all currently-used intermediate certs.
# If you don't get the expected result, then try again without using mozilla::pkix to see if the unexpected result is actually due to mozilla::pkix.
# If you don't get the expected result, then in Firefox 31 and Firefox 32 you can try again without using mozilla::pkix to see if the unexpected result is actually due to mozilla::pkix.
#* In [http://kb.mozillazine.org/About:config about:config] toggle "security.use_mozillapkix_verification" to false
#* In [http://kb.mozillazine.org/About:config about:config] toggle "security.use_mozillapkix_verification" to false
#** Or switch to a previously released version of Firefox
#** Or switch to a previously released version of Firefox
Line 74: Line 75:
= Behavior Changes =
= Behavior Changes =
Mozilla::pkix includes some changes in support of current best practices and policies, as listed below. If you notice an issue due to any of these changes, please feel free to [https://groups.google.com/d/msg/mozilla.dev.tech.crypto/EbWse7Ryj8I/mgNRW4yGAwUJ let us know]. However, we believe that in most cases, the simplest resolution will be to update the SSL certificate in your webserver.  
Mozilla::pkix includes some changes in support of current best practices and policies, as listed below. If you notice an issue due to any of these changes, please feel free to [https://groups.google.com/d/msg/mozilla.dev.tech.crypto/EbWse7Ryj8I/mgNRW4yGAwUJ let us know]. However, we believe that in most cases, the simplest resolution will be to update the SSL certificate in your webserver.  
# Mozilla::pkix does not allow x509 version 2 certificates in any position (root, intermediate or End-Entity (EE))  and version 1 certificates are only allowed as trust anchors.  
# End-entity certificates used in SSL/TLS servers:
# End certificates used by servers are not allowed to have basic constraints asserting isCA=TRUE.
#* Are not allowed to have basic constraints asserting isCA=TRUE.
# Version 3 certificates used as trust anchors or intermediates are now required to have the basic constraints extention and assert the isCA bit.
#* When the EKU extension is specified, must assert the serverAuth bit.
# Mozilla::pkix performs chaining based on issuer name alone, and does not require that issuer's subject key match the authority key info (AKI) extension in the certificate.  Classic verification enforces the AKI restriction.
#* Are no longer allowed to include the OCSPSigning EKU.
# A certificate will not be considered an EV certificate if mozilla::pkix cannot build a path to a trusted root that does not contain any certificates with the inhibitAnyPolicy extension. However, such certificates will still validate as non-EV as long as there are no non-policy-related issues. {{Bug|989051}}
#* Cannot have the Netscape Cert Type extension marked as critical.
# End-entity certificates that contain the EKU extension are now required to assert the serverAuth bit.
# Mozilla::pkix does not allow x509 '''version 2''' certificates in any position (root, intermediate or end-entity), and '''version 1''' certificates are only allowed as trust anchors. {{Bug|969188}}
# End-entity certificates are no longer allowed to include the OCSPSigning EKU.
# Version 3 root and intermediate certificates are now required to have the basic constraints extension and assert the isCA bit.
# Intermediate certificates that contain the EKU extension now are required to assert either the serverAuth bit or the Netscape Server Gated Crypto bit (support for NSGC is provided temporarily for backward compatibility).
# Mozilla::pkix performs chaining based on issuer name alone, and does not require that issuer's subject key match the authority key info (AKI) extension in the certificate.   
# If a root or intermediate certificate contains the EKU extension, and that intermediate certificate will be used to issue SSL/TLS certificates, then the EKU must include the id-kp-serverAuth (1.3.6.1.5.5.7.3.1) bit or the Netscape Server Gated Crypto bit (support for NSGC is provided temporarily for backward compatibility). {{Bug|982292}}


= Things for CAs to Fix =
= Things for CAs to Fix =
Line 87: Line 89:
Workarounds were implemented to allow mozilla::pkix to handle some of the following situations. We will be asking CAs to immediately stop issuing new certificates with these issues, and we will identify dates for removing these workarounds.
Workarounds were implemented to allow mozilla::pkix to handle some of the following situations. We will be asking CAs to immediately stop issuing new certificates with these issues, and we will identify dates for removing these workarounds.


# For all new intermediate certificate issuance, use the "TLS Web Server Authentication (1.3.6.1.5.5.7.3.1)" (serverAuth) EKU if that intermediate certificate will be signing SSL certificates. Mozilla will stop recognizing the "Netscape Server Gated Crypto (2.16.840.1.113730.4.1)" EKU.   
# All new intermediate certificates that include the EKU extension and will be used for SSL certificate issuance, must include the id-kp-serverAuth (1.3.6.1.5.5.7.3.1) EKU. Mozilla will stop recognizing the "Netscape Server Gated Crypto (2.16.840.1.113730.4.1)" EKU.   
#* Intermediate certificates are not required to have an EKU, but if a new intermediate certificate does have an EKU and the intermediate will be used for SSL, then it must have the id-kp-serverAuth EKU. See sections #8, 9, and 10 of [http://www.mozilla.org/about/governance/policies/security-group/certs/policy/inclusion/ Mozilla's CA Certificate Inclusion Policy].
#* Related Bugs: {{Bug|982292}}, {{Bug|982932}}, {{Bug|982936}}
#* Related Bugs: {{Bug|982292}}, {{Bug|982932}}, {{Bug|982936}}
# Default values in a SEQUENCE must not be explicitly encoded. We found end-entity certificates that have the value cA:false explicitly encoded.
# Default values in a SEQUENCE must not be explicitly encoded.  
#* 11.5 of X.690 - "The encoding of a set value or sequence value shall not include an encoding for any component value which is equal to its default value."
#* [http://www.itu.int/ITU-T/studygroups/com17/languages/X.690-0207.pdf ITU-T X.690] section 11.5: "The encoding of a set value or sequence value shall not include an encoding for any component value which is equal to its default value."
#* Note: We encountered certificates with a basicConstraints extension that explicitly encoded the default value cA:false. The solution that we recommend is to not include the basicConstraints extension in end-entity certificates.
#* Related Bugs: {{Bug|988633}}, {{Bug|989516}}, {{Bug|989518}}
#* Related Bugs: {{Bug|988633}}, {{Bug|989516}}, {{Bug|989518}}
# Basic constraints: pathLenConstraint must not be included if cA is false
# Basic constraints: pathLenConstraint must not be included if cA is false
Line 97: Line 101:
# OCSP responders should not include a responseExtensions consisting of an empty SEQUENCE (e.g. A2 02 30 00 - see http://tools.ietf.org/html/rfc6960#section-4.2.1 under ResponseData for reference). [http://www.ietf.org/rfc/rfc3280.txt RFC 3280] defines Extensions as SEQUENCE SIZE (1..MAX) OF Extension, so the empty SEQUENCE is not a valid encoding. Instead of using an empty SEQUENCE, the OCSP responder should just omit the responseExtensions in the ResponseData.
# OCSP responders should not include a responseExtensions consisting of an empty SEQUENCE (e.g. A2 02 30 00 - see http://tools.ietf.org/html/rfc6960#section-4.2.1 under ResponseData for reference). [http://www.ietf.org/rfc/rfc3280.txt RFC 3280] defines Extensions as SEQUENCE SIZE (1..MAX) OF Extension, so the empty SEQUENCE is not a valid encoding. Instead of using an empty SEQUENCE, the OCSP responder should just omit the responseExtensions in the ResponseData.
#* Related Bugs: {{Bug|991898}}, {{Bug|997994}}
#* Related Bugs: {{Bug|991898}}, {{Bug|997994}}
# According to RFC 5280: "In conforming CA certificates, the value of the subject key identifier MUST be the value placed in the key identifier field of the authority key identifier extension (Section 4.2.1.1) of certificates issued by the subject of this certificate. Applications are not required to verify that key identifiers match when performing certification path validation." So, in mozilla::pkix we will not be checking this, but we would like to remind CAs that they are supposed to do this.
# OCSP responses for subscriber certificates must have a maximum expiration time of ten days. BR #13.2.2: "For the status of Subscriber Certificates: ... The CA SHALL update information provided via an Online Certificate Status Protocol at least every four days. OCSP responses from this service MUST have a maximum expiration time of ten days."
#* Related Bugs: {{Bug|991823}}, {{Bug|997917}}
#* Related Bugs: {{Bug|1025625}}, {{Bug|997509}}
# EV treatment will not be given when the OCSP response for the intermediate certificate is more than 10 days old. For both intermediate and end-entity certificates, OCSP responses must have a maximum expiration time of ten days. {{Bug|991815#c13}}
# All times in all certificates must be encoded in a way that conforms to the stricter requirements in RFC 5280. In particular, the timezone must always be specified as "Z" (Zulu/GMT).
#* Related Bugs: {{Bug|1152515#c15}}, {{Bug|1085238#c4}}, {{Bug|1019770}}
#* Beginning in Firefox 33, mozilla::pkix enforces the requirement that the timezone always be specified as "Z". However, there may be some UX and certificate viewer cleanup needed to make this more clear, as per {{Bug|1152515#c15}} and {{Bug|1152515#c16}}
# When signing OCSP responses with a delegated OCSP response signing certificate, ensure that the delegated OCSP response signing certificate will not expire before the OCSP response expires. Otherwise, when doing OCSP stapling, some servers will cache the OCSP response past the point where the delegated response signing certificate expires, and then Firefox will reject the connection.
#* Related Bugs: {{Bug|1046223}}
# RSA end-entity certificates that have a KeyUsage extension should include keyEncipherment in the KeyUsage extension if the subscriber intends for the certificate to be used for RSA key exchange in TLS. In other words, include keyEncipherment in RSA certificates--but not ECDSA certificates--unless the subscriber asks for it not to be included. This way, Firefox can start enforcing the correct KeyUsage.
#* Related Bugs: {{Bug|970760}}
# Include the subjectAltName extension with appropriate dNSName/iPAddress entries in all certificates. Hopefully soon Firefox will be able to stop falling back on the subject CN when there are no dNSName/iPAddress SAN entries.
#* Related Bugs: {{Bug|1143085}}, {{Bug|1136616}}, {{Bug|1148766}}
# Do not use any string types other than PrintableString and UTF8String in DirectoryString components of names. In particular, RFC 5280 says "TeletexString, BMPString, and UniversalString are included for backward compatibility, and SHOULD NOT be used for certificates for new subjects." Hopefully we will stop accepting certificates that use those obsolete encodings soon.
#* Related Bugs: {{Bug|1089104}}
# Use the same encoding for name constraints as subject alternative names.
#* Related Bugs: {{Bug|1150114}}


== Future Considerations ==
= Future Considerations =
While testing mozilla::pkix, we noticed the following things that we would like to consider.
While testing mozilla::pkix, we noticed the following things that we would like to consider.
# In mozilla::pkix we won't accept any OCSP responses that are more than 10 days old, even for intermediate certificates. So EV treatment will not be given when an OCSP response is older than 10 days. In the [https://cabforum.org/baseline-requirements-documents/ BRs], the statement: "OCSP responses from this service MUST have a maximum expiration time of ten days." needs to be added to the Subordinate CA Certificates section. If a CA with an intermediate OCSP nextUpdate six months in the future actually revokes that intermediate today because an attacker got its private key, then an attacker could still MitM users for 6 months from today. We need to require intermediate OCSP nextUpdate values to be 10 days from thisUpdate or less.
# In the [https://cabforum.org/baseline-requirements-documents/ BRs], the statement: "OCSP responses from this service MUST have a maximum expiration time of ten days." needs to be added to the Subordinate CA Certificates section of BR #13.2.2. If a CA with an intermediate OCSP nextUpdate six months in the future actually revokes that intermediate today because an attacker got its private key, then an attacker could still MitM users for 6 months from today. We need to require intermediate OCSP nextUpdate values to be 10 days from thisUpdate or less.
#* Related Bugs: {{Bug|991815#c13}}
#* Related Bugs: {{Bug|991815}}, {{Bug|1009110}}
#* OneCRL will reduce our dependence on intermediate cert OCSP responses, so this is probably not worth pushing.
# EV treatment should not be given when the end-entity cert is signed directly by the root cert. The [https://cabforum.org/extended-validation/ EV Guidelines] say: "Root CA Private Keys MUST NOT be used to sign EV Certificates." We should programmatically enforce this.
# EV treatment should not be given when the end-entity cert is signed directly by the root cert. The [https://cabforum.org/extended-validation/ EV Guidelines] say: "Root CA Private Keys MUST NOT be used to sign EV Certificates." We should programmatically enforce this.
#* Related Bugs: {{Bug|991921}}
#* Related Bugs: {{Bug|991921}}
# Consider only giving EV treatment when the intermediate and end-entity certs in the chain have the specific EV policy OID that we are expecting; in other words, don’t give EV treatment when the intermediate certificate has the anyPolicy OID. To make this change, would need to change the CAB Forum’s EV Guidelines to also require the EV policy OID in intermediate certs (section 9.3.4 says the subordinate CA certificate may contain anyPolicy OID 2.5.29.32.0).
# Consider only giving EV treatment when the intermediate and end-entity certs in the chain have the specific EV policy OID that we are expecting; in other words, don’t give EV treatment when the intermediate certificate has the anyPolicy OID. To make this change, would need to change the CAB Forum’s EV Guidelines to also require the EV policy OID in intermediate certs (section 9.3.4 says the subordinate CA certificate may contain anyPolicy OID 2.5.29.32.0).
#* Related Bugs: {{Bug|986156}}
#* Related Bugs: {{Bug|986156}}
#* On consideration, this would be a big change, affecting almost all intermediates which issue EV certs. So it's probably not worth it.
Confirmed users, Administrators
5,526

edits