acme-v2.js
| Sponsored by ppl
A framework for building letsencrypt clients (and other ACME v2 clients), forked from le-acme-core.js
.
Summary of spec that I'm working off of here: https://git.coolaj86.com/coolaj86/greenlock.js/issues/5#issuecomment-8
In progress
- Mar 15, 2018 - get directory
- Mar 15, 2018 - get nonce
- Mar 15, 2018 - generate account keypair
- Mar 15, 2018 - create account
- Mar 16, 2018 - new order
- Mar 16, 2018 - get challenges
- Mar 20, 2018 - respond to challenges
- Mar 20, 2018 - generate domain keypair
- Mar 20, 2018 - finalize order (submit csr)
- Mar 20, 2018 - poll for status
- Mar 20, 2018 - download certificate
- Mar 20, 2018 - SUCCESS - got a test certificate (hard-coded)
- Mar 21, 2018 - can now accept values (not hard coded)
- Mar 21, 2018 - mostly matches le-acme-core.js API
Todo
- completely match api for acme v1 (le-acme-core.js)
- test http and dns challenges
- export http and dns challenge tests
- support ECDSA keys
API
var ACME = require('acme-v2.js').ACME.create({
RSA: require('rsa-compat').RSA
});
ACME.registerNewAccount(options, cb)
{ email: '<email>'
, accountKeypair: {
privateKeyPem: '<ASCII PEM>'
}
, agreeToTerms: fn (tosUrl, cb) {}
}
ACME.getCertificate(options, cb)
{ newAuthzUrl: '<url>'
, newCertUrl: '<url>'
, domainKeypair: {
privateKeyPem: '<ASCII PEM>'
}
, accountKeypair: {
privateKeyPem: '<ASCII PEM>'
}
, domains: [ 'example.com' ]
, setChallenge: fn (hostname, key, val, cb)
, removeChallenge: fn (hostname, key, cb)
}
ACME.getAcmeUrls(acmeDiscoveryUrl, cb)
Helpers & Stuff
ACME.productionServerUrl
ACME.stagingServerUrl
ACME.acmeChallengePrefix