The module you need to solve node's SSL woes when including a custom certificate.
Let's say you're trying to connect to a site with a cheap-o SSL cert -
such as RapidSSL certificate from name.com (the best place to get your domains, btw) -
you'll probably get an error like UNABLE_TO_VERIFY_LEAF_SIGNATURE
and after you google around and figure that
out you'll be able to connect to that site just fine, but now when you try to connect to other sites you get
CERT_UNTRUSTED
or possibly other errors.
This module is the solution to your woes!
FYI, I'm merely the publisher, not the author of this module. See here: https://groups.google.com/d/msg/nodejs/AjkHSYmiGYs/1LfNHbMhd48J
The script downloads the same root CAs that are included with
Mozilla Firefox,
Google Chrome,
libnss
,
and OpenSSL*:
https://mxr.mozilla.org/nss/source/lib/ckfw/builtins/certdata.txt?raw=1
* OpenSSL doesn't actually bundle these CAs, but they suggest using them
Other Implementations
- Golang https://github.com/agl/extract-nss-root-certs
- Perl https://github.com/bagder/curl/blob/master/lib/mk-ca-bundle.pl
'use strict';
// This will add the well-known CAs
// to `https.globalAgent.options.ca`
require('ssl-root-cas/latest')
.inject()
.addFile(__dirname + '/ssl/01-cheap-ssl-intermediary-a.pem')
.addFile(__dirname + '/ssl/02-cheap-ssl-intermediary-b.pem')
.addFile(__dirname + '/ssl/03-cheap-ssl-site.pem')
;
For the sake of version consistency this package ships with the CA certs that were available at the time it was published, but for the sake of security I recommend you use the latest ones.
If you want the latest certificates (downloaded as part of the postinstall process), you can require those like so:
require('ssl-root-cas/latest').inject();
You can use the ones that shippped with package like so:
require('ssl-root-cas').inject();
I thought it might be rude to modify https.globalAgent.options.ca
on require
,
so I afford you the opportunity to inject()
the certs at your leisure.
inject()
keeps track of whether or not it's been run, so no worries about calling it twice.
This is just a convenience method so that you don't
have to require fs
and path
if you don't need them.
require('ssl-root-cas/latest')
.addFile(__dirname + '/ssl/03-cheap-ssl-site.pem')
;
is the same as
var https = require('https')
, cas
;
cas = https.globalAgent.options.ca || [];
cas.push(fs.readFileSync(path.join(__dirname, 'ssl', '03-cheap-ssl-site.pem')));
If for some reason you just want to look at the array of Root CAs without actually injecting
them, or you just prefer to
https.globalAgent.options.ca = require('ssl-root-cas').rootCas;
yourself, well, you can.
Don't use dissolutions such as these. :-)
This will turn off SSL validation checking. This is not a good idea. Please do not do it. (really I'm only providing it as a reference for search engine seo so that people who are trying to figure out how to avoid doing that will end up here)
process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0"
The same dissolution from the terminal would be
export NODE_TLS_REJECT_UNAUTHORIZED="0"
node my-service.js