sunpengfei
2025-08-18 4b574fd74eece20f4e64b48c39c5aa6ad70b0d0f
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,6 +47,14 @@
            }
            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.IdentityImg = GetOssUrl(enterprise.EnterpriseAuth.IdentityImg, request.Enterprise.EnterpriseAuth.IdentityImg);
@@ -55,8 +65,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 +79,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 +109,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 +119,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