1 unstable release
Uses old Rust 2015
0.1.3 | Oct 12, 2016 |
---|
#1207 in Cryptography
Used in 2 crates
(via nss-webpki)
325KB
123 lines
Mozilla CA Certs, as a Rust crate
This crate statically embeds most of the information from the Mozilla CA Certificate Store into Rust programs. This includes all the certificates and raw trust entries, as well as more limited sets of trust roots and explicit distrust items.
There's also an (optional, enabled by default) integration with
webpki, which exposes the TLS server trust roots as webpki
TrustAnchor
s.
Warning
The Mozilla CA policy is mostly a set of trust roots, but there are
some more complicated cases, and they aren't all reflected properly in
this crate yet. For example, the CNNIC roots: the official policy is
that it's untrusted except for a fixed list of 1,427 issued certs, but
this is reflected by marking the roots as completely trusted in
certdata.txt
and expressing the restriction as
C++ code in Firefox. Because this crate is currently
just a translation of certdata.txt
, those roots are listed as
trusted when the truth is closer to the opposite of that.
Related Work
The webpki-roots crate also represents the Mozilla CA Certificate
Store in webpki form, but it makes its own policy decisions and
specifically excludes mostly-untrusted roots like CNNIC. It doesn't
attempt to represent the distrusts from certdata.txt
.
The build is also handled differently: webpki-roots includes
pre-generated source and a Python script for rebuilding it by
retrieving certificates from a Web service, whereas this crate
includes a copy of certdata.txt
and parser/translates it at build time.
Bugs
-
Correctly represent Mozilla poicy with respect to semi-trusted certificates (see the Warning section, above).
-
The Rust compiler is not very fast at handling large amounts of
[u8]
literals. Build time could probably be improved by avoiding duplication in the source and/or allowing dependent crates to opt out of building the parts they're not using. -
Add some simple utilities for doing lookups in the distrust lists (and extend this to other forms of distrust, when implemented).
Dependencies
~0–7.5MB
~69K SLoC