From e72ae00bc5590c54ef481f8e84509e31cf04f7ef Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Fri, 31 Mar 2023 10:29:58 +0300 Subject: [PATCH 1/2] UserRemovingDuringSyncError error class --- workers/loc.api/errors/index.js | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/workers/loc.api/errors/index.js b/workers/loc.api/errors/index.js index c28a293d1..8ce5d10ae 100644 --- a/workers/loc.api/errors/index.js +++ b/workers/loc.api/errors/index.js @@ -125,10 +125,18 @@ class UserUpdatingError extends AuthError { } class UserRemovingError extends AuthError { - constructor (message = 'ERR_USER_REMOVE_HAS_BEEN_FAILED') { + constructor (message = 'ERR_USER_REMOVAL_HAS_BEEN_FAILED') { super(message) - this.statusMessage = 'User remove has been failed' + this.statusMessage = 'User removal has been failed' + } +} + +class UserRemovingDuringSyncError extends UserRemovingError { + constructor (message = 'USER_REMOVAL_HAS_BEEN_DISALLOWED_DURING_SYNC') { + super(message) + + this.statusMessage = 'User removal has been disallowed during sync' } } @@ -250,6 +258,7 @@ module.exports = { SubAccountUpdatingError, UserUpdatingError, UserRemovingError, + UserRemovingDuringSyncError, UserWasPreviouslyStoredInDbError, SubAccountLedgersBalancesRecalcError, DatePropNameError, From 89e7847e67344065c7ed3761393c006cf89baf45 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Fri, 31 Mar 2023 10:30:21 +0300 Subject: [PATCH 2/2] Disallow user removal when sync going --- workers/loc.api/sync/authenticator/index.js | 8 ++++++++ workers/loc.api/sync/progress/index.js | 15 +++++++++++---- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/workers/loc.api/sync/authenticator/index.js b/workers/loc.api/sync/authenticator/index.js index 6eff74872..60879c013 100644 --- a/workers/loc.api/sync/authenticator/index.js +++ b/workers/loc.api/sync/authenticator/index.js @@ -16,6 +16,7 @@ const { const { UserUpdatingError, UserRemovingError, + UserRemovingDuringSyncError, UserWasPreviouslyStoredInDbError, AuthTokenGenerationError } = require('../../errors') @@ -24,6 +25,7 @@ const { pickProps, pickSessionProps } = require('./helpers') +const Progress = require('../progress') const { decorateInjectable } = require('../../di/utils') @@ -926,6 +928,12 @@ class Authenticator { } } ) + const progress = await Progress + .getNonEstimatedProgress(this.dao, this.TABLES_NAMES) + + if (progress < 100) { + throw new UserRemovingDuringSyncError() + } const res = await this.dao.removeElemsFromDb( this.TABLES_NAMES.USERS, diff --git a/workers/loc.api/sync/progress/index.js b/workers/loc.api/sync/progress/index.js index 6ef57c400..46f018559 100644 --- a/workers/loc.api/sync/progress/index.js +++ b/workers/loc.api/sync/progress/index.js @@ -74,15 +74,22 @@ class Progress extends EventEmitter { } async getProgress () { - const progressObj = await this.dao - .getElemInCollBy(this.TABLES_NAMES.PROGRESS) + const progress = await this.constructor + .getNonEstimatedProgress(this.dao, this.TABLES_NAMES) + const estimatedSyncTime = this._estimateSyncTime({ progress }) + + return estimatedSyncTime + } + + static async getNonEstimatedProgress (dao, TABLES_NAMES) { + const progressObj = await dao + .getElemInCollBy(TABLES_NAMES.PROGRESS) const progress = typeof progressObj?.value === 'string' ? tryParseJSON(progressObj.value, true) : 'SYNCHRONIZATION_HAS_NOT_STARTED_YET' - const estimatedSyncTime = this._estimateSyncTime({ progress }) - return estimatedSyncTime + return progress } activateSyncTimeEstimate () {