2012-07-03 23:30:40 +02:00
|
|
|
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');
|
2012-07-08 11:37:24 +02:00
|
|
|
var npm = require("npm/lib/npm.js");
|
2012-07-03 23:30:40 +02:00
|
|
|
var _ = require("underscore");
|
|
|
|
|
|
|
|
var server;
|
|
|
|
var serverName;
|
|
|
|
|
|
|
|
exports.createServer = function () {
|
|
|
|
//try to get the git version
|
|
|
|
var version = "";
|
|
|
|
try
|
|
|
|
{
|
|
|
|
var rootPath = path.resolve(npm.dir, '..');
|
|
|
|
var ref = fs.readFileSync(rootPath + "/.git/HEAD", "utf-8");
|
|
|
|
var refPath = rootPath + "/.git/" + ref.substring(5, ref.indexOf("\n"));
|
|
|
|
version = fs.readFileSync(refPath, "utf-8");
|
|
|
|
version = version.substring(0, 7);
|
2013-08-23 00:32:25 +02:00
|
|
|
console.log("Your Etherpad git version is " + version);
|
2012-07-03 23:30:40 +02:00
|
|
|
}
|
|
|
|
catch(e)
|
|
|
|
{
|
|
|
|
console.warn("Can't get git version for server header\n" + e.message)
|
|
|
|
}
|
2012-11-22 01:12:30 +01:00
|
|
|
console.log("Report bugs at https://github.com/ether/etherpad-lite/issues")
|
2012-07-03 23:30:40 +02:00
|
|
|
|
2013-08-23 00:32:25 +02:00
|
|
|
serverName = "Etherpad " + version + " (http://etherpad.org)";
|
2012-07-03 23:30:40 +02:00
|
|
|
|
|
|
|
exports.restartServer();
|
|
|
|
|
2013-08-23 00:32:25 +02:00
|
|
|
console.log("You can access your Etherpad instance at http://" + settings.ip + ":" + settings.port + "/");
|
2012-07-03 23:30:40 +02:00
|
|
|
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 () {
|
2012-09-12 20:38:53 +02:00
|
|
|
|
2012-07-03 23:30:40 +02:00
|
|
|
if (server) {
|
|
|
|
console.log("Restarting express server");
|
|
|
|
server.close();
|
|
|
|
}
|
|
|
|
|
2012-09-21 17:12:22 +02:00
|
|
|
var app = express(); // New syntax for express v3
|
2012-11-22 10:12:58 +01:00
|
|
|
|
|
|
|
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 );
|
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
2012-07-03 23:30:40 +02:00
|
|
|
|
2012-09-21 17:12:22 +02:00
|
|
|
app.use(function (req, res, next) {
|
2014-06-17 13:21:38 +02:00
|
|
|
// res.header("X-Frame-Options", "deny"); // breaks embedded pads
|
2013-03-14 23:03:20 +01:00
|
|
|
if(settings.ssl){ // if we use SSL
|
2014-06-17 13:21:38 +02:00
|
|
|
res.header("Strict-Transport-Security", "max-age=31536000; includeSubDomains");
|
2013-03-14 23:03:20 +01:00
|
|
|
}
|
|
|
|
|
2012-07-03 23:30:40 +02:00
|
|
|
res.header("Server", serverName);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
|
2013-04-24 12:19:41 +02:00
|
|
|
if(settings.trustProxy){
|
|
|
|
app.enable('trust proxy');
|
|
|
|
}
|
|
|
|
|
2012-09-21 17:12:22 +02:00
|
|
|
app.configure(function() {
|
|
|
|
hooks.callAll("expressConfigure", {"app": app});
|
2012-07-03 23:30:40 +02:00
|
|
|
});
|
2012-09-21 17:12:22 +02:00
|
|
|
hooks.callAll("expressCreateServer", {"app": app, "server": server});
|
2012-07-03 23:30:40 +02:00
|
|
|
|
|
|
|
server.listen(settings.port, settings.ip);
|
2012-09-12 20:38:53 +02:00
|
|
|
}
|