mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-04-23 00:46:16 -04:00

The mechanism used for determining if the application is being served over SSL
is wrapped by the "express-session" library for "express_sid", and manual for
the "language" cookie, but it's very similar in both cases.
The "secure" flag is set if one of these is true:
1. we are directly serving Etherpad over SSL using the native nodejs
functionality, via the "ssl" options in settings.json
2. Etherpad is being served in plaintext by nodejs, but we are using a reverse
proxy for terminating the SSL for us;
In this case, the user has to be instructed to properly set trustProxy: true
in settings.json, and the information wheter the application is over SSL or
not will be extracted from the X-Forwarded-Proto HTTP header.
Please note that this will not be compatible with applications being served over
http and https at the same time.
The change on webaccess.js amends 009b61b338
, which did not work when the SSL
termination was performed by a reverse proxy.
Reference for automatic "express_sid" configuration:
https://github.com/expressjs/session/blob/v1.17.0/README.md#cookiesecure
Closes #3561.
113 lines
3.4 KiB
JavaScript
113 lines
3.4 KiB
JavaScript
var path = require('path');
|
|
var eejs = require('ep_etherpad-lite/node/eejs');
|
|
var toolbar = require("ep_etherpad-lite/node/utils/toolbar");
|
|
var hooks = require('ep_etherpad-lite/static/js/pluginfw/hooks');
|
|
var settings = require('../../utils/Settings');
|
|
|
|
exports.expressCreateServer = function (hook_name, args, cb) {
|
|
// expose current stats
|
|
args.app.get('/stats', function(req, res) {
|
|
res.json(require('ep_etherpad-lite/node/stats').toJSON())
|
|
})
|
|
|
|
//serve index.html under /
|
|
args.app.get('/', function(req, res)
|
|
{
|
|
res.send(eejs.require("ep_etherpad-lite/templates/index.html"));
|
|
});
|
|
|
|
//serve javascript.html
|
|
args.app.get('/javascript', function(req, res)
|
|
{
|
|
res.send(eejs.require("ep_etherpad-lite/templates/javascript.html"));
|
|
});
|
|
|
|
|
|
//serve robots.txt
|
|
args.app.get('/robots.txt', function(req, res)
|
|
{
|
|
var filePath = path.join(settings.root, "src", "static", "skins", settings.skinName, "robots.txt");
|
|
res.sendFile(filePath, function(err)
|
|
{
|
|
//there is no custom favicon, send the default robots.txt which dissallows all
|
|
if(err)
|
|
{
|
|
filePath = path.join(settings.root, "src", "static", "robots.txt");
|
|
res.sendFile(filePath);
|
|
}
|
|
});
|
|
});
|
|
|
|
//serve pad.html under /p
|
|
args.app.get('/p/:pad', function(req, res, next)
|
|
{
|
|
// Set language for pad editor for the first time
|
|
// Or if language cookie doesn't exist
|
|
if (req.cookies.language === undefined)
|
|
{
|
|
cookieOptions = {
|
|
/* req.protocol may be 'https' because either:
|
|
*
|
|
* 1. we are directly serving the nodejs application over SSL, using
|
|
* the "ssl" options in settings.json
|
|
*
|
|
* 2. we are serving the nodejs application in plaintext, but we are
|
|
* using a reverse proxy that terminates SSL for us. In this case,
|
|
* the user has to set trustProxy = true in settings.json, and thus
|
|
* req.protocol will reflect the value of the X-Forwarded-Proto HTTP
|
|
* header
|
|
*
|
|
* Please note that this will not be compatible with applications being
|
|
* served over http and https at the same time.
|
|
*/
|
|
secure: (req.protocol === 'https'),
|
|
}
|
|
res.cookie('language', settings.padOptions.lang, cookieOptions);
|
|
}
|
|
|
|
// The below might break for pads being rewritten
|
|
var isReadOnly = req.url.indexOf("/p/r.") === 0;
|
|
|
|
hooks.callAll("padInitToolbar", {
|
|
toolbar: toolbar,
|
|
isReadOnly: isReadOnly
|
|
});
|
|
|
|
res.send(eejs.require("ep_etherpad-lite/templates/pad.html", {
|
|
req: req,
|
|
toolbar: toolbar,
|
|
isReadOnly: isReadOnly
|
|
}));
|
|
});
|
|
|
|
//serve timeslider.html under /p/$padname/timeslider
|
|
args.app.get('/p/:pad/timeslider', function(req, res, next)
|
|
{
|
|
hooks.callAll("padInitToolbar", {
|
|
toolbar: toolbar
|
|
});
|
|
|
|
res.send(eejs.require("ep_etherpad-lite/templates/timeslider.html", {
|
|
req: req,
|
|
toolbar: toolbar
|
|
}));
|
|
});
|
|
|
|
//serve favicon.ico from all path levels except as a pad name
|
|
args.app.get( /\/favicon.ico$/, function(req, res)
|
|
{
|
|
var filePath = path.join(settings.root, "src", "static", "skins", settings.skinName, "favicon.ico");
|
|
|
|
res.sendFile(filePath, function(err)
|
|
{
|
|
//there is no custom favicon, send the default favicon
|
|
if(err)
|
|
{
|
|
filePath = path.join(settings.root, "src", "static", "favicon.ico");
|
|
res.sendFile(filePath);
|
|
}
|
|
});
|
|
});
|
|
|
|
|
|
}
|