using JNPF.Common.Core.Manager; using JNPF.Common.Enums; using JNPF.Common.Extension; using JNPF.Common.Filter; using JNPF.Common.Security; using JNPF.DependencyInjection; using JNPF.DynamicApiController; using JNPF.FriendlyException; using JNPF.Systems.Entitys.Dto.User; using JNPF.Systems.Entitys.Permission; using JNPF.Systems.Interfaces.Permission; using JNPF.WorkFlow.Entitys.Dto.FlowDelegete; using JNPF.WorkFlow.Entitys.Dto.FlowTemplate; using JNPF.WorkFlow.Entitys.Entity; using JNPF.WorkFlow.Interfaces.Repository; using JNPF.WorkFlow.Interfaces.Service; using Mapster; using Microsoft.AspNetCore.Mvc; using SqlSugar; namespace JNPF.WorkFlow.Service; /// /// 流程委托. /// [ApiDescriptionSettings(Tag = "WorkflowEngine", Name = "FlowDelegate", Order = 300)] [Route("api/workflow/Engine/[controller]")] public class FlowDelegateService : IDynamicApiController, ITransient { private readonly ISqlSugarRepository _repository; private readonly IFlowTemplateService _flowTemplateService; private readonly IFlowTaskRepository _flowTaskRepository; private readonly IOrganizeService _organizeService; private readonly IUserManager _userManager; public FlowDelegateService(ISqlSugarRepository repository, IFlowTemplateService flowTemplateService, IFlowTaskRepository flowTaskRepository, IOrganizeService organizeService, IUserManager userManager) { _repository = repository; _flowTemplateService = flowTemplateService; _flowTaskRepository = flowTaskRepository; _organizeService = organizeService; _userManager = userManager; } #region GET /// /// 列表. /// /// 请求参数. /// [HttpGet("")] public async Task GetList([FromQuery] FlowDelegateQuery input) { var output = new SqlSugarPagedList(); if (input.myOrDelagateToMe.Equals("1")) { //var crUserList = new List(); //if (!_userManager.IsAdministrator) //{ // var orgIds = _userManager.DataScope.Select(x => x.organizeId).ToList();//分管组织id // crUserList = await _repository.AsSugarClient().Queryable().Where(x => orgIds.Contains(x.ObjectId)).Select(x => x.UserId).ToListAsync(); // crUserList.Add(_userManager.UserId); //} //output = await _repository.AsQueryable().Where(x => x.DeleteMark == null).WhereIF(crUserList.Count > 0, x => crUserList.Contains(x.UserId)) //.WhereIF(!input.keyword.IsNullOrEmpty(), m => m.FlowName.Contains(input.keyword) || m.ToUserName.Contains(input.keyword)).OrderBy(t => t.SortCode) //.OrderBy(x => x.CreatorTime, OrderByType.Desc).OrderByIF(!string.IsNullOrEmpty(input.keyword), t => t.LastModifyTime, OrderByType.Desc).ToPagedListAsync(input.currentPage, input.pageSize); output = await _repository.AsQueryable().Where(x => x.DeleteMark == null).Where(x => x.UserId == _userManager.UserId) .WhereIF(!input.keyword.IsNullOrEmpty(), m => m.FlowName.Contains(input.keyword) || m.ToUserName.Contains(input.keyword)).OrderBy(t => t.SortCode) .OrderBy(x => x.CreatorTime, OrderByType.Desc).OrderByIF(!string.IsNullOrEmpty(input.keyword), t => t.LastModifyTime, OrderByType.Desc).ToPagedListAsync(input.currentPage, input.pageSize); } else { output = await _repository.AsQueryable().Where(x => x.ToUserId == _userManager.UserId && x.DeleteMark == null) .WhereIF(!input.keyword.IsNullOrEmpty(), m => m.FlowName.Contains(input.keyword) || m.ToUserName.Contains(input.keyword)).OrderBy(t => t.SortCode) .OrderBy(x => x.CreatorTime, OrderByType.Desc).OrderByIF(!string.IsNullOrEmpty(input.keyword), t => t.LastModifyTime, OrderByType.Desc).ToPagedListAsync(input.currentPage, input.pageSize); } var pageList = new SqlSugarPagedList() { list = output.list.Adapt>(), pagination = output.pagination }; return PageResult.SqlSugarPageResult(pageList); } /// /// 信息. /// /// 主键值. /// [HttpGet("{id}")] public async Task GetInfo_Api(string id) { return (await _repository.GetFirstAsync(x => x.Id == id && x.DeleteMark == null)).Adapt(); } /// /// 委托发起流程列表. /// /// 请求参数. /// [HttpGet("getflow")] public async Task GetFlowList([FromQuery] FlowTemplateListQuery input) { var output = new List(); //委托给我的发起流程 var flowDelegateList = await _repository.GetListAsync(x => x.ToUserId == _userManager.UserId && x.Type == "0" && x.EndTime > DateTime.Now && x.StartTime < DateTime.Now && x.DeleteMark == null); foreach (var item in flowDelegateList) { var flowList = await _flowTemplateService.GetFlowFormList(input.flowType.ParseToInt(), item.UserId); // 非全部流程 if (item.FlowId.IsNotEmptyOrNull()) { output = output.Union(flowList.FindAll(x => item.FlowId.Contains(x.templateId))).DistinctBy(x => x.id).ToList(); } else { output = output.Union(flowList).DistinctBy(x => x.id).ToList(); } } if (input.keyword.IsNotEmptyOrNull()) output = output.FindAll(o => o.fullName.Contains(input.keyword) || o.enCode.Contains(input.keyword)); var pageList = new SqlSugarPagedList() { list = output.Skip((input.currentPage - 1) * input.pageSize).Take(input.pageSize).ToList(), pagination = new Pagination() { CurrentPage = input.currentPage, PageSize = input.pageSize, Total = output.Count } }; return PageResult.SqlSugarPageResult(pageList); } /// /// 发起流程委托人. /// /// 请求参数. /// [HttpGet("userList")] public async Task GetFlowList([FromQuery] string flowId) { var output = new List(); var orgList = _organizeService.GetOrgListTreeName(); var flowJsonModel = _flowTaskRepository.GetFlowTemplateInfo(flowId); // 委托给我的发起流程 var delagateToMeList = await _repository.GetListAsync(x => x.ToUserId == _userManager.UserId && x.Type == "0" && x.EndTime > DateTime.Now && x.StartTime < DateTime.Now && x.DeleteMark == null); foreach (var item in delagateToMeList) { var isDelagateUser = false; if (item.IsNotEmptyOrNull()) { if (item.FlowId.IsNotEmptyOrNull()) { // 非全部流程 isDelagateUser = item.FlowId.Contains(flowJsonModel.templateId); } else { // 全部流程 var flowList = await _flowTemplateService.GetFlowFormList(flowJsonModel.type.ParseToInt(), item.UserId); isDelagateUser = flowList.Select(x => x.id).Contains(flowId); } } if (isDelagateUser) { UserListOutput userListOutput = new UserListOutput(); var delagateUser = _repository.AsSugarClient().Queryable().First(x => x.Id == item.UserId && x.EnabledMark == 1 && x.DeleteMark == null); userListOutput.id = delagateUser.Id; userListOutput.headIcon = string.Format("/api/File/Image/userAvatar/{0}", delagateUser.HeadIcon); userListOutput.fullName = string.Format("{0}/{1}", delagateUser.RealName, delagateUser.Account); userListOutput.organize = orgList.FirstOrDefault(x => x.Id == delagateUser.OrganizeId).Description; output.Add(userListOutput); } } return new { list = output }; } #endregion #region POST /// /// 删除. /// /// 主键值. [HttpDelete("{id}")] public async Task Delete(string id) { var entity = await _repository.GetFirstAsync(x => x.Id == id && x.DeleteMark == null); if (entity == null) throw Oops.Oh(ErrorCode.COM1005); var isOk = await _repository.AsUpdateable(entity).CallEntityMethod(m => m.Delete()).UpdateColumns(it => new { it.DeleteMark, it.DeleteTime, it.DeleteUserId }).ExecuteCommandHasChangeAsync(); if (!isOk) throw Oops.Oh(ErrorCode.COM1002); } /// /// 新建. /// /// 新建参数. [HttpPost("")] public async Task Create([FromBody] FlowDelegeteCrInput input) { await Validation(input.Adapt()); var entity = input.Adapt(); var isOk = await _repository.AsInsertable(entity).CallEntityMethod(m => m.Create()).ExecuteCommandAsync(); if (isOk < 1) throw Oops.Oh(ErrorCode.COM1000); } /// /// 更新. /// /// 主键值. /// 修改参数. /// [HttpPut("{id}")] public async Task Update(string id, [FromBody] FlowDelegeteUpInput input) { await Validation(input.Adapt()); var entity = input.Adapt(); var isOk = await _repository.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).CallEntityMethod(m => m.LastModify()).ExecuteCommandHasChangeAsync(); if (!isOk) throw Oops.Oh(ErrorCode.COM1001); } #endregion /// /// 委托验证. /// /// /// private async Task Validation(FlowDelegeteUpInput input) { if (input.userId.Equals(input.toUserId)) throw Oops.Oh(ErrorCode.WF0001); //同委托人、被委托人、委托类型 var list = await _repository.GetListAsync(x => x.UserId == input.userId && x.ToUserId == input.toUserId && x.Type == input.type && x.Id != input.id && x.DeleteMark == null); if (list.Any()) { //同一时间段内 list = list.FindAll(x => !((x.StartTime > input.startTime && x.StartTime > input.endTime) || (x.EndTime < input.startTime && x.EndTime < input.endTime))); if (list.Any()) { if (list.Any(x => x.FlowId.IsNullOrEmpty()) || input.flowId.IsNullOrEmpty()) { throw Oops.Oh(ErrorCode.WF0041); } else { //非全部流程看存不存在相同流程 foreach (var item in input.flowId.Split(",")) { if (list.Any(x => x.FlowId.Contains(item))) throw Oops.Oh(ErrorCode.WF0041); } } } } var list1 = await _repository.GetListAsync(x => x.UserId == input.toUserId && x.ToUserId == input.userId && x.Type == input.type && x.Id != input.id && x.DeleteMark == null); if (list1.Any()) { //同一时间段内 list1 = list1.FindAll(x => !((x.StartTime > input.startTime && x.StartTime > input.endTime) || (x.EndTime < input.startTime && x.EndTime < input.endTime))); if (list1.Any()) { if (list1.Any(x => x.FlowId.IsNullOrEmpty()) || input.flowId.IsNullOrEmpty()) { throw Oops.Oh(ErrorCode.WF0042); } else { //非全部流程看存不存在相同流程 foreach (var item in input.flowId.Split(",")) { if (list1.Any(x => x.FlowId.Contains(item))) throw Oops.Oh(ErrorCode.WF0042); } } } } } }