From dfd067a00e06989934a8a2e39a244f301f34797b Mon Sep 17 00:00:00 2001 From: Oleg Zhuk Date: Mon, 26 Aug 2024 13:43:35 +0200 Subject: [PATCH] VCST-1705: Validation error displayed after Google SSO when account data is incomplete (#7) VCST-1705: Validation error displayed after Google SSO when account data is incomplete fix: Validation error displayed after Google SSO when account data is incomplete. --- .../Services/ExternalSignInUserBuilder.cs | 32 ++++++++++++++++--- 1 file changed, 27 insertions(+), 5 deletions(-) diff --git a/src/VirtoCommerce.Xapi.Data/Services/ExternalSignInUserBuilder.cs b/src/VirtoCommerce.Xapi.Data/Services/ExternalSignInUserBuilder.cs index 6f957a1..2c26588 100644 --- a/src/VirtoCommerce.Xapi.Data/Services/ExternalSignInUserBuilder.cs +++ b/src/VirtoCommerce.Xapi.Data/Services/ExternalSignInUserBuilder.cs @@ -1,3 +1,4 @@ +using System.Collections.Generic; using System.Security.Claims; using System.Threading.Tasks; using Microsoft.AspNetCore.Identity; @@ -14,15 +15,16 @@ namespace VirtoCommerce.Xapi.Data.Services; public class ExternalSignInUserBuilder(IStoreService storeService, IMemberService memberService) : IExternalSignInUserBuilder { - public async Task BuildNewUser(ApplicationUser user, ExternalLoginInfo externalLoginInfo) + public virtual async Task BuildNewUser(ApplicationUser user, ExternalLoginInfo externalLoginInfo) { if (user.MemberId is null && user.UserType == UserType.Customer.ToString()) { var contact = AbstractTypeFactory.TryCreateInstance(); - contact.Name = externalLoginInfo.Principal.FindFirstValue("name"); - contact.FirstName = externalLoginInfo.Principal.FindFirstValue(ClaimTypes.GivenName); - contact.LastName = externalLoginInfo.Principal.FindFirstValue(ClaimTypes.Surname); - contact.Emails = [user.Email]; + + contact.Name = ResolveContactName(user, externalLoginInfo); + contact.FirstName = ResolveContactFirstName(user, externalLoginInfo); + contact.LastName = ResolveContactLastName(user, externalLoginInfo); + contact.Emails = ResolveContactEmails(user, externalLoginInfo); if (!string.IsNullOrEmpty(user.StoreId)) { @@ -35,4 +37,24 @@ public async Task BuildNewUser(ApplicationUser user, ExternalLoginInfo externalL user.MemberId = contact.Id; } } + + protected virtual string ResolveContactName(ApplicationUser user, ExternalLoginInfo externalLoginInfo) + { + return externalLoginInfo.Principal.FindFirstValue("name"); + } + + protected virtual string ResolveContactFirstName(ApplicationUser user, ExternalLoginInfo externalLoginInfo) + { + return externalLoginInfo.Principal.FindFirstValue(ClaimTypes.GivenName) ?? string.Empty; + } + + protected virtual string ResolveContactLastName(ApplicationUser user, ExternalLoginInfo externalLoginInfo) + { + return externalLoginInfo.Principal.FindFirstValue(ClaimTypes.Surname) ?? string.Empty; + } + + protected virtual IList ResolveContactEmails(ApplicationUser user, ExternalLoginInfo externalLoginInfo) + { + return [user.Email]; + } }