Add ssl support

pull/178/head
Sebastian Tanase 3 years ago
parent 4941a7e5b8
commit 2c21b0db36

@ -42,6 +42,12 @@ If you need to apply basic HTTP authentication, you can set user name and passwo
Also, you may have to **set permissions** for your `node_modules` folder. Refer [this](https://docs.npmjs.com/getting-started/fixing-npm-permissions). Also, you may have to **set permissions** for your `node_modules` folder. Refer [this](https://docs.npmjs.com/getting-started/fixing-npm-permissions).
If you need to use SSL, you can pass the private key and certificat through environment variables:
SSL_CERT=/path/to/ssl_certificate SSL_KEY=/path/to/ssl_private_key
Make sure node has the correct **permissions** to read the certificate and the key.
If you need to autosave your changes to crontab directly: If you need to autosave your changes to crontab directly:
crontab-ui --autosave crontab-ui --autosave

@ -5,6 +5,8 @@ var crontab = require("./crontab");
var restore = require("./restore"); var restore = require("./restore");
var moment = require('moment'); var moment = require('moment');
var basicAuth = require('express-basic-auth'); var basicAuth = require('express-basic-auth');
var http = require('http');
var https = require('https');
var path = require('path'); var path = require('path');
var mime = require('mime-types'); var mime = require('mime-types');
@ -32,6 +34,22 @@ if (BASIC_AUTH_USER && BASIC_AUTH_PWD) {
})) }))
} }
// ssl credentials
var credentials = {
key: process.env.SSL_KEY ? fs.readFileSync(process.env.SSL_KEY) : '',
cert: process.env.SSL_CERT ? fs.readFileSync(process.env.SSL_CERT) : '',
}
if (
(credentials.key && !credentials.cert) ||
(credentials.cert && !credentials.key)
) {
console.error('Please provide both SSL_KEY and SSL_CERT');
process.exit(1);
}
var startHttpsServer = credentials.key && credentials.cert;
// include the routes // include the routes
var routes = require("./routes").routes; var routes = require("./routes").routes;
var routes_relative = require("./routes").relative var routes_relative = require("./routes").relative
@ -238,7 +256,10 @@ process.on('SIGTERM', function() {
process.exit(); process.exit();
}) })
app.listen(app.get('port'), app.get('host'), function() { var server = startHttpsServer ?
https.createServer(credentials, app) : http.createServer(app);
server.listen(app.get('port'), app.get('host'), function() {
console.log("Node version:", process.versions.node); console.log("Node version:", process.versions.node);
fs.access(crontab.db_folder, fs.W_OK, function(err) { fs.access(crontab.db_folder, fs.W_OK, function(err) {
if(err){ if(err){
@ -277,5 +298,7 @@ app.listen(app.get('port'), app.get('host'), function() {
crontab.reload_db(); crontab.reload_db();
} }
console.log("Crontab UI is running at http://" + app.get('host') + ":" + app.get('port') + base_url);
var protocol = startHttpsServer ? "https" : "http";
console.log("Crontab UI is running at " + protocol + "://" + app.get('host') + ":" + app.get('port') + base_url);
}); });

Loading…
Cancel
Save