//-------------------------------------------------------------------- // 此代码由liquid模板自动生成 byzhouhang 20240909 // 生成时间 2025-03-27 06:13:33Z // 对此文件的更改可能会导致不正确的行为,并且如果重新生成代码,这些更改将会丢失。 //-------------------------------------------------------------------- using IRaCIS.Core.Domain.Models; using Microsoft.AspNetCore.Mvc; using IRaCIS.Core.Application.Interfaces; using IRaCIS.Core.Application.ViewModel; using IRaCIS.Core.Infrastructure.Extention; using System.Threading.Tasks; using IRaCIS.Core.Infra.EFCore; using AutoMapper.Execution; using System.Linq; using IRaCIS.Core.Infrastructure; using DocumentFormat.OpenXml.Office2010.Excel; using MassTransit; using NPOI.POIFS.Properties; using Org.BouncyCastle.Crypto; using Microsoft.AspNetCore.Http; using IRaCIS.Core.Application.Contracts; namespace IRaCIS.Core.Application.Service; /// /// 稽查文档 /// /// [ApiExplorerSettings(GroupName = "FileRecord")] public class AuditDocumentService(IRepository _auditDocumentRepository, IRepository _auditRecordRepository, IRepository _auditRecordPermissionRepository, IRepository _auditRecordIdentityUserRepository, IMapper _mapper, IUserInfo _userInfo, IStringLocalizer _localizer) : BaseService { #region 稽查新增需求 /// /// 稽查记录 列表 /// /// /// [HttpPost] public async Task> GetAuditRecordList(AuditRecordQuery inQuery) { var auditRecordQueryable = _auditRecordRepository .WhereIf(inQuery.BeginAuditTime != null, t => t.AuditTime >= inQuery.BeginAuditTime) .WhereIf(inQuery.EndAuditTime != null, t => t.AuditTime <= inQuery.EndAuditTime) .WhereIf(inQuery.AuditState != null, t => t.AuditState == inQuery.AuditState) .WhereIf(inQuery.BeginTime != null, t => t.BeginTime >= inQuery.BeginTime) .WhereIf(inQuery.EndTime != null, t => t.EndTime <= inQuery.EndTime) .WhereIf(inQuery.CompanyName.IsNotNullOrEmpty(), t => t.CompanyName.Contains(inQuery.CompanyName)) .WhereIf(inQuery.AuditContent.IsNotNullOrEmpty(), t => t.AuditContent.Contains(inQuery.AuditContent)) .ProjectTo(_mapper.ConfigurationProvider); var pageList = await auditRecordQueryable.ToPagedListAsync(inQuery); return pageList; } [HttpPost] public async Task AddOrUpdateAuditRecord(AuditRecordAddOrEdit addOrEditAuditRecord) { if (addOrEditAuditRecord.Id == null) { var entity = _mapper.Map(addOrEditAuditRecord); if (await _auditRecordRepository.AnyAsync(t => t.CompanyName == addOrEditAuditRecord.CompanyName && t.AuditContent == addOrEditAuditRecord.AuditContent && t.AuditTime == addOrEditAuditRecord.AuditTime, true)) { //---重复的稽查记录。 return ResponseOutput.NotOk(_localizer["AuditDocument_RepeatAuditRecord"]); } await _auditRecordRepository.AddAsync(entity, true); return ResponseOutput.Ok(entity.Id.ToString()); } else { if (await _auditRecordRepository.AnyAsync(t => t.CompanyName == addOrEditAuditRecord.CompanyName && t.AuditContent == addOrEditAuditRecord.AuditContent && t.AuditTime == addOrEditAuditRecord.AuditTime && t.Id != addOrEditAuditRecord.Id, true)) { //---重复的稽查记录。 return ResponseOutput.NotOk(_localizer["AuditDocument_RepeatAuditRecord"]); } var find = _auditRecordRepository.Where(t => t.Id == addOrEditAuditRecord.Id, true).FirstOrDefault(); _mapper.Map(addOrEditAuditRecord, find); find.UpdateTime = DateTime.Now; var success = await _auditRecordRepository.SaveChangesAsync(); return ResponseOutput.Ok(find.Id.ToString()); } } /// /// 删除稽查记录 /// /// /// [HttpDelete("{auditRecordId:guid}")] public async Task DeleteAuditRecord(Guid auditRecordId) { if (await _auditRecordRepository.Where(t => t.Id == auditRecordId).AnyAsync(u => u.AuditState != AuditState.NotStart)) { //未开始的才允许删除 return ResponseOutput.NotOk(_localizer["AuditDocument_CannotDeleteStartRecod"]); } var success = await _auditRecordRepository.DeleteFromQueryAsync(t => t.Id == auditRecordId, true); return ResponseOutput.Ok(); } /// /// 设置授权 /// /// /// public async Task SetAuditRecordPermission(SetAuditRecordPermissionCommand inCommand) { if (_auditRecordPermissionRepository.Any(t => t.AuditRecordId == inCommand.AuditRecordId && t.AuditDocumentId == inCommand.AuditDocumentId)) { } return ResponseOutput.Ok(); } #endregion /// /// 获取稽查文档 /// /// /// [HttpPost] public async Task> GetAuditDocumentList(AuditDocumentQuery inQuery) { var auditDocumentQueryable = _auditDocumentRepository .ProjectTo(_mapper.ConfigurationProvider); var pageList = await auditDocumentQueryable.ToPagedListAsync(inQuery); return pageList; } /// /// 修改稽查文档 /// /// /// [HttpPost] public async Task UpdateAuditDocument(AuditDocumentUpdateDto inDto) { AuditDocumentAddOrEdit addOrEdit = _mapper.Map(inDto); addOrEdit.IsUpdate = true; var result = await AddOrUpdateAuditDocument(addOrEdit); return ResponseOutput.Ok(result.Id); } /// /// 新增文件夹 /// /// /// /// [HttpPost] public async Task AddFolder(AuditDocumentAddOrEdit inDto) { if (await _auditDocumentRepository.AnyAsync(x => x.Name == inDto.Name && x.AuditDocumentTypeEnum == inDto.AuditDocumentTypeEnum && x.ParentId == inDto.ParentId)) { throw new BusinessValidationFailedException(_localizer["AuditDocument_CanNotAddFolder"]); } List auditDocumentAddOrEdits = new List(); auditDocumentAddOrEdits.Add(inDto); var result = await AddAuditDocument(auditDocumentAddOrEdits); return ResponseOutput.Ok(result); } /// /// 新增稽查文档 /// /// /// [HttpPost] public async Task AddAuditDocument(List inDto) { List resultData = new List(); inDto.ForEach(x => x.IsUpdate = false); await addData(inDto); async Task addData(List data) { foreach (var item in data) { var result = await AddOrUpdateAuditDocument(item); resultData.Add(result.Id); item.Children.ForEach(x => { x.ParentId = result.Id; x.IsUpdate = false; }); if (item.Children.Count() > 0) { await addData(item.Children); } } } return ResponseOutput.Ok(resultData); } /// /// 通用方法 /// /// private async Task AddOrUpdateAuditDocument(AuditDocumentAddOrEdit inDto) { var alikeData = await _auditDocumentRepository.Where(x => x.Id != inDto.Id && x.ParentId == inDto.ParentId && x.Name == inDto.Name && x.AuditDocumentTypeEnum == inDto.AuditDocumentTypeEnum).FirstOrDefaultAsync(); if (alikeData != null) { if (inDto.AuditDocumentTypeEnum == AuditDocumentType.Folder) { if (inDto.IsUpdate) { throw new BusinessValidationFailedException(_localizer["AuditDocument_CanNotAddFolder"]); } else { return alikeData; } } else { var entityData = await _auditDocumentRepository.InsertOrUpdateAsync(inDto, true); var historicalVersionIds = await _auditDocumentRepository.Where(x => x.MainFileId == alikeData.Id).OrderBy(x => x.Version).Select(x => x.Id).ToListAsync(); historicalVersionIds.Add(alikeData.Id); int num = 1; foreach (var item in historicalVersionIds) { await _auditDocumentRepository.UpdatePartialFromQueryAsync(item, x => new AuditDocument() { MainFileId = entityData.Id, ParentId = null, Version = num, AuditDocumentTypeEnum = AuditDocumentType.HistoricalVersion }, true); num++; } return entityData; } } var entity = await _auditDocumentRepository.InsertOrUpdateAsync(inDto, true); return entity; } /// /// 获取面包屑导航 /// /// /// [HttpPost] public async Task> GetBreadcrumbData(GetBreadcrumbDataInDto inDto) { List result = new List(); await findParent(result, inDto.Id); async Task findParent(List datas, Guid id) { var data = await _auditDocumentRepository.Where(x => x.Id == id).ProjectTo(_mapper.ConfigurationProvider).FirstNotNullAsync(); datas.Add(data); if (data.ParentId != null) { await findParent(datas, data.ParentId.Value); } } result.Reverse(); return result; } /// /// 获取文件树形结构 (传Id 根节点就是自己) /// /// /// [HttpPost] public async Task> GetAuditDocumentData(GetAuditDocumentDataInDto inDto) { var defalutSortArray = new string[] { nameof(AuditDocumentData.AuditDocumentTypeEnum), nameof(AuditDocumentData.Name) }; if (inDto.SortField.IsNotNullOrEmpty()) { defalutSortArray = new string[] { nameof(AuditDocumentData.AuditDocumentTypeEnum), inDto.SortField + (inDto.Asc ? " asc" : " desc") }; inDto.SortField = string.Empty; } // 新取出来排序 然后再找子项 var data = (await _auditDocumentRepository .Where(x => x.AuditDocumentTypeEnum != AuditDocumentType.HistoricalVersion) .WhereIf(inDto.IsAuthorization != null, x => x.IsAuthorization == inDto.IsAuthorization) .ProjectTo(_mapper.ConfigurationProvider).ToPagedListAsync(new PageInput() { PageIndex = 1, PageSize = 999999, }, defalutSortArray)).CurrentPageData.ToList(); if (inDto.Name.IsNotNullOrEmpty()) { List findIds = new List(); var findData = data.Where(x => x.Name.Contains(inDto.Name)).Select(x => x.Id.Value).ToList(); GetParentId(findIds, findData, data); findIds.AddRange(findData); data = data.Where(x => findIds.Distinct().Contains(x.Id.Value)).ToList(); } var query = data .WhereIf(inDto.SelfId != null, x => inDto.SelfId == x.Id) .WhereIf(inDto.Id != null, x => inDto.Id == x.ParentId) .WhereIf(inDto.Id == null && inDto.SelfId == null, x => x.ParentId == null); PageOutput result = new PageOutput() { PageIndex = inDto.PageIndex, PageSize = inDto.PageSize, TotalCount = query.Count(), }; var root = query .Skip(inDto.PageSize * (inDto.PageIndex - 1)).Take(inDto.PageSize).ToList(); var historicalVersionList = await _auditDocumentRepository .Where(x => x.AuditDocumentTypeEnum == AuditDocumentType.HistoricalVersion).ProjectTo(_mapper.ConfigurationProvider).ToListAsync(); foreach (var item in root) { GetChildren(item, data, historicalVersionList); } result.CurrentPageData = root; return result; } private void GetParentId(List parentIds, List ids, List dataList) { var parentid = dataList.Where(x => ids.Contains(x.Id.Value) && x.ParentId != null).Select(x => x.ParentId.Value).ToList(); if (parentid.Count() > 0) { parentIds.AddRange(parentid); GetParentId(parentIds, parentid, dataList); } } private void GetChildren(AuditDocumentData item, List dataList, List historyList) { item.Children = dataList.Where(x => x.ParentId == item.Id).ToList(); item.HistoricalVersionsCount = historyList.Where(x => x.MainFileId == item.Id).Count(); foreach (var x in item.Children) { GetChildren(x, dataList, historyList); } } /// /// 删除稽查文档 /// /// /// [HttpPost] public async Task DeleteAuditDocument(DeleteAuditDocumentInDto inDto) { var data = await _auditDocumentRepository.Select(x => new DeleteAudit() { Id = x.Id, ParentId = x.ParentId, MainFileId = x.MainFileId }).ToListAsync(); List DeleteId = inDto.Ids; finId(inDto.Ids, data); void finId(List deletids, List deletes) { DeleteId.AddRange(deletids); var temp = deletes.Where(x => (x.ParentId != null && deletids.Contains(x.ParentId.Value)) || (x.MainFileId != null && deletids.Contains(x.MainFileId.Value))).Select(x => x.Id).ToList(); if (temp.Count() > 0) { finId(temp, deletes); } } DeleteId = DeleteId.Distinct().ToList(); var mainFileId = await _auditDocumentRepository.Where(x => DeleteId.Contains(x.Id) && x.MainFileId != null).Select(x => x.MainFileId).Distinct().ToListAsync(); var success = await _auditDocumentRepository.DeleteFromQueryAsync(t => DeleteId.Distinct().Contains(t.Id), true); foreach (var item in mainFileId) { var historicalVersionList = await _auditDocumentRepository.Where(x => x.MainFileId == item).OrderBy(x => x.Version).ToListAsync(); var num = 1; foreach (var historical in historicalVersionList) { await _auditDocumentRepository.UpdatePartialFromQueryAsync(historical.Id, x => new AuditDocument() { Version = num, }, true); num++; } } return ResponseOutput.Ok(); } /// /// 移动文件或者文件夹 到其他文件夹 /// /// [HttpPost] public async Task MovieFileOrFolder(MovieFileOrFolderInDto inDto) { var data = await _auditDocumentRepository.Select(x => new DeleteAudit() { Id = x.Id, ParentId = x.ParentId, AuditDocumentTypeEnum = x.AuditDocumentTypeEnum, MainFileId = x.MainFileId }).ToListAsync(); foreach (var id in inDto.Ids) { var file = data.Where(x => x.Id == id).FirstOrDefault(); if (file.AuditDocumentTypeEnum == AuditDocumentType.Folder) { if (finChild(new List { id }, inDto.ParentId, data)) { throw new BusinessValidationFailedException(_localizer["AuditDocument_CanNotMove"]); } } } bool finChild(List ids, Guid ChildId, List data) { var child = data.Where(x => x.ParentId != null && ids.Contains(x.ParentId.Value)).ToList(); if (child.Count() == 0) { return false; } else if (child.Any(x => x.Id == ChildId)) { return true; } else { var newids = child.Select(x => x.Id).ToList(); return finChild(newids, ChildId, data); } } foreach (var id in inDto.Ids) { await _auditDocumentRepository.UpdatePartialFromQueryAsync(id, x => new AuditDocument() { ParentId = inDto.ParentId }); await _auditDocumentRepository.SaveChangesAsync(); } return ResponseOutput.Ok(); } /// /// 复制文件或者文件夹 /// /// /// [HttpPost] public async Task CopyFileOrFolder(MovieFileOrFolderInDto inDto) { foreach (var item in inDto.Ids) { var data = (await GetAuditDocumentData(new GetAuditDocumentDataInDto() { SelfId = item, PageIndex = 1, PageSize = 1000 })).CurrentPageData; List auditDocumentAddOrEdits = _mapper.Map>(data); auditDocumentAddOrEdits.ForEach(x => { x.IsUpdate = false; x.Id = null; x.ParentId = inDto.ParentId; }); await addData(auditDocumentAddOrEdits); } async Task addData(List data) { foreach (var item in data) { item.Id = null; var result = await AddOrUpdateAuditDocument(item); item.Children.ForEach(x => { x.ParentId = result.Id; x.IsUpdate = false; x.Id = null; }); if (item.Children.Count() > 0) { await addData(item.Children); } } } return ResponseOutput.Ok(); } /// /// 获取历史版本 /// /// /// [HttpPost] public async Task> GetHistoricalVersion(GetHistoricalVersionInDto inDto) { List result = new List(); result = await _auditDocumentRepository.Where(x => x.MainFileId == inDto.Id).ProjectTo(_mapper.ConfigurationProvider).OrderByDescending(x => x.Version).ToListAsync(); var currentData = await _auditDocumentRepository.Where(x => x.Id == inDto.Id).ProjectTo(_mapper.ConfigurationProvider).FirstNotNullAsync(); currentData.IsCurrentVersion = true; result.Insert(0, currentData); return result; } /// /// 把历史版本设置为当前版本 /// /// [HttpPost] public async Task SetCurrentVersion(SetCurrentVersionInDto inDto) { var file = await _auditDocumentRepository.Where(x => x.Id == inDto.Id).FirstNotNullAsync(); if (file.AuditDocumentTypeEnum != AuditDocumentType.HistoricalVersion) { throw new BusinessValidationFailedException(_localizer["AuditDocument_CanNotSetCurrentVersion"]); } var mainFile = await _auditDocumentRepository.Where(x => x.Id == file.MainFileId).FirstNotNullAsync(); var historicalVersionIds = await _auditDocumentRepository.Where(x => x.MainFileId == mainFile.Id && x.Id != inDto.Id).OrderBy(x => x.Version).Select(x => x.Id).ToListAsync(); historicalVersionIds.Add(mainFile.Id); await _auditDocumentRepository.UpdatePartialFromQueryAsync(inDto.Id, x => new AuditDocument() { MainFileId = null, ParentId = mainFile.ParentId, AuditDocumentTypeEnum = AuditDocumentType.File, }); int num = 1; foreach (var item in historicalVersionIds) { await _auditDocumentRepository.UpdatePartialFromQueryAsync(item, x => new AuditDocument() { MainFileId = inDto.Id, ParentId = null, Version = num, AuditDocumentTypeEnum = AuditDocumentType.HistoricalVersion }); num++; } await _auditDocumentRepository.SaveChangesAsync(); return ResponseOutput.Ok(); } /// /// 设置是否授权 /// /// /// [HttpPost] public async Task SetIsAuthorization(SetIsAuthorizationInDto inDto) { var data = await _auditDocumentRepository.Select(x => new DeleteAudit() { Id = x.Id, ParentId = x.ParentId, MainFileId = x.MainFileId }).ToListAsync(); List allid = new List(); findChild(allid, inDto.Ids, data); if (inDto.IsAuthorization) { findParent(allid, inDto.Ids, data); } allid = allid.Distinct().ToList(); await _auditDocumentRepository.UpdatePartialFromQueryAsync(t => allid.Contains(t.Id), x => new AuditDocument() { IsAuthorization = inDto.IsAuthorization }); await _auditDocumentRepository.SaveChangesAsync(); return ResponseOutput.Ok(); void findParent(List allId, List current, List data) { allId.AddRange(current); var parent = data.Where(x => current.Contains(x.Id)).Select(x => x.ParentId).Where(x => x != null).Select(x => (Guid)x).ToList(); if (parent.Count() > 0) { findParent(allId, parent, data); } } void findChild(List allId, List current, List data) { allId.AddRange(current); var child = data.Where(x => (x.ParentId != null && current.Contains(x.ParentId.Value)) || (x.MainFileId != null && current.Contains(x.MainFileId.Value))).Select(x => x.Id).ToList(); if (child.Count() > 0) { findChild(allId, child, data); } } } }