mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-02-08 11:12:01 +01:00
402e53d88e
Express 4 support
77 lines
2.2 KiB
JavaScript
77 lines
2.2 KiB
JavaScript
var hooks = require("ep_etherpad-lite/static/js/pluginfw/hooks");
|
|
var express = require('express');
|
|
var settings = require('../utils/Settings');
|
|
var fs = require('fs');
|
|
var path = require('path');
|
|
var npm = require("npm/lib/npm.js");
|
|
var _ = require("underscore");
|
|
|
|
var server;
|
|
var serverName;
|
|
|
|
exports.createServer = function () {
|
|
console.log("Report bugs at https://github.com/ether/etherpad-lite/issues")
|
|
|
|
serverName = "Etherpad " + settings.getGitCommit() + " (http://etherpad.org)";
|
|
|
|
console.log("Your Etherpad version is " + settings.getEpVersion() + " (" + settings.getGitCommit() + ")");
|
|
|
|
exports.restartServer();
|
|
|
|
console.log("You can access your Etherpad instance at http://" + settings.ip + ":" + settings.port + "/");
|
|
if(!_.isEmpty(settings.users)){
|
|
console.log("The plugin admin page is at http://" + settings.ip + ":" + settings.port + "/admin/plugins");
|
|
}
|
|
else{
|
|
console.warn("Admin username and password not set in settings.json. To access admin please uncomment and edit 'users' in settings.json");
|
|
}
|
|
}
|
|
|
|
exports.restartServer = function () {
|
|
|
|
if (server) {
|
|
console.log("Restarting express server");
|
|
server.close();
|
|
}
|
|
|
|
var app = express(); // New syntax for express v3
|
|
|
|
if (settings.ssl) {
|
|
|
|
console.log( "SSL -- enabled");
|
|
console.log( "SSL -- server key file: " + settings.ssl.key );
|
|
console.log( "SSL -- Certificate Authority's certificate file: " + settings.ssl.cert );
|
|
|
|
var options = {
|
|
key: fs.readFileSync( settings.ssl.key ),
|
|
cert: fs.readFileSync( settings.ssl.cert )
|
|
};
|
|
|
|
var https = require('https');
|
|
server = https.createServer(options, app);
|
|
|
|
} else {
|
|
|
|
var http = require('http');
|
|
server = http.createServer(app);
|
|
}
|
|
|
|
app.use(function (req, res, next) {
|
|
// res.header("X-Frame-Options", "deny"); // breaks embedded pads
|
|
if(settings.ssl){ // if we use SSL
|
|
res.header("Strict-Transport-Security", "max-age=31536000; includeSubDomains");
|
|
}
|
|
|
|
res.header("Server", serverName);
|
|
next();
|
|
});
|
|
|
|
if(settings.trustProxy){
|
|
app.enable('trust proxy');
|
|
}
|
|
|
|
hooks.callAll("expressConfigure", {"app": app});
|
|
hooks.callAll("expressCreateServer", {"app": app, "server": server});
|
|
|
|
server.listen(settings.port, settings.ip);
|
|
}
|