2019-11-01 10:12:40 +00:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var pkg = require("../../package.json");
|
|
|
|
|
|
|
|
// The WRONG way:
|
|
|
|
//var http = require('http');
|
|
|
|
//var httpServer = https.createSecureServer(redirectToHttps);
|
|
|
|
//
|
|
|
|
// Why is that wrong?
|
|
|
|
// Greenlock needs to change some low-level http and https options.
|
|
|
|
// Use glx.httpServer(redirectToHttps) instead.
|
|
|
|
|
|
|
|
function httpsWorker(glx) {
|
2019-11-01 21:14:07 +00:00
|
|
|
//
|
|
|
|
// HTTP can only be used for ACME HTTP-01 Challenges
|
|
|
|
// (and it is not required for DNS-01 challenges)
|
|
|
|
//
|
2019-11-01 10:12:40 +00:00
|
|
|
|
2019-11-01 21:14:07 +00:00
|
|
|
// Get the raw http server:
|
|
|
|
var httpServer = glx.httpServer(function(req, res) {
|
|
|
|
res.statusCode = 301;
|
|
|
|
res.setHeader("Location", "https://" + req.headers.host + req.path);
|
|
|
|
res.end("Insecure connections are not allowed. Redirecting...");
|
|
|
|
});
|
2019-11-01 10:12:40 +00:00
|
|
|
|
2019-11-01 21:14:07 +00:00
|
|
|
httpServer.listen(80, "0.0.0.0", function() {
|
|
|
|
console.info("Listening on ", httpServer.address());
|
|
|
|
});
|
2019-11-01 10:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//require("greenlock-express")
|
|
|
|
require("../../")
|
2019-11-01 21:14:07 +00:00
|
|
|
.init(function getConfig() {
|
|
|
|
// Greenlock Config
|
2019-11-01 10:12:40 +00:00
|
|
|
|
2019-11-01 21:14:07 +00:00
|
|
|
return {
|
|
|
|
package: { name: "plain-http-example", version: pkg.version },
|
|
|
|
maintainerEmail: "jon@example.com",
|
|
|
|
cluster: false
|
|
|
|
};
|
|
|
|
})
|
|
|
|
.serve(httpsWorker);
|