From 8d68c4f54d7f087a837090baa3564973e4c88de1 Mon Sep 17 00:00:00 2001 From: Ivan Vershigora Date: Mon, 5 Feb 2024 17:18:58 +0000 Subject: [PATCH] fix: migration --- src/store/index.ts | 2 +- src/store/migrations/index.ts | 42 +++++++++++++++++++++++++++-------- 2 files changed, 34 insertions(+), 10 deletions(-) diff --git a/src/store/index.ts b/src/store/index.ts index 37a7673b0..524975d9b 100644 --- a/src/store/index.ts +++ b/src/store/index.ts @@ -40,7 +40,7 @@ const persistConfig = { key: 'root', storage: mmkvStorage, // increase version after store shape changes - version: 34, + version: 35, stateReconciler: autoMergeLevel2, blacklist: ['receive', 'ui'], migrate: createMigrate(migrations, { debug: __ENABLE_MIGRATION_DEBUG__ }), diff --git a/src/store/migrations/index.ts b/src/store/migrations/index.ts index 86515cd45..41008a415 100644 --- a/src/store/migrations/index.ts +++ b/src/store/migrations/index.ts @@ -18,7 +18,7 @@ import { import { initialActivityState } from '../slices/activity'; import { initialChecksState } from '../slices/checks'; import { initialWidgetsState } from '../slices/widgets'; -import cloneDeep from 'lodash/cloneDeep'; +import { EBackupCategories } from '../utils/backup'; const migrations = { 0: (state): PersistedState => { @@ -444,18 +444,42 @@ const migrations = { }; } - // force backup - const backup = cloneDeep(initialBackupState); - for (const key in initialBackupState) { - backup[key].synced = backup[key].required - 10; + const now = Date.now(); + const old = state.backup; + const backup = {}; + + for (const [oldKey, newKey] of [ + ['remoteBlocktankBackup', EBackupCategories.blocktank], + ['remoteLdkActivityBackup', EBackupCategories.ldkActivity], + ['remoteMetadataBackup', EBackupCategories.metadata], + ['remoteSettingsBackup', EBackupCategories.settings], + ['remoteSlashtagsBackup', EBackupCategories.slashtags], + ['remoteWidgetsBackup', EBackupCategories.widgets], + ]) { + const oldLastSync = old[`${oldKey}LastSync`]; + const oldSynced = old[`${oldKey}Synced`]; + const oldSyncRequired = old[`${oldKey}SyncRequired`]; + + if (oldSynced === false && !oldSyncRequired) { + // backup not required + backup[newKey] = { + required: now - 1000, + synced: now, + running: false, + }; + } else { + // force backup + backup[newKey] = { + required: now, + synced: oldLastSync ?? now - 1000, + running: false, + }; + } } return { ...state, - backup: { - ...backup, - ...state.backup, - }, + backup, lightning: { ...state.lightning, nodes: newNodes,