Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@vladmandic/piacme

Package Overview
Dependencies
Maintainers
1
Versions
32
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@vladmandic/piacme

Simple ACME/LetsEncrypt HTTP/SSL Certificate Management

  • 0.1.4
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
37
increased by1133.33%
Maintainers
1
Weekly downloads
 
Created
Source

piacme

Simple ACME/LetsEncrypt HTTP/SSL Certificate Management

Usage

Initialize PiACME by passing a configuration object:

const config = {
  application: 'example/0.0.1',              // website or application signature, can be any string
  domains: ['example1.com', 'example2.com'], // list of domains for which we're getting a certificate for (same certificate can be used for multiple domain). must be resolvable and reachable over internet for validation before certificate can be issued.
  maintainer: 'maintainer@example.com',      // email of the person responsible for the site for which we're getting certificate for
  subscriber: 'subscriber@example.com',      // email of the person that will be registered with LetsEncrypt, can be the same as maintainer
  accountFile: './cert/account.json',        // file where account info will be stored once account is created
  accountKeyFile: './cert/account.pem',      // file where account secret will be stored once account is created
  ServerKeyFile: './cert//private.pem',      // file where server private key will be stored 
  fullChain: './cert/fullchain.pem',         // file where server certificate will be stored
};

const piacme = require('piacme');
piacme.init(config);
const { Key, Crt } = await acme.getCert();

Now you're free to use server key and certificate.
For example to start a secure http2 server:

const http2 = require('http2');
const opts = {
  key = fs.readFileSync(Key);
  cert = fs.readFileSync(Crt);
};
const server = http2.createSecureServer(opts);
server.listen(443);

Internal workflow

All functions use same object passed during init() call. Core function is getCert() and it will either return existing valid certificate, issue a new one or trigger a certificate renewal.

Internally, it calls piacme.checkCert() to verify if server key and certificate specified in config object already exists and are valid.
If yes, it will just return those objects: config.ServerKeyFile and config.fullChain.
If not, if calls:

  • piacme.createKeys()
    Which is used only once per server lifetime.
    It initialize LetsEncrypt account using maintainer info and generate server private key.
  • piacme.createCert()
    Which is used to genrates new certificate if one doesn't exist or is about to expire.
    Interally it temporarily starts a http server on port 80 to listen for LetsEncrypt validation callbacks and then shuts down the server.

Next, it calls parseCert() and parses cetificate details for validity before returning server key and certificate.

Optional

To monitor certificate, call monitorCert() which updates object initially passed using init() call by triggering getCert() every 12 hours.
Usefull for certfificates with short lifespan that require freqent renewals.

To get certificate details, call parseCert() and it will parse certificate from the initial object used during init() call.

const ssl = await parseCert();
ssl: {
  account: { error?, contact, createdAt },
  serverKey: { error? },
  accountKey: { error? },
  fullChain: { error?, subject, issuer, notBefore, notAfter }
}

Keywords

FAQs

Package last updated on 06 Aug 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc