From e88519257bbbd98b2b6e82c1a77ba788d956f0b4 Mon Sep 17 00:00:00 2001 From: Andrey Sobolev Date: Sat, 7 Dec 2024 23:49:59 +0700 Subject: [PATCH] UBERF-8612: Fix modifiedOn for apply tx (#7292) Signed-off-by: Andrey Sobolev --- server/middleware/src/modified.ts | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/server/middleware/src/modified.ts b/server/middleware/src/modified.ts index dde0704518..64bd26f7b7 100644 --- a/server/middleware/src/modified.ts +++ b/server/middleware/src/modified.ts @@ -13,7 +13,7 @@ // limitations under the License. // -import core, { MeasureContext, Tx, systemAccountEmail, type SessionData } from '@hcengineering/core' +import core, { MeasureContext, Tx, systemAccountEmail, type SessionData, type TxApplyIf } from '@hcengineering/core' import { BaseMiddleware, Middleware, TxMiddlewareResult, type PipelineContext } from '@hcengineering/server-core' /** @@ -33,12 +33,20 @@ export class ModifiedMiddleware extends BaseMiddleware implements Middleware { } tx (ctx: MeasureContext, txes: Tx[]): Promise { - for (const tx of txes) { + const now = Date.now() + function updateTx (tx: Tx): void { if (tx.modifiedBy !== core.account.System && ctx.contextData.userEmail !== systemAccountEmail) { - tx.modifiedOn = Date.now() + tx.modifiedOn = now tx.createdOn = tx.modifiedOn } } + for (const tx of txes) { + updateTx(tx) + if (tx._class === core.class.TxApplyIf) { + const atx = tx as TxApplyIf + atx.txes.forEach(updateTx) + } + } return this.provideTx(ctx, txes) } }