From 38b8feb4a1c3fc34216ef8e7e0929a858ea114fc Mon Sep 17 00:00:00 2001 From: "alexis.vigoureux" Date: Fri, 29 Nov 2024 18:03:11 +0100 Subject: [PATCH] disableLastLoginUpdate --- packages/core/src/config/default-config.ts | 1 + packages/core/src/config/vendure-config.ts | 7 +++++++ packages/core/src/service/services/auth.service.ts | 6 ++++-- 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/packages/core/src/config/default-config.ts b/packages/core/src/config/default-config.ts index dfd9fe3e38..0a02cbf10f 100644 --- a/packages/core/src/config/default-config.ts +++ b/packages/core/src/config/default-config.ts @@ -99,6 +99,7 @@ export const defaultConfig: RuntimeVendureConfig = { sessionCacheStrategy: new InMemorySessionCacheStrategy(), sessionCacheTTL: 300, requireVerification: true, + disableLastLoginUpdate: false, verificationTokenDuration: '7d', superadminCredentials: { identifier: SUPER_ADMIN_USER_IDENTIFIER, diff --git a/packages/core/src/config/vendure-config.ts b/packages/core/src/config/vendure-config.ts index 017dfce4c5..9b14ae82af 100644 --- a/packages/core/src/config/vendure-config.ts +++ b/packages/core/src/config/vendure-config.ts @@ -473,6 +473,13 @@ export interface AuthOptions { * @default DefaultPasswordValidationStrategy */ passwordValidationStrategy?: PasswordValidationStrategy; + /** + * @description + * Disable the last login update (prevent a save on user entity) when a user logs in. + * This can be useful when there is a lot of authentication in a short period of time and get lock on the user table. + * @since 3.0.7 + */ + disableLastLoginUpdate?: boolean } /** diff --git a/packages/core/src/service/services/auth.service.ts b/packages/core/src/service/services/auth.service.ts index f1b3d0df38..d6f4f2259f 100644 --- a/packages/core/src/service/services/auth.service.ts +++ b/packages/core/src/service/services/auth.service.ts @@ -97,8 +97,10 @@ export class AuthService { if (ctx.session && ctx.session.activeOrderId) { await this.sessionService.deleteSessionsByActiveOrderId(ctx, ctx.session.activeOrderId); } - user.lastLogin = new Date(); - await this.connection.getRepository(ctx, User).save(user, { reload: false }); + if (user.roles || !this.configService.authOptions.disableLastLoginUpdate) { + user.lastLogin = new Date(); + await this.connection.getRepository(ctx, User).save(user, { reload: false }); + } const session = await this.sessionService.createNewAuthenticatedSession( ctx, user,