From 8ffda541b48cbf619f8493196da4fb44d4f3ddc5 Mon Sep 17 00:00:00 2001 From: sunpengfei <i@angelzzz.com> Date: 星期五, 05 九月 2025 10:22:55 +0800 Subject: [PATCH] feat:开发 --- FlexJobApi.UserServer.Application/EnterpriseEmployees/Commands/EnterpriseEmployeesCommandHandler.cs | 167 +++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 111 insertions(+), 56 deletions(-) diff --git a/FlexJobApi.UserServer.Application/EnterpriseEmployees/Commands/EnterpriseEmployeesCommandHandler.cs b/FlexJobApi.UserServer.Application/EnterpriseEmployees/Commands/EnterpriseEmployeesCommandHandler.cs index 5926454..e807a1b 100644 --- a/FlexJobApi.UserServer.Application/EnterpriseEmployees/Commands/EnterpriseEmployeesCommandHandler.cs +++ b/FlexJobApi.UserServer.Application/EnterpriseEmployees/Commands/EnterpriseEmployeesCommandHandler.cs @@ -30,6 +30,7 @@ /// 鐏靛伐鍛戒护澶勭悊鍣� /// </summary> public class EnterpriseEmployeesCommandHandler( + SmsUtils smsUtils, IMediator mediator, IRepository<EnterpriseEmployee> rep, IRepository<User> repUser, @@ -42,11 +43,13 @@ ) : IRequestHandler<ImportEnterpriseEmployeesCommand, ImportEnterpriseEmployeesCommandResult>, IRequestHandler<EditEnterpriseEmployeeCommand, Guid>, - IRequestHandler<InviteElectronSignCommand, Guid>, + IRequestHandler<InviteElectronSignCommand, int>, IRequestHandler<PersonalUserElectronSignCommand, PersonalUserElectronSignCommandResult>, IRequestHandler<EnterpriseUserElectronSignCommand, EnterpriseUserElectronSignCommandResult>, - IRequestHandler<StopElectronSignCommand, Guid> + IRequestHandler<StopElectronSignCommand, int>, + IRequestHandler<SendInviteElectronSignSmsCommand, int> { + private readonly SmsUtils smsUtils = smsUtils; private readonly IMediator mediator = mediator; private readonly IRepository<EnterpriseEmployee> rep = rep; private readonly IRepository<User> repUser = repUser; @@ -163,7 +166,7 @@ } } } - if (errors.IsNotNull()) + else { var error = model.Adapt<ImportEnterpriseEmployeesCommandResultError>(); error.ErrorMessage = errors.SplitJoin("锛�"); @@ -220,43 +223,82 @@ /// <param name="request"></param> /// <param name="cancellationToken"></param> /// <returns></returns> - public async Task<Guid> Handle(InviteElectronSignCommand request, CancellationToken cancellationToken) + public async Task<int> Handle(InviteElectronSignCommand request, CancellationToken cancellationToken) { var logier = JwtUtils.GetCurrentLogier(); - var entity = await rep.AsQueryable() - .Where(it => it.EnterpriseId == logier.EnterpriseId && it.Id == request.Id) - .FirstOrDefaultAsync(); - if (entity == null) throw Oops.Oh(EnumErrorCodeType.s404, "鐏靛伐"); - if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s400, "宸查個璇�"); - if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass) throw Oops.Oh(EnumErrorCodeType.s400, "宸茬绾�"); - if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Effect) throw Oops.Oh(EnumErrorCodeType.s400, "宸茬敓鏁�"); + await mediator.Send(new CheckContractTemplateCommand { Id = request.ContractTemplateId }, cancellationToken); - entity.ContractTemplateId = request.ContractTemplateId; - entity.UserSignContractStatus = EnumTaskUserSignContractStatus.Wait; - entity.UserSignContractTime = null; - entity.EnterpriseSignContractStatus = null; - entity.EnterpriseSignContractTime = null; - entity.ContractCode = $"{DateTime.Now:yyyyMMddHHmmss}{new Random(IDGen.NextID().GetHashCode()).Next(1000, 9999)}"; - var contract = new EnterpriseEmployeeContract + + var entities = await rep.AsQueryable() + .Where(it => it.EnterpriseId == logier.EnterpriseId && request.Ids.Contains(it.Id)) + .ToListAsync(); + foreach (var id in request.Ids) { - EnterpriseEmployeeId = entity.Id, - ContractTemplateId = entity.ContractTemplateId, - ContractCode = entity.ContractCode, - UserSignContractStatus = entity.UserSignContractStatus, - }; - await repEnterpriseEmployeeContract.InsertAsync(contract); - //await mediator.Send(new SaveEnterpriseCostCommand - //{ - // EnterpriseId = logier.EnterpriseId!.Value, - // ContractTemplateId = request.ContractTemplateId, - // EnterpriseEmployeeContractId = contract.Id, - // Type = EnumEnterpriseCostType.ElectronSign - //}); - await rep.UpdateAsync(entity); - return entity.Id; + var entity = entities.FirstOrDefault(it => it.Id == id); + if (entity == null) throw Oops.Oh(EnumErrorCodeType.s404, "鐏靛伐"); + if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s400, $"宸查個璇穥entity.Name}"); + if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass) throw Oops.Oh(EnumErrorCodeType.s400, $"宸茬绾entity.Name}"); + entity.ContractTemplateId = request.ContractTemplateId; + entity.UserSignContractStatus = EnumTaskUserSignContractStatus.Wait; + entity.UserSignContractTime = null; + entity.EnterpriseSignContractStatus = null; + entity.EnterpriseSignContractTime = null; + entity.ContractCode = $"{DateTime.Now:yyyyMMddHHmmss}{new Random(IDGen.NextID().GetHashCode()).Next(1000, 9999)}"; + entity.ContractUrl = null; + var contract = new EnterpriseEmployeeContract + { + EnterpriseEmployeeId = entity.Id, + ContractTemplateId = entity.ContractTemplateId, + ContractCode = entity.ContractCode, + UserSignContractStatus = entity.UserSignContractStatus, + }; + await repEnterpriseEmployeeContract.InsertAsync(contract); + //await mediator.Send(new SaveEnterpriseCostCommand + //{ + // EnterpriseId = logier.EnterpriseId!.Value, + // ContractTemplateId = request.ContractTemplateId, + // EnterpriseEmployeeContractId = contract.Id, + // Type = EnumEnterpriseCostType.ElectronSign + //}); + await rep.UpdateAsync(entity); + } + return entities.Count; + } + + /// <summary> + /// 鍙戦�侀個璇风绾︾煭淇� + /// </summary> + /// <param name="request"></param> + /// <param name="cancellationToken"></param> + /// <returns></returns> + public async Task<int> Handle(SendInviteElectronSignSmsCommand request, CancellationToken cancellationToken) + { + var logier = JwtUtils.GetCurrentLogier(); + var entities = await rep.AsQueryable() + .Include(it => it.Enterprise) + .Include(it => it.ContractTemplate) + .Where(it => + it.EnterpriseId == logier.EnterpriseId + && request.Ids.Contains(it.Id) + && it.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait) + .ToListAsync(); + foreach (var entity in entities) + { + await smsUtils.Send(new SendSmsModel + { + PhoneNumber = entity.ContactPhoneNumber, + TemplateCode = EnumSmsTemplateCode.InviteElectronSign, + }, + new + { + name = entity.Enterprise.EnterpriseName, + code = entity.ContractTemplate.Code + }); + } + return entities.Count; } /// <summary> @@ -275,7 +317,6 @@ if (entity == null) throw Oops.Oh(EnumErrorCodeType.s510, "鏈姤鍚嶈浼佷笟"); if (entity.UserSignContractStatus == null) throw Oops.Oh(EnumErrorCodeType.s510, "浼佷笟鏈彂璧风绾�"); if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass) throw Oops.Oh(EnumErrorCodeType.s510, "宸茬绾�"); - if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Effect) throw Oops.Oh(EnumErrorCodeType.s510, "宸茬敓鏁�"); if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Refuse) throw Oops.Oh(EnumErrorCodeType.s510, "宸叉嫆绛�"); if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Stop) throw Oops.Oh(EnumErrorCodeType.s510, "宸茬粓姝�"); var contract = await repEnterpriseEmployeeContract.AsQueryable() @@ -327,7 +368,11 @@ { throw Oops.Oh(EnumErrorCodeType.s510, result?.Message ?? "绛剧害澶辫触"); } - return result.Result.Adapt<PersonalUserElectronSignCommandResult>(); + var model = result.Result.Adapt<PersonalUserElectronSignCommandResult>(); + model.SignContractLongUrl = model.SignContractLongUrl + .Replace("https://openapi.bestsign.info:443", "https://wx115.bestsign.info") + .Replace("https://openapi.bestsign.cn:443", "https://wx115.bestsign.cn"); + return model; } /// <summary> @@ -346,7 +391,6 @@ if (entity == null) throw Oops.Oh(EnumErrorCodeType.s510, "鐏靛伐涓嶅瓨鍦�"); if (entity.UserSignContractStatus == null) throw Oops.Oh(EnumErrorCodeType.s510, "鏈個璇风绾�"); if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s510, "璇峰厛绛夊緟鐏靛伐绛剧害瀹屾垚"); - if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Effect) throw Oops.Oh(EnumErrorCodeType.s510, "宸茬敓鏁�"); if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Refuse) throw Oops.Oh(EnumErrorCodeType.s510, "宸叉嫆绛�"); if (entity.UserSignContractStatus == EnumTaskUserSignContractStatus.Stop) throw Oops.Oh(EnumErrorCodeType.s510, "宸茬粓姝�"); var contract = await repEnterpriseEmployeeContract.AsQueryable() @@ -379,7 +423,11 @@ { throw Oops.Oh(EnumErrorCodeType.s510, result?.Message ?? "绛剧害澶辫触"); } - return result.Result.Adapt<EnterpriseUserElectronSignCommandResult>(); + var model = result.Result.Adapt<EnterpriseUserElectronSignCommandResult>(); + model.SignContractLongUrl = model.SignContractLongUrl + .Replace("https://openapi.bestsign.info:443", "https://wx115.bestsign.info") + .Replace("https://openapi.bestsign.cn:443", "https://wx115.bestsign.cn"); + return model; } /// <summary> @@ -388,29 +436,35 @@ /// <param name="request"></param> /// <param name="cancellationToken"></param> /// <returns></returns> - public async Task<Guid> Handle(StopElectronSignCommand request, CancellationToken cancellationToken) + public async Task<int> Handle(StopElectronSignCommand request, CancellationToken cancellationToken) { var logier = JwtUtils.GetCurrentLogier(); - var entity = await rep.AsQueryable() - .Where(it => it.EnterpriseId == logier.EnterpriseId && it.Id == request.Id) - .FirstOrDefaultAsync(); - if (entity == null) throw Oops.Oh(EnumErrorCodeType.s404, "鐏靛伐"); - if (entity.UserSignContractStatus != EnumTaskUserSignContractStatus.Effect) throw Oops.Oh(EnumErrorCodeType.s400, "鏈敓鏁�"); - entity.UserSignContractStatus = EnumTaskUserSignContractStatus.Stop; - entity.EnterpriseSignContractStatus = EnumTaskUserSignContractStatus.Stop; - await rep.UpdateAsync(entity); + var entities = await rep.AsQueryable() + .Include(it => it.Contracts) + .Where(it => it.EnterpriseId == logier.EnterpriseId && request.Ids.Contains(it.Id)) + .ToListAsync(); + foreach (var id in request.Ids) + { + var entity = entities.FirstOrDefault(it => it.Id == id); + if (entity == null) throw Oops.Oh(EnumErrorCodeType.s404, "鐏靛伐"); + if (entity.UserSignContractStatus != EnumTaskUserSignContractStatus.Pass) throw Oops.Oh(EnumErrorCodeType.s400, $"鏈绾entity.Name}"); + entity.UserSignContractStatus = EnumTaskUserSignContractStatus.Stop; + entity.EnterpriseSignContractStatus = EnumTaskUserSignContractStatus.Stop; + await rep.UpdateAsync(entity); - var contract = await repEnterpriseEmployeeContract.AsQueryable() - .OrderByDescending(it => it.CreatedTime) - .Where(it => it.EnterpriseEmployeeId == entity.Id) - .FirstOrDefaultAsync(); - if (contract == null) throw Oops.Oh(EnumErrorCodeType.s404, "鍚堝悓"); - contract.UserSignContractStatus = EnumTaskUserSignContractStatus.Stop; - contract.EnterpriseSignContractStatus = EnumTaskUserSignContractStatus.Stop; - await repEnterpriseEmployeeContract.UpdateAsync(contract); + var contract = entity.Contracts + .OrderByDescending(it => it.CreatedTime) + .FirstOrDefault(); + if (contract == null) throw Oops.Oh(EnumErrorCodeType.s404, $"涓巤entity.Name}鐨勫悎鍚�"); + contract.UserSignContractStatus = EnumTaskUserSignContractStatus.Stop; + contract.EnterpriseSignContractStatus = EnumTaskUserSignContractStatus.Stop; + await repEnterpriseEmployeeContract.UpdateAsync(contract); + } var taskUsers = await repTaskInfoUser.AsQueryable() - .Where(it => it.EnterpriseEmployeeId == entity.Id && it.HireStatus == EnumTaskUserHireStatus.Pass) + .Where(it => + it.HireStatus == EnumTaskUserHireStatus.Pass + && request.Ids.Contains(it.EnterpriseEmployeeId)) .ToListAsync(); if (taskUsers.IsNotNull()) { @@ -421,7 +475,8 @@ await repTaskInfoUser.UpdateAsync(taskUsers); } - return entity.Id; + return entities.Count; } + } } -- Gitblit v1.9.1