zhengyiming
2025-08-22 f12b337fd0a9273cb982cbc09e3be43a4e078ffc
FlexJobApi.UserServer.Application/Users/Commands/SyncUserCommandHandler.cs
@@ -1,6 +1,11 @@
using FlexJobApi.Core;
using FlexJobApi.Core.Models.ElectronSignServer.Common;
using FlexJobApi.Core.Models.ElectronSignServer.PersonalUserReals;
using FlexJobApi.Core.Models.ElectronSignServer.Users;
using Furion;
using Furion.DatabaseAccessor;
using Furion.DataEncryption;
using Furion.DistributedIDGenerator;
using Furion.FriendlyException;
using Mapster;
using MediatR;
@@ -53,24 +58,84 @@
                var result = await BaiduOcrUtils.OcrBusinessLicense(enterprise.LicenseImage);
                if (result?.Model != null)
                {
                    result.Model.Adapt(enterprise);
                    enterprise.EnterpriseType = result.Model.EnterpriseType;
                    enterprise.RegisteredCapital = result.Model.RegisteredCapital;
                    enterprise.EstablishmentDate = result.Model.EstablishmentDate;
                    enterprise.Address = result.Model.Address;
                    enterprise.MainBusiness = result.Model.MainBusiness;
                }
            }
            if (enterprise.EnterpriseAuth != null)
            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);
                enterprise.EnterpriseAuth = new EnterpriseAuth();
            }
            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);
            if (enterprise.Id == Guid.Empty)
                await repEnterprise.InsertAsync(enterprise);
            else
                await repEnterprise.UpdateAsync(enterprise);
            if (enterprise.EnterpriseAuth.ElectronSignEnterpriseId == null)
            {
                var resultRegOrUpdateUser = await new RegOrUpdateUserInput
                {
                    OutUserId = enterprise.Id.ToString(),
                    UserType = EnumElectronSignUserType.Personal,
                    EnterpriseName = enterprise.EnterpriseName,
                    SocietyCreditCode = enterprise.SocietyCreditCode,
                    Name = enterprise.EnterpriseAuth.Name ?? enterprise.Contacts,
                    Identity = enterprise.EnterpriseAuth.Identity,
                    Mobile = enterprise.EnterpriseAuth.PhoneNumber,
                    CertAccount = enterprise.EnterpriseAuth.CertAccount
                }.SendHttpAsync<RegOrUpdateUserInput, ElectronSignServerResult<Guid?>>(EnumResourceHttpProvider.ElectronSignServerCustomer);
                if (resultRegOrUpdateUser?.Success == true)
                {
                    enterprise.EnterpriseAuth.ElectronSignEnterpriseId = resultRegOrUpdateUser.Result;
                }
                else
                {
                    throw Oops.Oh(EnumErrorCodeType.s510, resultRegOrUpdateUser?.Message ?? "注册电子签账号异常");
                }
            }
            if (enterprise.IsReal)
            {
                var resultReal = await new RealEnterpriseInputByCertAccountInput
                {
                    CustomerId = App.GetConfig<Guid>("ElectronSignServer:AppId"),
                    OutUserId = enterprise.Id.ToString(),
                    EnterpriseName = enterprise.EnterpriseName,
                    SocietyCreditCode = enterprise.SocietyCreditCode,
                    Name = enterprise.EnterpriseAuth.Name ?? enterprise.Contacts,
                    Identity = enterprise.EnterpriseAuth.Identity,
                    Mobile = enterprise.EnterpriseAuth.PhoneNumber,
                    BankCard = enterprise.EnterpriseAuth.BankCard,
                    BankCardImgUrl = enterprise.EnterpriseAuth.BankCardImg,
                    LicenseUrl = enterprise.EnterpriseAuth.LicenseImage,
                    IdentityImgUrl = enterprise.EnterpriseAuth.IdentityImg,
                    IdentityBackImgUrl = enterprise.EnterpriseAuth.IdentityBackImg,
                    ProxyPowerAttorneyUrl = enterprise.EnterpriseAuth.ProxyPowerAttorneyUrl,
                    LegalPerson = enterprise.EnterpriseAuth.LegalPerson,
                    Proxy = enterprise.EnterpriseAuth.Proxy ?? false,
                    RealMethod = (EnumElectronSignPersonalRealMethod)enterprise.EnterpriseAuth.EnterpriseRealMethod!.Value,
                    CertAccount = enterprise.EnterpriseAuth.CertAccount
                }.SendHttpAsync<RealEnterpriseInputByCertAccountInput, ElectronSignServerResult<RealEnterpriseInputByCertAccountOutput>>(EnumResourceHttpProvider.ElectronSignServerCustomer);
                if (resultReal?.Success != true || resultReal?.Result.Status != EnumElectronSignRealStatus.Real)
                {
                    throw Oops.Oh(EnumErrorCodeType.s510, resultReal?.Message ?? "账号实名异常");
                }
                enterprise.EnterpriseAuth.CertAccount = resultReal.Result.CertAccount;
            }
            var user = await repUser.AsQueryable()
                    .Include(it => it.UserRoles)
@@ -103,6 +168,9 @@
                await repUser.InsertAsync(user);
            else
                await repUser.UpdateAsync(user);
            return user.Id;
        }