2017-10-21 21:10:33 -04:00
|
|
|
"use strict";
|
|
|
|
|
2018-04-01 21:27:46 -04:00
|
|
|
const optionService = require('../../services/options');
|
2018-06-02 13:02:20 -04:00
|
|
|
const log = require('../../services/log');
|
2019-01-27 21:18:11 +01:00
|
|
|
const attributes = require('../../services/attributes');
|
2017-10-14 23:31:44 -04:00
|
|
|
|
2018-04-01 17:41:28 -04:00
|
|
|
// options allowed to be updated directly in options dialog
|
2019-11-19 20:53:04 +01:00
|
|
|
const ALLOWED_OPTIONS = new Set([
|
2020-01-03 22:32:49 +01:00
|
|
|
'eraseNotesAfterTimeInSeconds',
|
2019-05-10 21:43:40 +02:00
|
|
|
'protectedSessionTimeout',
|
|
|
|
'noteRevisionSnapshotTimeInterval',
|
|
|
|
'zoomFactor',
|
|
|
|
'theme',
|
|
|
|
'syncServerHost',
|
|
|
|
'syncServerTimeout',
|
|
|
|
'syncProxy',
|
|
|
|
'hoistedNoteId',
|
|
|
|
'mainFontSize',
|
|
|
|
'treeFontSize',
|
|
|
|
'detailFontSize',
|
2019-05-12 21:45:30 +02:00
|
|
|
'openTabs',
|
2019-08-22 20:58:43 +02:00
|
|
|
'noteInfoWidget',
|
|
|
|
'attributesWidget',
|
|
|
|
'linkMapWidget',
|
|
|
|
'noteRevisionsWidget',
|
2019-08-29 21:08:53 +02:00
|
|
|
'whatLinksHereWidget',
|
2019-09-01 08:58:13 +02:00
|
|
|
'similarNotesWidget',
|
2019-09-07 10:11:59 +02:00
|
|
|
'editedNotesWidget',
|
2019-09-08 13:08:01 +02:00
|
|
|
'calendarWidget',
|
2019-10-06 21:35:26 +02:00
|
|
|
'codeNotesMimeTypes',
|
|
|
|
'spellCheckEnabled',
|
2019-11-03 17:59:11 +01:00
|
|
|
'spellCheckLanguageCode',
|
|
|
|
'imageMaxWidthHeight',
|
2019-12-23 20:34:29 +01:00
|
|
|
'imageJpegQuality',
|
|
|
|
'leftPaneWidth',
|
|
|
|
'rightPaneWidth',
|
2020-02-04 20:42:40 +01:00
|
|
|
'leftPaneVisible',
|
2019-12-24 12:10:32 +01:00
|
|
|
'rightPaneVisible',
|
|
|
|
'nativeTitleBarVisible'
|
2019-11-19 20:53:04 +01:00
|
|
|
]);
|
2017-10-14 23:31:44 -04:00
|
|
|
|
2018-04-01 20:33:10 -04:00
|
|
|
async function getOptions() {
|
2019-11-19 20:53:04 +01:00
|
|
|
const optionMap = await optionService.getOptionsMap();
|
|
|
|
const resultMap = {};
|
|
|
|
|
|
|
|
for (const optionName in optionMap) {
|
|
|
|
if (isAllowed(optionName)) {
|
|
|
|
resultMap[optionName] = optionMap[optionName];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return resultMap;
|
2018-03-30 13:56:46 -04:00
|
|
|
}
|
2017-10-14 23:31:44 -04:00
|
|
|
|
2018-04-01 17:41:28 -04:00
|
|
|
async function updateOption(req) {
|
2018-04-01 20:33:10 -04:00
|
|
|
const {name, value} = req.params;
|
2017-10-14 23:31:44 -04:00
|
|
|
|
2019-11-19 20:53:04 +01:00
|
|
|
if (!await update(name, value)) {
|
2018-07-22 22:21:16 +02:00
|
|
|
return [400, "not allowed option to change"];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function updateOptions(req) {
|
|
|
|
for (const optionName in req.body) {
|
2019-11-19 20:53:04 +01:00
|
|
|
if (!await update(optionName, req.body[optionName])) {
|
2018-07-22 22:21:16 +02:00
|
|
|
// 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) {
|
2019-11-19 20:53:04 +01:00
|
|
|
if (!isAllowed(name)) {
|
2018-07-22 22:21:16 +02:00
|
|
|
return false;
|
2017-10-14 23:31:44 -04:00
|
|
|
}
|
|
|
|
|
2019-11-05 20:59:20 +01:00
|
|
|
if (name !== 'openTabs') {
|
|
|
|
log.info(`Updating option ${name} to ${value}`);
|
|
|
|
}
|
2018-06-02 13:02:20 -04:00
|
|
|
|
2018-04-01 21:27:46 -04:00
|
|
|
await optionService.setOption(name, value);
|
2018-07-22 22:21:16 +02:00
|
|
|
|
|
|
|
return true;
|
2018-03-30 13:56:46 -04:00
|
|
|
}
|
|
|
|
|
2019-01-27 21:18:11 +01:00
|
|
|
async function getUserThemes() {
|
2019-02-03 00:12:57 +01:00
|
|
|
const notes = await attributes.getNotesWithLabel('appTheme');
|
|
|
|
|
|
|
|
const ret = [];
|
|
|
|
|
|
|
|
for (const note of notes) {
|
2019-12-01 11:10:04 +01:00
|
|
|
let value = await note.getOwnedLabelValue('appTheme');
|
2019-02-03 00:12:57 +01:00
|
|
|
|
2019-02-03 15:35:37 +01:00
|
|
|
if (!value) {
|
2019-02-03 00:12:57 +01:00
|
|
|
value = note.title.toLowerCase().replace(/[^a-z0-9]/gi, '-');
|
|
|
|
}
|
|
|
|
|
|
|
|
ret.push({
|
|
|
|
val: value,
|
|
|
|
title: note.title,
|
|
|
|
noteId: note.noteId
|
2019-01-27 21:18:11 +01:00
|
|
|
});
|
2019-02-03 00:12:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
2019-01-27 21:18:11 +01:00
|
|
|
}
|
|
|
|
|
2019-11-19 20:53:04 +01:00
|
|
|
function isAllowed(name) {
|
|
|
|
return ALLOWED_OPTIONS.has(name) || name.startsWith("keyboardShortcuts");
|
|
|
|
}
|
|
|
|
|
2018-03-30 13:56:46 -04:00
|
|
|
module.exports = {
|
2018-04-01 20:33:10 -04:00
|
|
|
getOptions,
|
2018-07-22 22:21:16 +02:00
|
|
|
updateOption,
|
2019-01-27 21:18:11 +01:00
|
|
|
updateOptions,
|
|
|
|
getUserThemes
|
2018-03-30 13:56:46 -04:00
|
|
|
};
|