trilium/src/routes/api/options.js

49 lines
1.4 KiB
JavaScript
Raw Normal View History

2017-10-22 09:10:33 +08:00
"use strict";
2017-10-16 07:47:05 +08:00
const sql = require('../../services/sql');
const optionService = require('../../services/options');
const log = require('../../services/log');
// options allowed to be updated directly in options dialog
const ALLOWED_OPTIONS = ['protectedSessionTimeout', 'noteRevisionSnapshotTimeInterval',
2018-12-12 04:53:56 +08:00
'zoomFactor', 'theme', 'syncServerHost', 'syncServerTimeout', 'syncProxy', 'leftPaneMinWidth', 'leftPaneWidthPercent', 'hoistedNoteId'];
2018-04-02 08:33:10 +08:00
async function getOptions() {
2018-09-06 17:54:04 +08:00
return await optionService.getOptionsMap(ALLOWED_OPTIONS);
}
async function updateOption(req) {
2018-04-02 08:33:10 +08:00
const {name, value} = req.params;
if (!update(name, value)) {
return [400, "not allowed option to change"];
}
}
async function updateOptions(req) {
for (const optionName in req.body) {
if (!update(optionName, req.body[optionName])) {
// this should be improved
// it should return 400 instead of current 500, but at least it now rollbacks transaction
throw new Error(`${optionName} is not allowed to change`);
}
}
}
async function update(name, value) {
2018-04-02 08:33:10 +08:00
if (!ALLOWED_OPTIONS.includes(name)) {
return false;
}
log.info(`Updating option ${name} to ${value}`);
await optionService.setOption(name, value);
return true;
}
module.exports = {
2018-04-02 08:33:10 +08:00
getOptions,
updateOption,
updateOptions
};