@small-tech/syswide-cas
v7.0.2
Published
Fork of syswide-cas by a now-defunct company called Capriza. Enable node to use system wide certificate authorities in conjunction with the bundled root CAs.
Maintainers
Readme
@small-tech/syswide-cas
Note: this is a fork of the original module being maintained by Aral Balkan of Small Technology Foundation as the original company seems to have gone out of business.
Enables Node.js to use custom Certificate Authorities (CAs) alongside the bundled root CAs.
Until version 7, Node did not support system-wide installed trusted CAs. You could only specify a custom CA via the ca option in the tls and https modules or fallback to using the bundled list of root CAs Node is compiled with.
Starting with version 7, it’s possible to set the NODE_EXTRA_CA_CERTS environment variable to a single file containing an additional root CA to trust, however it still does not allow programmatic addition of several directories and files containing root CAs.
This module enables custom CAs to be used alongside the root CAs bundled with Node.
💡 syswide-cas will automatically load root CAs from the file
/etc/ssl/ca-node.pemif it exists.
Install
npm i @small-tech/syswide-casUse
💡 Import
@small-tech/syswide-casbefore any TLS calls if you use dynamic imports.
// Importing syswide-cas automatically loads Certificate Authorities (CAs) from the file _/etc/ssl/ca-node.pem_ if it exists
import syswideCas from '@small-tech/syswide-cas'
// Optionally, load all files from a custom directory.
syswideCas.addCAs('/my/custom/path/to/certs/dir')
// Or multiple directories.
syswideCas.addCAs(['/my/custom/path/to/certs/dir1', '/my/other/path/to/certs/dir2'])
// Optionally, load a file directly.
syswideCas.addCAs('/my/custom/path/to/cert.pem')
// Or multiple files.
syswideCas.addCAs(['/my/custom/path/to/cert1.pem', '/my/other/path/to/cert2.pem'])
import https from 'node:https'
https.get('https://my.custom.domain.com/with/self/signed/cert')Test
npm -s testTests failing? Read this!
If you get the following error when running the tests:
✖ FAIL: page with self-signed certificate loads with syswide-casIt’s possible that the Root Certificate Authority has changed on badssl.com.
We use https://self-signed.badssl.com/ for the tests and its Certificate Authority (in PEM format) can be found in /tests/fixtures/self-signed.badssl.com.
To update the fixture:
- In Chromium, visit https://self-signed.badssl.com/
- Click on the “✖ Not Secure” button in the address bar.
- Select “Certificate details”
- Navigate to the Details tab
- Click the “Export…” button
- Under “Format” choose “Base64-encoded ASCII, single certificate and save it on top of /tests/fixtures/self-signed.badssl.com.
Ensure that the certificate has changed by doing a git diff and, if so, run the tests again and they should pass.
Please open an issue to let us know the BadSSL certificate has changed and, if you can, please open a pull request to resolve it using the new certificate.
Thanks!
License
Copyright 2021-present Aral Balkan, Small Technology Foundation. Copyright 2016 Capriza.
Code released under the MIT license
