|
20 | 20 | */ |
21 | 21 |
|
22 | 22 | /*unittests: Preferences Manager */ |
| 23 | +/*global fs*/ |
23 | 24 |
|
24 | 25 | /** |
25 | 26 | * StateManager |
|
28 | 29 | define(function (require, exports, module) { |
29 | 30 | const _ = require("thirdparty/lodash"), |
30 | 31 | EventDispatcher = require("utils/EventDispatcher"), |
| 32 | + Metrics = require("utils/Metrics"), |
31 | 33 | ProjectManager = require("project/ProjectManager"); |
32 | 34 |
|
| 35 | + const LEGACY_STATE_MANAGER_MIGRATED = "ph_state_manager_migrated"; |
| 36 | + const LEGACY_STATE_FILE_PATH = "/fs/app/state.json"; |
| 37 | + |
33 | 38 | const PROJECT_CONTEXT = "project"; |
34 | 39 | const GLOBAL_CONTEXT = "global"; |
35 | 40 | const PROJECT_THEN_GLOBAL_CONTEXT = "any"; |
@@ -235,6 +240,68 @@ define(function (require, exports, module) { |
235 | 240 | return createExtensionStateManager(prefix); |
236 | 241 | } |
237 | 242 |
|
| 243 | + /** |
| 244 | + * We used file based state.json in the earlier state manager impl. no we moved to phstore. So we have to move |
| 245 | + * earlier users to phstore to prevent losing their files. This code can be deleted anytime after 4 months |
| 246 | + * from this commit. |
| 247 | + * @private |
| 248 | + */ |
| 249 | + function _migrateLegacyStateFile() { |
| 250 | + if(Phoenix.firstBoot){ |
| 251 | + // nothing to migrate, fresh install |
| 252 | + setVal(LEGACY_STATE_MANAGER_MIGRATED, true); |
| 253 | + return new $.Deferred().resolve().promise(); |
| 254 | + } |
| 255 | + if(getVal(LEGACY_STATE_MANAGER_MIGRATED)){ |
| 256 | + return new $.Deferred().resolve().promise(); |
| 257 | + } |
| 258 | + const _migrated = new $.Deferred(); |
| 259 | + console.log("Migrating legacy state file", LEGACY_STATE_FILE_PATH); |
| 260 | + fs.readFile(LEGACY_STATE_FILE_PATH, "utf8", function (err, data) { |
| 261 | + setVal(LEGACY_STATE_MANAGER_MIGRATED, true); |
| 262 | + if (err) { |
| 263 | + // if error, ignore and continue. state file not found(unlikely to be here) |
| 264 | + _migrated.resolve(); |
| 265 | + return; |
| 266 | + } |
| 267 | + try{ |
| 268 | + const keysToMigrate = [ |
| 269 | + "afterFirstLaunch", |
| 270 | + "sidebar", |
| 271 | + "workingSetSortMethod", |
| 272 | + "healthDataUsage", |
| 273 | + "main-toolbar", |
| 274 | + "recentProjects", |
| 275 | + "healthDataNotificationShown", |
| 276 | + "searchHistory", |
| 277 | + "problems-panel" |
| 278 | + ]; |
| 279 | + const oldState = JSON.parse(data); |
| 280 | + for(let key of keysToMigrate) { |
| 281 | + if(oldState[key]){ |
| 282 | + console.log("Migrated Legacy state: ", key, oldState[key]); |
| 283 | + setVal(key, oldState[key]); |
| 284 | + } |
| 285 | + } |
| 286 | + fs.unlink(LEGACY_STATE_FILE_PATH, (unlinkErr)=>{ |
| 287 | + if(unlinkErr){ |
| 288 | + console.error(`Error deleting legacy state file ${LEGACY_STATE_FILE_PATH}`, unlinkErr); |
| 289 | + } |
| 290 | + }); |
| 291 | + } catch (e) { |
| 292 | + console.error("Error migrating legacy state file", LEGACY_STATE_FILE_PATH); |
| 293 | + } |
| 294 | + Metrics.countEvent(Metrics.EVENT_TYPE.PLATFORM, "legacyState", "migrated"); |
| 295 | + _migrated.resolve(); |
| 296 | + console.log("Legacy state migration completed"); |
| 297 | + }); |
| 298 | + return _migrated.promise(); |
| 299 | + } |
| 300 | + |
| 301 | + // private API |
| 302 | + exports._migrateLegacyStateFile = _migrateLegacyStateFile; |
| 303 | + |
| 304 | + // public api |
238 | 305 | exports.get = getVal; |
239 | 306 | exports.set = setVal; |
240 | 307 | exports.definePreference = definePreferenceInternal; |
|
0 commit comments