2012-02-25 13:38:09 +01:00
|
|
|
var express = require('express');
|
|
|
|
var log4js = require('log4js');
|
|
|
|
var httpLogger = log4js.getLogger("http");
|
2012-02-25 17:23:44 +01:00
|
|
|
var settings = require('../../utils/Settings');
|
2012-02-25 13:38:09 +01:00
|
|
|
|
|
|
|
|
|
|
|
//checks for basic http auth
|
|
|
|
exports.basicAuth = function (req, res, next) {
|
2012-04-03 14:17:19 +02:00
|
|
|
|
|
|
|
// When handling HTTP-Auth, an undefined password will lead to no authorization at all
|
|
|
|
var pass = settings.httpAuth || '';
|
|
|
|
|
2012-04-02 18:45:37 +02:00
|
|
|
if (req.path.indexOf('/admin') == 0) {
|
|
|
|
var pass = settings.adminHttpAuth;
|
2012-04-03 14:17:19 +02:00
|
|
|
|
2012-04-02 18:45:37 +02:00
|
|
|
}
|
2012-04-03 14:17:19 +02:00
|
|
|
|
|
|
|
// Just pass if password is an empty string
|
|
|
|
if (pass === '') {
|
2012-04-02 18:45:37 +02:00
|
|
|
return next();
|
|
|
|
}
|
2012-04-03 14:17:19 +02:00
|
|
|
|
|
|
|
|
|
|
|
// If a password has been set and auth headers are present...
|
|
|
|
if (pass && req.headers.authorization && req.headers.authorization.search('Basic ') === 0) {
|
|
|
|
// ...check login and password
|
|
|
|
if (new Buffer(req.headers.authorization.split(' ')[1], 'base64').toString() === pass) {
|
2012-04-02 18:45:37 +02:00
|
|
|
return next();
|
2012-02-25 13:38:09 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-04-03 14:17:19 +02:00
|
|
|
// Otherwise return Auth required Headers, delayed for 1 second, if auth failed.
|
2012-02-25 13:38:09 +01:00
|
|
|
res.header('WWW-Authenticate', 'Basic realm="Protected Area"');
|
|
|
|
if (req.headers.authorization) {
|
|
|
|
setTimeout(function () {
|
|
|
|
res.send('Authentication required', 401);
|
|
|
|
}, 1000);
|
|
|
|
} else {
|
|
|
|
res.send('Authentication required', 401);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.expressConfigure = function (hook_name, args, cb) {
|
2012-04-02 18:45:37 +02:00
|
|
|
args.app.use(exports.basicAuth);
|
2012-02-25 13:38:09 +01:00
|
|
|
|
|
|
|
// If the log level specified in the config file is WARN or ERROR the application server never starts listening to requests as reported in issue #158.
|
|
|
|
// Not installing the log4js connect logger when the log level has a higher severity than INFO since it would not log at that level anyway.
|
|
|
|
if (!(settings.loglevel === "WARN" || settings.loglevel == "ERROR"))
|
|
|
|
args.app.use(log4js.connectLogger(httpLogger, { level: log4js.levels.INFO, format: ':status, :method :url'}));
|
|
|
|
args.app.use(express.cookieParser());
|
|
|
|
}
|