The base set of tests for all ACME challenge strategies (including greenlock). Any `acme-challenge-` plugin should be able to pass these tests.
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
AJ ONeal 803cb4ef2c add missing node-v6-compat il y a 5 ans
lib add missing node-v6-compat il y a 5 ans
.gitignore initial commit il y a 5 ans
.prettierrc v3.2.0: support zones(), separate docs il y a 5 ans
LICENSE add LICENSE il y a 5 ans
README.md clean text il y a 5 ans
example.js from tabs back to spaces il y a 5 ans
index.js add missing node-v6-compat il y a 5 ans
package.json add missing node-v6-compat il y a 5 ans

README.md

acme-challenge-test | a Root project

Test harness for ACME http-01 and dns-01 challenges for Let's Encrypt Free SSL integration.

This was specificially designed for ACME.js and Greenlock.js, but will be generically useful to any ACME module.

If you are building a plugin, please let us know. We may like to co-author and help maintain and promote your module.

This package has been split in two for the purpose of keeping the documentation clear and concise.

ACME http-01

Use this for quick-and-easy, average-joe kind of stuff.

ACME dns-01

Use this for wildcards, and private and local domains.

Reference Implementations

These are plugins that use the v2.7+ (v3) API, and pass this test harness, which you should use as a model for any plugins that you create.

You can find other implementations by searching npm for acme-http-01- and acme-dns-01-.

Starter Template

Just so you have an idea, this is typically how you'd start passing the tests:

var tester = require('acme-challenge-test');

// The dry-run tests can pass on, literally, 'example.com'
// but the integration tests require that you have control over the domain
var domain = 'example.com';

tester
  .testRecord('http-01', domain, {
    set: function(opts) {
      console.log('set opts:', opts);
      throw new Error('set not implemented');
    },

    remove: function(opts) {
      console.log('remove opts:', opts);
      throw new Error('remove not implemented');
    },

    get: function(opts) {
      console.log('get opts:', opts);
      throw new Error('get not implemented');
    }
  })
  .then(function() {
    console.info('PASS');
  });