diff --git a/src/modules/app/services/DefaultSettings.js b/src/modules/app/services/DefaultSettings.js index 364a140765..be42905f07 100644 --- a/src/modules/app/services/DefaultSettings.js +++ b/src/modules/app/services/DefaultSettings.js @@ -193,6 +193,10 @@ return Object.prototype.hasOwnProperty.call(this.commonDefaults, start); } + getDefaultSettings() { + return this.defaults; + } + } return { diff --git a/src/modules/app/services/StorageExporter.js b/src/modules/app/services/StorageExporter.js index 47d78d0047..f70fb4e00a 100644 --- a/src/modules/app/services/StorageExporter.js +++ b/src/modules/app/services/StorageExporter.js @@ -1,12 +1,15 @@ (function () { 'use strict'; + const { pickBy, hasIn } = require('ramda'); + class StorageExporter { static $inject = [ '$log', 'storage', - 'multiAccount' + 'multiAccount', + 'defaultSettings' ]; /** @@ -14,10 +17,11 @@ * @param {app.utils.Storage} storage * @param {app.MultiAccount} multiAccount */ - constructor($log, storage, multiAccount) { + constructor($log, storage, multiAccount, defaultSettings) { this.$log = $log; this.storage = storage; this.multiAccount = multiAccount; + this.defaultSettings = defaultSettings; } /** @@ -49,6 +53,13 @@ } } + const predicate = (value, key) => hasIn(key, this.defaultSettings.create().getDefaultSettings()); + + for (const user of Object.values(storageData.userList)) { + delete user.settings.encryptionRounds; + user.settings = pickBy(predicate)(user.settings); + } + return this.multiAccount.export(privateKeyFrom, publicKeyTo, storageData); }