2017-11-02 20:48:02 -04:00
|
|
|
const sql = require('./sql');
|
|
|
|
const utils = require('./utils');
|
2018-04-02 20:46:46 -04:00
|
|
|
const dateUtils = require('./date_utils');
|
2018-04-01 21:27:46 -04:00
|
|
|
const syncTableService = require('./sync_table');
|
|
|
|
const appInfo = require('./app_info');
|
2017-11-02 20:48:02 -04:00
|
|
|
|
2018-01-28 19:30:14 -05:00
|
|
|
async function getOption(name) {
|
2018-04-02 22:53:01 -04:00
|
|
|
const row = await await sql.getRowOrNull("SELECT value FROM options WHERE name = ?", [name]);
|
2017-11-02 20:48:02 -04:00
|
|
|
|
|
|
|
if (!row) {
|
2018-01-28 19:30:14 -05:00
|
|
|
throw new Error("Option " + name + " doesn't exist");
|
2017-11-02 20:48:02 -04:00
|
|
|
}
|
|
|
|
|
2018-03-31 23:11:43 -04:00
|
|
|
return row.value;
|
2017-11-02 20:48:02 -04:00
|
|
|
}
|
|
|
|
|
2018-03-30 19:41:54 -04:00
|
|
|
async function setOption(name, value) {
|
2018-03-30 13:56:46 -04:00
|
|
|
const opt = await sql.getRow("SELECT * FROM options WHERE name = ?", [name]);
|
2018-01-11 22:45:25 -05:00
|
|
|
|
|
|
|
if (!opt) {
|
2018-01-28 19:30:14 -05:00
|
|
|
throw new Error(`Option ${name} doesn't exist`);
|
2018-01-11 22:45:25 -05:00
|
|
|
}
|
|
|
|
|
2018-01-28 19:30:14 -05:00
|
|
|
if (opt.isSynced) {
|
2018-04-01 21:27:46 -04:00
|
|
|
await syncTableService.addOptionsSync(name);
|
2017-11-02 20:48:02 -04:00
|
|
|
}
|
|
|
|
|
2018-03-30 13:56:46 -04:00
|
|
|
await sql.execute("UPDATE options SET value = ?, dateModified = ? WHERE name = ?",
|
2018-04-02 20:46:46 -04:00
|
|
|
[value, dateUtils.nowDate(), name]);
|
2018-01-11 22:45:25 -05:00
|
|
|
}
|
|
|
|
|
2018-03-30 19:41:54 -04:00
|
|
|
async function createOption(name, value, isSynced) {
|
2018-01-11 22:45:25 -05:00
|
|
|
await sql.insert("options", {
|
2018-01-28 19:30:14 -05:00
|
|
|
name: name,
|
|
|
|
value: value,
|
|
|
|
isSynced: isSynced,
|
2018-04-02 20:46:46 -04:00
|
|
|
dateModified: dateUtils.nowDate()
|
2017-12-03 22:29:23 -05:00
|
|
|
});
|
2018-01-11 22:45:25 -05:00
|
|
|
|
|
|
|
if (isSynced) {
|
2018-04-01 21:27:46 -04:00
|
|
|
await syncTableService.addOptionsSync(name);
|
2018-01-11 22:45:25 -05:00
|
|
|
}
|
2017-11-02 20:48:02 -04:00
|
|
|
}
|
|
|
|
|
2017-12-06 23:15:53 -05:00
|
|
|
async function initOptions(startNotePath) {
|
2018-04-02 21:47:46 -04:00
|
|
|
await createOption('documentId', utils.randomSecureToken(16), false);
|
|
|
|
await createOption('documentSecret', utils.randomSecureToken(16), false);
|
2018-01-11 22:45:25 -05:00
|
|
|
|
|
|
|
await createOption('username', '', true);
|
2018-04-02 21:47:46 -04:00
|
|
|
await createOption('passwordVerificationHash', '', true);
|
|
|
|
await createOption('passwordVerificationSalt', '', true);
|
|
|
|
await createOption('passwordDerivedKeySalt', '', true);
|
|
|
|
await createOption('encryptedDataKey', '', true);
|
2018-04-02 22:33:54 -04:00
|
|
|
await createOption('encryptedDataKeyIv', '', true);
|
2018-01-11 22:45:25 -05:00
|
|
|
|
2018-04-02 21:47:46 -04:00
|
|
|
await createOption('startNotePath', startNotePath, false);
|
|
|
|
await createOption('protectedSessionTimeout', 600, true);
|
|
|
|
await createOption('noteRevisionSnapshotTimeInterval', 600, true);
|
|
|
|
await createOption('lastBackupDate', dateUtils.nowDate(), false);
|
|
|
|
await createOption('dbVersion', appInfo.dbVersion, false);
|
2018-01-11 22:45:25 -05:00
|
|
|
|
2018-04-02 21:47:46 -04:00
|
|
|
await createOption('lastSyncedPull', appInfo.dbVersion, false);
|
|
|
|
await createOption('lastSyncedPush', 0, false);
|
2017-12-03 22:29:23 -05:00
|
|
|
}
|
2017-11-16 21:50:00 -05:00
|
|
|
|
2017-11-02 20:48:02 -04:00
|
|
|
module.exports = {
|
|
|
|
getOption,
|
|
|
|
setOption,
|
2018-04-02 22:53:01 -04:00
|
|
|
initOptions
|
2017-11-02 20:48:02 -04:00
|
|
|
};
|