mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-20 06:29:53 +01:00
Make APIKEY und SESSIONKEY file customizable
Running multiple instances sometimes requires different api- and session-keys for security reasons.
This commit is contained in:
parent
f6456c0aa7
commit
4cce3bcbed
3 changed files with 17 additions and 4 deletions
|
@ -24,17 +24,19 @@ var fs = require("fs");
|
||||||
var api = require("../db/API");
|
var api = require("../db/API");
|
||||||
var padManager = require("../db/PadManager");
|
var padManager = require("../db/PadManager");
|
||||||
var randomString = require("../utils/randomstring");
|
var randomString = require("../utils/randomstring");
|
||||||
|
var argv = require('../utils/Cli').argv;
|
||||||
|
|
||||||
//ensure we have an apikey
|
//ensure we have an apikey
|
||||||
var apikey = null;
|
var apikey = null;
|
||||||
|
var apikeyFilename = argv.apikey || "./APIKEY.txt";
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
apikey = fs.readFileSync("./APIKEY.txt","utf8");
|
apikey = fs.readFileSync(apikeyFilename,"utf8");
|
||||||
}
|
}
|
||||||
catch(e)
|
catch(e)
|
||||||
{
|
{
|
||||||
apikey = randomString(32);
|
apikey = randomString(32);
|
||||||
fs.writeFileSync("./APIKEY.txt",apikey,"utf8");
|
fs.writeFileSync(apikeyFilename,apikey,"utf8");
|
||||||
}
|
}
|
||||||
|
|
||||||
//a list of all functions
|
//a list of all functions
|
||||||
|
|
|
@ -39,5 +39,15 @@ for ( var i = 0; i < argv.length; i++ ) {
|
||||||
exports.argv.credentials = arg;
|
exports.argv.credentials = arg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Override location of settings.json file
|
||||||
|
if ( prevArg == '--sessionkey' || prevArg == '-k' ) {
|
||||||
|
exports.argv.sessionkey = arg;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Override location of settings.json file
|
||||||
|
if ( prevArg == '--apikey' || prevArg == '-k' ) {
|
||||||
|
exports.argv.apikey = arg;
|
||||||
|
}
|
||||||
|
|
||||||
prevArg = arg;
|
prevArg = arg;
|
||||||
}
|
}
|
||||||
|
|
|
@ -449,11 +449,12 @@ exports.reloadSettings = function reloadSettings() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!exports.sessionKey) {
|
if (!exports.sessionKey) {
|
||||||
|
var sessionkeyFilename = argv.sessionkey || "./SESSIONKEY.txt";
|
||||||
try {
|
try {
|
||||||
exports.sessionKey = fs.readFileSync("./SESSIONKEY.txt","utf8");
|
exports.sessionKey = fs.readFileSync(sessionkeyFilename,"utf8");
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
exports.sessionKey = randomString(32);
|
exports.sessionKey = randomString(32);
|
||||||
fs.writeFileSync("./SESSIONKEY.txt",exports.sessionKey,"utf8");
|
fs.writeFileSync(sessionkeyFilename,exports.sessionKey,"utf8");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
console.warn("Declaring the sessionKey in the settings.json is deprecated. This value is auto-generated now. Please remove the setting from the file.");
|
console.warn("Declaring the sessionKey in the settings.json is deprecated. This value is auto-generated now. Please remove the setting from the file.");
|
||||||
|
|
Loading…
Reference in a new issue