greenlock-express.js/lex.js

58 lines
1.6 KiB
JavaScript
Raw Normal View History

2016-08-10 17:10:00 +00:00
'use strict';
2016-08-12 07:02:33 +00:00
// opts.approveDomains(options, certs, cb)
2016-08-10 17:10:00 +00:00
module.exports.create = function (opts) {
2016-08-16 01:15:16 +00:00
// accept all defaults for le.challenges, le.store, le.middleware
var le = require('letsencrypt').create(opts);
opts.app = opts.app || require('express')().use('/', function (req, res) {
res.end("Hello, World!\nWith Love,\nLet's Encrypt Express");
});
opts.listen = function (plainPort, port) {
var PromiseA = require('bluebird');
var promises = [];
var plainPorts = plainPort;
var ports = port;
var servers = [];
if (!plainPorts || !ports) {
plainPorts = 80;
ports = 443;
2016-08-10 17:10:00 +00:00
}
2016-08-16 01:15:16 +00:00
if (!Array.isArray(plainPorts)) {
plainPorts = [ plainPorts ];
ports = [ ports ];
}
2016-08-10 17:10:00 +00:00
2016-08-16 01:15:16 +00:00
plainPorts.forEach(function (p) {
promises.push(new PromiseA(function (resolve, reject) {
2016-08-16 17:05:41 +00:00
require('http').createServer(le.middleware(require('redirect-https')())).listen(p, function () {
console.log("Handling ACME challenges and redirecting to https on plain port " + p);
2016-08-16 01:15:16 +00:00
resolve();
}).on('error', reject);
}));
2016-08-10 17:10:00 +00:00
});
2016-08-16 01:15:16 +00:00
ports.forEach(function (p) {
promises.push(new PromiseA(function (resolve, reject) {
var server = require('https').createServer(le.httpsOptions, le.middleware(le.app)).listen(p, function () {
2016-08-16 17:05:41 +00:00
console.log("Handling ACME challenges and serving https " + p);
2016-08-16 01:15:16 +00:00
resolve();
}).on('error', reject);
servers.push(server);
}));
});
2016-08-11 07:07:20 +00:00
2016-08-16 01:15:16 +00:00
if (!Array.isArray(port)) {
servers = servers[0];
}
2016-08-10 17:10:00 +00:00
2016-08-16 01:15:16 +00:00
return servers;
2016-08-10 17:10:00 +00:00
};
2016-08-16 01:15:16 +00:00
return le;
2016-08-10 17:10:00 +00:00
};