From 8e2a25b07e8d4d003c61c8f7b9ee5e5e542371b4 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期四, 21 八月 2025 15:14:06 +0800
Subject: [PATCH] feat:开发

---
 FlexJobApi.UserServer.Application/Users/Commands/SyncUserCommandHandler.cs |   47 ++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 44 insertions(+), 3 deletions(-)

diff --git a/FlexJobApi.UserServer.Application/Users/Commands/SyncUserCommandHandler.cs b/FlexJobApi.UserServer.Application/Users/Commands/SyncUserCommandHandler.cs
index c501c32..ad47137 100644
--- a/FlexJobApi.UserServer.Application/Users/Commands/SyncUserCommandHandler.cs
+++ b/FlexJobApi.UserServer.Application/Users/Commands/SyncUserCommandHandler.cs
@@ -20,13 +20,15 @@
     /// </summary>
     public class SyncUserCommandHandler(
             IRepository<User> repUser,
-            IRepository<Enterprise> repEnterprise
+            IRepository<Enterprise> repEnterprise,
+            IRepository<Role> repRole
         ) :
         IRequestHandler<SyncEnterpriseUserCommand, Guid>,
         IRequestHandler<SyncOperationUserCommand, Guid>
     {
         private readonly IRepository<User> repUser = repUser;
         private readonly IRepository<Enterprise> repEnterprise = repEnterprise;
+        private readonly IRepository<Role> repRole = repRole;
 
         /// <summary>
         /// 鍚屾浼佷笟鐢ㄦ埛
@@ -45,8 +47,21 @@
             }
             request.Enterprise.Adapt(enterprise);
             enterprise.LicenseImage = GetOssUrl(enterprise.LicenseImage, request.Enterprise.LicenseImage);
+            if (enterprise.LicenseImage.IsNotNull() && enterprise.EnterpriseType.IsNull())
+            {
+                var result = await BaiduOcrUtils.OcrBusinessLicense(enterprise.LicenseImage);
+                if (result?.Model != null)
+                {
+                    result.Model.Adapt(enterprise);
+                }
+            }
             if (enterprise.EnterpriseAuth != null)
             {
+                enterprise.EnterpriseAuth.EnterpriseName = enterprise.EnterpriseName;
+                enterprise.EnterpriseAuth.SocietyCreditCode = enterprise.SocietyCreditCode;
+                enterprise.EnterpriseAuth.LicenseImage = enterprise.LicenseImage;
+                enterprise.EnterpriseAuth.LegalPerson = enterprise.LegalPerson;
+                enterprise.EnterpriseAuth.LegalIdentity = enterprise.LegalIdentity;
                 enterprise.EnterpriseAuth.IdentityImg = GetOssUrl(enterprise.EnterpriseAuth.IdentityImg, request.Enterprise.EnterpriseAuth.IdentityImg);
                 enterprise.EnterpriseAuth.IdentityBackImg = GetOssUrl(enterprise.EnterpriseAuth.IdentityBackImg, request.Enterprise.EnterpriseAuth.IdentityBackImg);
                 enterprise.EnterpriseAuth.BankCardImg = GetOssUrl(enterprise.EnterpriseAuth.BankCardImg, request.Enterprise.EnterpriseAuth.BankCardImg);
@@ -55,8 +70,10 @@
                 await repEnterprise.InsertAsync(enterprise);
             else
                 await repEnterprise.UpdateAsync(enterprise);
+
             var user = await repUser.AsQueryable()
-                    .Where(it => it.Type == EnumUserType.Enterprise && it.UserName == request.UserName)
+                    .Include(it => it.UserRoles)
+                    .Where(it => it.Type == EnumUserType.Enterprise && it.DataSource == request.DataSource && it.DataSourceId == request.DataSourceId)
                     .FirstOrDefaultAsync(cancellationToken);
             if (user == null)
             {
@@ -67,7 +84,19 @@
             {
                 throw Oops.Oh(EnumErrorCodeType.s405, "璐﹀彿");
             }
+            var checkUserNameExist = await repUser.AsQueryable().AsNoTracking()
+                .AnyAsync(it => it.Type == EnumUserType.Enterprise && it.UserName == request.UserName && it.Id != user.Id);
+            if (checkUserNameExist) throw Oops.Oh(EnumErrorCodeType.s405, "璐﹀彿");
+
             user.EnterpriseId = enterprise.Id;
+            user.Level = 100;
+            user.UserRoles = await repRole.AsQueryable().AsNoTracking()
+                .Where(it => it.UserType == user.Type && it.MinLevel == 100)
+                .Select(it => new UserRole
+                {
+                    RoleId = it.Id
+                })
+                .ToListAsync();
             request.Adapt(user);
             if (user.Id == Guid.Empty)
                 await repUser.InsertAsync(user);
@@ -85,8 +114,9 @@
         public async Task<Guid> Handle(SyncOperationUserCommand request, CancellationToken cancellationToken)
         {
             var user = await repUser.AsQueryable()
+                .Include(it => it.UserRoles)
                 .Include(it => it.UserManageIndustrialParks)
-                .Where(it => it.Type == EnumUserType.Operation && it.UserName == request.UserName)
+                .Where(it => it.Type == EnumUserType.Operation && it.DataSource == request.DataSource && it.DataSourceId == request.DataSourceId)
                 .FirstOrDefaultAsync(cancellationToken);
             if (user == null)
             {
@@ -94,11 +124,22 @@
                 user.Type = EnumUserType.Operation;
                 user.Status = EnumUserStatus.Normal;
             }
+            var checkUserNameExist = await repUser.AsQueryable().AsNoTracking()
+                .AnyAsync(it => it.Type == EnumUserType.Operation && it.UserName == request.UserName && it.Id != user.Id);
+            if (checkUserNameExist) throw Oops.Oh(EnumErrorCodeType.s405, "璐﹀彿");
             request.Adapt(user);
             user.UserManageIndustrialParks = request.IndustrialParkIds.Select(it => new UserManageIndustrialPark
             {
                 IndustrialParkId = it
             }).ToList();
+            user.Level = 100;
+            user.UserRoles = await repRole.AsQueryable().AsNoTracking()
+                .Where(it => it.UserType == user.Type && it.MinLevel == 100)
+                .Select(it => new UserRole
+                {
+                    RoleId = it.Id
+                })
+                .ToListAsync();
             if (user.Id == Guid.Empty)
                 await repUser.InsertAsync(user);
             else

--
Gitblit v1.9.1