KnowledgeController.cs 69 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522
  1. using DocumentFormat.OpenXml.Wordprocessing;
  2. using DotNetCore.CAP;
  3. using Hotline.Api.Filter;
  4. using Hotline.Application.Bulletin;
  5. using Hotline.Application.ExportExcel;
  6. using Hotline.Application.ExportWord;
  7. using Hotline.Application.FlowEngine;
  8. using Hotline.Application.Knowledge;
  9. using Hotline.Application.Systems;
  10. using Hotline.Application.Tools;
  11. using Hotline.File;
  12. using Hotline.FlowEngine.WorkflowModules;
  13. using Hotline.KnowledgeBase;
  14. using Hotline.KnowledgeBase.Notifies;
  15. using Hotline.Permissions;
  16. using Hotline.Repository.SqlSugar.Extensions;
  17. using Hotline.Repository.SqlSugar.Knowledge;
  18. using Hotline.Repository.SqlSugar.Ts;
  19. using Hotline.Settings;
  20. using Hotline.Settings.Hotspots;
  21. using Hotline.Share.Dtos;
  22. using Hotline.Share.Dtos.File;
  23. using Hotline.Share.Dtos.FlowEngine;
  24. using Hotline.Share.Dtos.Knowledge;
  25. using Hotline.Share.Dtos.Order;
  26. using Hotline.Share.Enums.Article;
  27. using Hotline.Share.Enums.KnowledgeBase;
  28. using Hotline.Share.Mq;
  29. using Hotline.Share.Tools;
  30. using Hotline.Users;
  31. using J2N.Text;
  32. using Mapster;
  33. using MapsterMapper;
  34. using MediatR;
  35. using Microsoft.AspNetCore.Mvc;
  36. using Microsoft.EntityFrameworkCore.Metadata.Internal;
  37. using Org.BouncyCastle.Utilities.IO;
  38. using SqlSugar;
  39. using System.Threading;
  40. using XF.Domain.Authentications;
  41. using XF.Domain.Exceptions;
  42. using XF.Domain.Repository;
  43. using XF.Utility.EnumExtensions;
  44. using static Microsoft.EntityFrameworkCore.DbLoggerCategory;
  45. namespace Hotline.Api.Controllers
  46. {
  47. public class KnowledgeController : BaseController
  48. {
  49. #region 注入
  50. private readonly IExportApplication _exportApplication;
  51. private readonly IRepository<KnowledgeHotWord> _knowledgeHotWordRepository;
  52. private readonly IRepository<KnowledgeWord> _knowledgeWordRepository;
  53. private readonly IWordHelperService _wordHelperService;
  54. private readonly BaseDataApplication _baseDataApplication;
  55. private readonly IKnowledgeRepository _knowledgeRepository;
  56. private readonly ISessionContext _sessionContext;
  57. private readonly IKnowledgeDomainService _knowledgeDomainService;
  58. private readonly IMapper _mapper;
  59. private readonly IKnowApplication _knowApplication;
  60. private readonly IMediator _mediator;
  61. private readonly IWorkflowApplication _workflowApplication;
  62. private readonly IKnowledgeWorkFlowRepository _knowledgeWorkFlowRepository;
  63. private readonly IRepository<User> _userRepository;
  64. private readonly IRepository<KnowledgeType> _knowledgeTypeRepository;
  65. private readonly IRepository<Hotspot> _hotspotTypeRepository;
  66. private readonly IRepositoryTextSearch<KnowledgeTs> _repositoryts;
  67. private readonly IRepository<KnowledgeWord> _knowledgeWrodRepository;
  68. private readonly IRepository<KnowledgeQuestions> _knowledgeQuestionsRepository;
  69. private readonly IRepository<KnowledgeCorrection> _knowledgeCorrectionRepository;
  70. private readonly IRepository<KnowledgeCollect> _knowledgeCollectRepository;
  71. private readonly ISystemDomainService _systemDomainService;
  72. private readonly IRepository<KnowledgeComment> _knowledgeCommentRepository;
  73. private readonly ISystemOrganizeRepository _systemOrganizeRepository;
  74. private readonly IFileRepository _fileRepository;
  75. private readonly ICapPublisher _capPublisher;
  76. private readonly IRepository<KnowledgeRelationType> _knowledgeRelationTypeRepository;
  77. private readonly IBulletinApplication _bulletinApplication;
  78. private readonly IRepository<KnowledgeCollectGroup> _knowledgeCollectGroupRepository;
  79. private readonly IRepository<KnowledgePv> _knowledgePvepository;
  80. public KnowledgeController(
  81. IKnowledgeRepository knowledgeRepository,
  82. ISessionContext sessionContext,
  83. IKnowledgeDomainService knowledgeDomainService,
  84. IMapper mapper,
  85. IKnowApplication knowApplication,
  86. IMediator mediator,
  87. IWorkflowApplication workflowApplication,
  88. IKnowledgeWorkFlowRepository knowledgeWorkFlowRepository,
  89. IRepository<User> userRepository,
  90. IRepository<KnowledgeType> knowledgeTypeRepository,
  91. IRepository<Hotspot> hotspotTypeRepository,
  92. IRepositoryTextSearch<KnowledgeTs> repositoryts,
  93. IRepository<KnowledgeWord> knowledgeWrodRepository,
  94. IRepository<KnowledgeQuestions> knowledgeQuestionsRepository,
  95. IRepository<KnowledgeCorrection> knowledgeCorrectionRepository,
  96. IRepository<KnowledgeCollect> knowledgeCollectRepository,
  97. ISystemDomainService systemDomainService,
  98. IRepository<KnowledgeComment> knowledgeCommentRepository,
  99. ISystemOrganizeRepository systemOrganizeRepository,
  100. IFileRepository fileRepository,
  101. ICapPublisher capPublisher,
  102. IRepository<KnowledgeRelationType> knowledgeRelationTypeRepository,
  103. IBulletinApplication bulletinApplication,
  104. IRepository<KnowledgeCollectGroup> knowledgeCollectGroupRepository,
  105. IExportApplication exportApplication,
  106. BaseDataApplication baseDataApplication,
  107. IWordHelperService wordHelperService,
  108. IRepository<KnowledgePv> knowledgePvepository,
  109. IRepository<KnowledgeWord> knowledgeWordRepository,
  110. IRepository<KnowledgeHotWord> knowledgeWordHotRepository,
  111. IRepository<KnowledgeHotWord> knowledgeHotWordRepository)
  112. {
  113. _knowledgeRepository = knowledgeRepository;
  114. _sessionContext = sessionContext;
  115. _knowledgeDomainService = knowledgeDomainService;
  116. _mapper = mapper;
  117. _knowApplication = knowApplication;
  118. _mediator = mediator;
  119. _workflowApplication = workflowApplication;
  120. _knowledgeWorkFlowRepository = knowledgeWorkFlowRepository;
  121. _userRepository = userRepository;
  122. _knowledgeTypeRepository = knowledgeTypeRepository;
  123. _hotspotTypeRepository = hotspotTypeRepository;
  124. _repositoryts = repositoryts;
  125. _knowledgeWrodRepository = knowledgeWrodRepository;
  126. _knowledgeQuestionsRepository = knowledgeQuestionsRepository;
  127. _knowledgeCorrectionRepository = knowledgeCorrectionRepository;
  128. _knowledgeCollectRepository = knowledgeCollectRepository;
  129. _systemDomainService = systemDomainService;
  130. _knowledgeCommentRepository = knowledgeCommentRepository;
  131. _systemOrganizeRepository = systemOrganizeRepository;
  132. _fileRepository = fileRepository;
  133. _capPublisher = capPublisher;
  134. _knowledgeRelationTypeRepository = knowledgeRelationTypeRepository;
  135. _bulletinApplication = bulletinApplication;
  136. _knowledgeCollectGroupRepository = knowledgeCollectGroupRepository;
  137. _exportApplication = exportApplication;
  138. _baseDataApplication = baseDataApplication;
  139. _wordHelperService = wordHelperService;
  140. _knowledgePvepository = knowledgePvepository;
  141. _knowledgeWordRepository = knowledgeWordRepository;
  142. _knowledgeHotWordRepository = knowledgeHotWordRepository;
  143. }
  144. #endregion
  145. #region 知识管理
  146. /// <summary>
  147. /// 知识库-新增
  148. /// </summary>
  149. /// <param name="dto"></param>
  150. /// <returns></returns>
  151. [Permission(EPermission.AddKnowledge)]
  152. [HttpPost("add")]
  153. [LogFilter("知识新增")]
  154. public async Task<string> AddKnowledge([FromBody] AddStartFlowDto dto)
  155. {
  156. //var addDto = _mapper.Map<AddKnowledgeDto>(dto.Data);
  157. var kn = _mapper.Map<Knowledge>(dto.Data);
  158. kn.SourceOrganizeId = _sessionContext.RequiredOrgId;
  159. var any = await _knowledgeRepository.Queryable().Where(x => x.Status == EKnowledgeStatus.OnShelf && x.Title == kn.Title).AnyAsync();
  160. if (any) throw UserFriendlyException.SameMessage("当前知识标题存在重复标题!");
  161. //Code为空,从新生成Code
  162. if (string.IsNullOrEmpty(kn.Code))
  163. kn.Code = Convert.ToInt64((DateTime.Now - new DateTime(1970, 1, 1, 0, 0, 0, 0)).TotalSeconds).ToString();
  164. kn.Status = EKnowledgeStatus.Drafts;
  165. kn.InitId();
  166. if (dto.Data.Files.Any()) kn.FileJson = await _fileRepository.AddFileAsync(dto.Data.Files, kn.Id, "", HttpContext.RequestAborted);
  167. await _knowledgeRepository.AddAsync(kn, HttpContext.RequestAborted);
  168. if (dto.Data.KnowledgeType.Any())
  169. {
  170. List<KnowledgeRelationType> types = _mapper.Map<List<KnowledgeRelationType>>(dto.Data.KnowledgeType);
  171. types.ForEach(x => x.KnowledgeId = kn.Id);
  172. await _knowledgeRelationTypeRepository.AddRangeAsync(types, HttpContext.RequestAborted);
  173. }
  174. if (dto.Workflow != null && !string.IsNullOrEmpty(kn.Id))
  175. {
  176. var startDto = _mapper.Map<StartWorkflowDto>(dto.Workflow);
  177. startDto.DefinitionModuleCode = WorkflowModuleConsts.KnowledgeAdd;
  178. startDto.Title = "知识库新增";
  179. //await _workflowApplication.StartWorkflowAsync(startDto, _sessionContext, kn.Id, cancellationToken: HttpContext.RequestAborted);
  180. await StartFlow(kn.Id, WorkflowModuleConsts.KnowledgeAdd, EKnowledgeApplyType.Add, startDto);
  181. //var knowledge = await _knowledgeRepository.GetAsync(kn.Id);
  182. //knowledge.Status = EKnowledgeStatus.Auditing;
  183. //await _knowledgeRepository.UpdateAsync(knowledge, HttpContext.RequestAborted);
  184. }
  185. return kn.Id;
  186. }
  187. /// <summary>
  188. /// 知识库-知识下架
  189. /// </summary>
  190. /// <param name="Id"></param>
  191. /// <returns></returns>
  192. [Permission(EPermission.KnowledgeOffShelf)]
  193. [HttpPut("offshelf")]
  194. [LogFilter("知识下架")]
  195. public async Task KnowledgeOffShelf(string Id)
  196. {
  197. var know = await _knowledgeRepository.GetAsync(Id, HttpContext.RequestAborted);
  198. if (know != null && know.Status == EKnowledgeStatus.OnShelf)
  199. {
  200. know.Status = EKnowledgeStatus.OffShelf;
  201. know.OnShelfTime = null;
  202. know.OffShelfTime = DateTime.Now;
  203. await _knowledgeRepository.UpdateAsync(know, HttpContext.RequestAborted);
  204. var pushKnowledge = _mapper.Map<KnowledgeSendDto>(know);
  205. pushKnowledge.CategoryCode = "01";
  206. pushKnowledge.CategoryName = "公共服务";
  207. //推省上
  208. await _capPublisher.PublishAsync(EventNames.HotlineKnowledgeRemove, pushKnowledge, cancellationToken: HttpContext.RequestAborted);
  209. }
  210. else
  211. throw UserFriendlyException.SameMessage("知识下架失败");
  212. }
  213. /// <summary>
  214. /// 知识库-知识上架
  215. /// </summary>
  216. /// <param name="Id"></param>
  217. /// <returns></returns>
  218. [Permission(EPermission.KnowledgeOnTheShelf)]
  219. [HttpPut("ontheshelf")]
  220. [LogFilter("知识上架")]
  221. public async Task KnowledgeOnTheShelf(string Id)
  222. {
  223. var know = await _knowledgeRepository.GetAsync(Id, HttpContext.RequestAborted);
  224. if (know != null && know.Status == EKnowledgeStatus.OffShelf)
  225. {
  226. var any = await _knowledgeRepository.Queryable().Where(x => x.Status == EKnowledgeStatus.OnShelf && x.Title == know.Title && x.Id != know.Id).AnyAsync();
  227. if (any) throw UserFriendlyException.SameMessage("当前知识标题存在重复标题!");
  228. if (know.ExpiredTime < DateTime.Now) throw UserFriendlyException.SameMessage("知识已过期不能上架!");
  229. know.Status = EKnowledgeStatus.OnShelf;
  230. know.OnShelfTime = DateTime.Now;
  231. know.OffShelfTime = null;
  232. await _knowledgeRepository.UpdateAsync(know, HttpContext.RequestAborted);
  233. }
  234. else
  235. throw UserFriendlyException.SameMessage("知识上架失败");
  236. }
  237. /// <summary>
  238. /// 知识库-标题
  239. /// </summary>
  240. /// <param name="title"></param>
  241. /// <returns></returns>
  242. [HttpGet("title")]
  243. public async Task<bool> KnowledgeTitle([FromQuery] KnowledgeTitleDto dto)
  244. {
  245. var count = await _knowledgeRepository.Queryable()
  246. .WhereIF(!string.IsNullOrEmpty(dto.Id), x => x.Id != dto.Id)
  247. .Where(x => x.Title == dto.Title && x.Status == EKnowledgeStatus.OnShelf).CountAsync();
  248. return count > 0;
  249. }
  250. /// <summary>
  251. /// 知识库-修改
  252. /// </summary>
  253. /// <param name="dto"></param>
  254. /// <returns></returns>
  255. [HttpPut("update")]
  256. [LogFilter("知识修改")]
  257. public async Task UpdateKnowledge([FromBody] UpdateStartFlowDto dto)
  258. {
  259. var update = _mapper.Map<UpdateKnowledgeDto>(dto.Data);
  260. var knowledge = await _knowledgeRepository.GetAsync(update.Id);
  261. if (knowledge == null)
  262. throw UserFriendlyException.SameMessage("知识库数据错误");
  263. if ((knowledge.Status == EKnowledgeStatus.OnShelf || knowledge.Status == EKnowledgeStatus.Auditing) && (knowledge.ExpiredTime.HasValue && knowledge.ExpiredTime.Value > DateTime.Now))
  264. throw UserFriendlyException.SameMessage("知识库数据不可修改");
  265. var any = await _knowledgeRepository.Queryable().Where(x => x.Status == EKnowledgeStatus.OnShelf && x.Title == update.Title && x.Id != update.Id).AnyAsync();
  266. if (any) throw UserFriendlyException.SameMessage("当前知识标题存在重复标题!");
  267. _mapper.Map(dto.Data, knowledge);
  268. //if (update.Tags.Any()) await _repositoryts.UpdateVectorAsync(update.Id, update.Tags, HttpContext.RequestAborted);
  269. if (dto.Data.Files.Any())
  270. knowledge.FileJson = await _fileRepository.AddFileAsync(dto.Data.Files, knowledge.Id, "", HttpContext.RequestAborted);
  271. else
  272. knowledge.FileJson = new List<Share.Dtos.File.FileJson>();
  273. if (dto.Workflow != null) knowledge.Renewaln = knowledge.Status != EKnowledgeStatus.Drafts;
  274. await _knowledgeRepository.UpdateAsync(knowledge, HttpContext.RequestAborted);
  275. if (dto.Data.KnowledgeType.Any())
  276. {
  277. var anyRelationTypes = await _knowledgeRelationTypeRepository.Queryable().Where(x => x.KnowledgeId == knowledge.Id).ToListAsync();
  278. if (anyRelationTypes.Any())
  279. await _knowledgeRelationTypeRepository.RemoveRangeAsync(anyRelationTypes);
  280. List<KnowledgeRelationType> types = _mapper.Map<List<KnowledgeRelationType>>(dto.Data.KnowledgeType);
  281. types.ForEach(x => x.KnowledgeId = update.Id);
  282. await _knowledgeRelationTypeRepository.AddRangeAsync(types, HttpContext.RequestAborted);
  283. }
  284. if (dto.Workflow != null)
  285. {
  286. if (knowledge.Status == EKnowledgeStatus.Drafts)
  287. {
  288. var startDto = _mapper.Map<StartWorkflowDto>(dto.Workflow);
  289. startDto.DefinitionModuleCode = WorkflowModuleConsts.KnowledgeAdd;
  290. startDto.Title = "知识库新增";
  291. //await _workflowApplication.StartWorkflowAsync(startDto, _sessionContext, knowledge.Id, cancellationToken: HttpContext.RequestAborted);
  292. await StartFlow(knowledge.Id, WorkflowModuleConsts.KnowledgeAdd, EKnowledgeApplyType.Add, startDto);
  293. }
  294. else
  295. {
  296. var startDto = _mapper.Map<StartWorkflowDto>(dto.Workflow);
  297. startDto.DefinitionModuleCode = WorkflowModuleConsts.KnowledgeUpdate;
  298. startDto.Title = "知识库修改";
  299. //await _workflowApplication.StartWorkflowAsync(startDto, _sessionContext, knowledge.Id, cancellationToken: HttpContext.RequestAborted);
  300. await StartFlow(knowledge.Id, WorkflowModuleConsts.KnowledgeUpdate, EKnowledgeApplyType.Update, startDto);
  301. }
  302. }
  303. }
  304. /// <summary>
  305. /// 批量审核
  306. /// </summary>
  307. /// <returns></returns>
  308. [HttpPost("batch_audit")]
  309. public async Task KnowledgeBatchAuditAsync()
  310. {
  311. // TODO: qcy 批量审核
  312. }
  313. /// <summary>
  314. /// 根据知识标题自动分词并保存到关键词表中
  315. /// </summary>
  316. /// <param name="title"></param>
  317. /// <returns></returns>
  318. [HttpGet("participle")]
  319. public async Task<IList<KnowledgeWordOutDto>> KnowledgeKeyWord([FromQuery] string title)
  320. {
  321. return await _knowApplication.TitleParticiple(title);
  322. }
  323. /// <summary>
  324. /// 删除知识
  325. /// </summary>
  326. /// <param name="id"></param>
  327. /// <returns></returns>
  328. [HttpDelete]
  329. [LogFilter("删除知识")]
  330. public async Task Remove([FromBody] DeleteStartFlowDto dto)
  331. {
  332. var delete = _mapper.Map<KnowledgeDto>(dto.Data);
  333. var knowledge = await _knowledgeRepository.GetAsync(delete.Id, HttpContext.RequestAborted);
  334. if (knowledge == null)
  335. throw UserFriendlyException.SameMessage("无效知识库数据");
  336. if (knowledge.Status == EKnowledgeStatus.OnShelf || knowledge.Status == EKnowledgeStatus.Auditing)
  337. throw UserFriendlyException.SameMessage("知识库数据不可删除");
  338. if (knowledge.Status == EKnowledgeStatus.Drafts)
  339. {
  340. await _knowledgeRepository.RemoveAsync(knowledge, false, HttpContext.RequestAborted);
  341. }
  342. else
  343. {
  344. var startDto = _mapper.Map<StartWorkflowDto>(dto.Workflow);
  345. startDto.DefinitionModuleCode = WorkflowModuleConsts.KnowledgeDelete;
  346. startDto.Title = "知识库删除";
  347. //await _workflowApplication.StartWorkflowAsync(startDto, _sessionContext, knowledge.Id, cancellationToken: HttpContext.RequestAborted);
  348. await StartFlow(delete.Id, WorkflowModuleConsts.KnowledgeDelete, EKnowledgeApplyType.Delete, startDto);
  349. }
  350. }
  351. /// <summary>
  352. /// 增加搜索量
  353. /// </summary>
  354. /// <param name="dto"></param>
  355. /// <returns></returns>
  356. [HttpPost("search_num")]
  357. [LogFilter("知识搜索")]
  358. public async Task SearchNum([FromBody] KnowledgeSearchNumDto dto)
  359. {
  360. var knowledge = await _knowledgeRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  361. if (knowledge == null)
  362. throw UserFriendlyException.SameMessage("无效知识库数据");
  363. knowledge.SearchNum++;
  364. await _knowledgeRepository.UpdateAsync(knowledge, HttpContext.RequestAborted);
  365. }
  366. /// <summary>
  367. /// 搜索量列表
  368. /// </summary>
  369. /// <param name="dto"></param>
  370. /// <returns></returns>
  371. [HttpGet("search_num/list")]
  372. public async Task<PagedDto<KnowledgeDto>> SearchNumList([FromQuery] KnowledgeCollectListDto dto)
  373. {
  374. var query = _knowledgeRepository.Queryable(false, true, false)
  375. .Where(x => x.Status == EKnowledgeStatus.OnShelf)
  376. .Where(m => m.IsDeleted == false)
  377. .Where(x => (x.ExpiredTime != null && x.ExpiredTime >= DateTime.Now) || x.ExpiredTime == null)
  378. .OrderByDescending(x => x.SearchNum);
  379. if (_sessionContext.OrgIsCenter == false)
  380. {
  381. query = query.Where(m => m.KnowledgeType.Any(a => a.IsDeleted == false && a.KnowledgeType.KnowledgeTypeOrgs
  382. .Any(k => k.IsDeleted == false && k.OrgId.StartsWith(_sessionContext.OrgId))));
  383. query = query.Where(m => m.Attribution == "部门知识库");
  384. }
  385. var (total, items) = await query.ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  386. return new PagedDto<KnowledgeDto>(total, _mapper.Map<IReadOnlyList<KnowledgeDto>>(items));
  387. }
  388. /// <summary>
  389. /// 知识库-知识修改-查询详情
  390. /// </summary>
  391. /// <param name="Id"></param>
  392. /// <returns></returns>
  393. [HttpGet("updateinfo/{Id}")]
  394. public async Task<KnowledgeInfoDto> KnowledgeUpdateInfo(string Id)
  395. {
  396. //var know = await _knowledgeRepository.GetAsync(Id, HttpContext.RequestAborted);
  397. var know = await _knowledgeDomainService.KnowledgeInfo(Id, HttpContext.RequestAborted);
  398. if (know is null)
  399. throw UserFriendlyException.SameMessage("知识查询失败!");
  400. var knowledgeInfoDto = _mapper.Map<KnowledgeInfoDto>(know);
  401. if (knowledgeInfoDto != null && !string.IsNullOrEmpty(knowledgeInfoDto.Content))
  402. knowledgeInfoDto.Content = _bulletinApplication.GetSiteUrls(knowledgeInfoDto.Content);
  403. //分类
  404. //var type = await _knowledgeTypeRepository.GetAsync(know.KnowledgeTypeId, HttpContext.RequestAborted);
  405. //if (type != null)
  406. // knowledgeInfoDto.KnowledgeTypeName = type.SpliceName;
  407. //热点
  408. var hot = await _hotspotTypeRepository.GetAsync(know.HotspotId, HttpContext.RequestAborted);
  409. if (hot != null)
  410. knowledgeInfoDto.HotspotName = hot.HotSpotFullName;
  411. //收藏
  412. var collect = await _knowledgeCollectRepository.GetAsync(x => x.KnowledgeId == Id && x.CreatorId == _sessionContext.UserId);
  413. if (collect != null)
  414. knowledgeInfoDto.Collect = _mapper.Map<KnowledgeCollectDto>(collect);
  415. return knowledgeInfoDto;
  416. }
  417. /// <summary>
  418. /// 知识库-查询详情-增加浏览量
  419. /// </summary>
  420. /// <param name="Id">知识Id</param>
  421. /// <param name="IsAddPv">默认不增加,false不增加,true增加浏览量</param>
  422. /// <returns></returns>
  423. [HttpGet("info/{Id}")]
  424. public async Task<KnowledgeInfoDto> KnowledgeInfo(string Id, bool? IsAddPv)
  425. {
  426. var knowledge = await _knowledgeDomainService.KnowledgeInfo(Id, HttpContext.RequestAborted);
  427. if (knowledge is null)
  428. throw UserFriendlyException.SameMessage("知识查询失败!");
  429. if (knowledge.Workflow != null)
  430. knowledge.IsCanHandle = knowledge.Workflow.IsCanHandle(_sessionContext.RequiredUserId, _sessionContext.RequiredOrgId, _sessionContext.Roles);
  431. //转化
  432. var knowledgeShowInfoDto = _mapper.Map<KnowledgeInfoDto>(knowledge);
  433. if (knowledgeShowInfoDto != null && !string.IsNullOrEmpty(knowledgeShowInfoDto.Content))
  434. knowledgeShowInfoDto.Content = _bulletinApplication.GetSiteUrls(knowledgeShowInfoDto.Content);
  435. //var type = await _knowledgeTypeRepository.GetAsync(knowledge.KnowledgeTypeId, HttpContext.RequestAborted);
  436. //if (type != null)
  437. //{
  438. // knowledgeShowInfoDto.KnowledgeTypeName = type.SpliceName;
  439. // knowledgeShowInfoDto.KnowledgeType = _mapper.Map<KnowledgeTypeDto>(type);
  440. //}
  441. var hot = await _hotspotTypeRepository.GetAsync(knowledge.HotspotId, HttpContext.RequestAborted);
  442. if (hot != null)
  443. knowledgeShowInfoDto.HotspotName = hot.HotSpotFullName;
  444. //收藏
  445. var collect = await _knowledgeCollectRepository.GetAsync(x => x.KnowledgeId == Id && x.CreatorId == _sessionContext.UserId);
  446. if (collect != null)
  447. knowledgeShowInfoDto.Collect = _mapper.Map<KnowledgeCollectDto>(collect);
  448. //关联知识
  449. var knowledges = await _knowledgeRepository.Queryable().In(x => x.Id, knowledge.Knowledges).Where(x => x.Status == EKnowledgeStatus.OnShelf && ((x.ExpiredTime != null && x.ExpiredTime >= DateTime.Now) || x.ExpiredTime == null)).ToListAsync();
  450. if (knowledges.Any())
  451. knowledgeShowInfoDto.KnowledgeDtos = _mapper.Map<List<KnowledgeDto>>(knowledges);
  452. //关键词
  453. var knowledgeWords = await _knowledgeWrodRepository.Queryable().In(x => x.Id, knowledge.Keywords).ToListAsync();
  454. if (knowledgeWords.Any())
  455. knowledgeShowInfoDto.KeywordsDto = _mapper.Map<List<KnowledgeWordDto>>(knowledgeWords);
  456. if (knowledgeShowInfoDto.FileJson != null && knowledgeShowInfoDto.FileJson.Any())
  457. {
  458. var ids = knowledgeShowInfoDto.FileJson.Select(x => x.Id).ToList();
  459. knowledgeShowInfoDto.Files = await _fileRepository.GetFilesAsync(ids, HttpContext.RequestAborted);
  460. }
  461. //var files = await _fileRepository.Queryable().Where(x => x.Key == knowledge.Id).ToListAsync();
  462. // if (files.Any()) knowledgeShowInfoDto.Files = _mapper.Map<List<FileDto>>(files);
  463. if (IsAddPv == true)
  464. _mediator.Publish(new GetKnowledgeInfoNotify(knowledge));
  465. return knowledgeShowInfoDto;
  466. }
  467. /// <summary>
  468. /// 知识详情--导出
  469. /// </summary>
  470. /// <param name="dto"></param>
  471. /// <returns></returns>
  472. [HttpPost("info/export")]
  473. public async Task<IActionResult> KnowledgeInfoExport([FromBody] KnowledgeInfoExportInDto dto)
  474. {
  475. if (dto.Ids.Length > 1)
  476. {
  477. var streams = await _knowApplication.KnowledgeInfoListExportAsync(dto, HttpContext.RequestAborted);
  478. byte[] fileBytes = _wordHelperService.ConvertZipStream(streams);
  479. var name = DateTime.Now.ToString("yyyyMMddHHmmss");
  480. return File(fileBytes, "application/octet-stream", $"{name}.zip");
  481. }
  482. var info = await _knowledgeRepository.GetAsync(dto.Ids[0]) ?? throw UserFriendlyException.SameMessage("知识不存在");
  483. return info.Content.HtmlToStream(dto.FileType).GetFileStreamResult(dto.FileType, info.Title, false);
  484. }
  485. /// <summary>
  486. /// 知识申请-关联知识-获取知识列表
  487. /// </summary>
  488. /// <returns></returns>
  489. [HttpGet("getknowledge")]
  490. public async Task<IReadOnlyList<KnowledgeCreateBMDataDto>> GetKnowledge()
  491. {
  492. var temp = await _knowledgeRepository
  493. .Queryable()
  494. .LeftJoin<SystemOrganize>((o, sys) => o.CreatorOrgId == sys.Id)
  495. //重新构建数据
  496. .Select((o, sys) => new
  497. {
  498. index = SqlFunc.RowNumber($"{o.Version} desc ", $"{o.Code}"),
  499. DepartmentId = sys.Id,
  500. Department = sys.Name,
  501. o.Id,
  502. o.Title,
  503. o.Status,
  504. o.Code,
  505. o.IsDeleted,
  506. o.ExpiredTime
  507. })
  508. //将结果合并成一个表
  509. .MergeTable()
  510. //取第一条数据
  511. .Where(x => x.IsDeleted == false)
  512. .Where(x => (x.ExpiredTime != null && x.ExpiredTime >= DateTime.Now) || x.ExpiredTime == null)
  513. .Where(d => d.index == 1 && d.Status == EKnowledgeStatus.OnShelf)
  514. .ToListAsync();
  515. //返回数据
  516. return _mapper.Map<IReadOnlyList<KnowledgeCreateBMDataDto>>(temp);
  517. }
  518. /// <summary>
  519. /// 我的草稿箱
  520. /// </summary>
  521. /// <param name="pagedDto"></param>
  522. /// <returns></returns>
  523. [HttpGet("mydraftslist")]
  524. public async Task<PagedDto<KnowledgeDataDto>> MyDraftsList([FromQuery] MyDraftsListPagedDto pagedDto)
  525. {
  526. var (total, items) = await _knowledgeRepository
  527. .Queryable()
  528. .Includes(it => it.User)
  529. .Where(p => p.CreatorId == _sessionContext.RequiredUserId && p.Status == EKnowledgeStatus.Drafts)
  530. .WhereIF(!string.IsNullOrEmpty(pagedDto.Keyword), d => d.Title.Contains(pagedDto.Keyword!))
  531. .WhereIF(pagedDto.StartTime != null, d => d.CreationTime >= pagedDto.StartTime)
  532. .WhereIF(pagedDto.EndTime != null, d => d.CreationTime <= pagedDto.EndTime)
  533. .OrderByDescending(p => p.CreationTime)
  534. .ToPagedListAsync(pagedDto.PageIndex, pagedDto.PageSize, HttpContext.RequestAborted);
  535. return new PagedDto<KnowledgeDataDto>(total, _mapper.Map<IReadOnlyList<KnowledgeDataDto>>(items));
  536. }
  537. /// <summary>
  538. /// 知识库列表页面枚举值
  539. /// </summary>
  540. /// <returns></returns>
  541. [HttpGet("knowledge-status-data")]
  542. public async Task<Dictionary<string, dynamic>> KnowledgeStatus()
  543. {
  544. var tabNames = new List<KeyValuePair<int, string>>
  545. {
  546. new KeyValuePair<int, string>(3, "已上架"),
  547. new KeyValuePair<int, string>(4, "已下架"),
  548. new KeyValuePair<int, string>(1, "审核中"),
  549. new KeyValuePair<int, string>(5, "审核不通过")
  550. };
  551. return _baseDataApplication
  552. .FileType(EFileType.excel | EFileType.pdf)
  553. .Add("tabNames", tabNames)
  554. .Build();
  555. }
  556. /// <summary>
  557. /// 知识查询
  558. /// </summary>
  559. /// <param name="pagedDto"></param>
  560. /// <returns></returns>
  561. [HttpGet]
  562. public async Task<PagedDto<KnowledgeDataDto>> GetKnowList([FromQuery] KnowPagedListDto pagedDto)
  563. {
  564. return (await _knowApplication.GetKnowList(pagedDto, HttpContext.RequestAborted))
  565. .ToPaged();
  566. }
  567. /// <summary>
  568. /// 知识查询-导出
  569. /// </summary>
  570. /// <param name="dto"></param>
  571. /// <returns></returns>
  572. [HttpPost("export")]
  573. public async Task<IActionResult> GetKnowListExportAsync([FromBody] ExportExcelDto<KnowPagedListDto> dto)
  574. {
  575. var items = (await _knowApplication.GetKnowList(dto.QueryDto, HttpContext.RequestAborted)).Item2;
  576. return _exportApplication.GetExcelFile(dto, items, "知识明细导出");
  577. }
  578. /// <summary>
  579. /// 来电弹窗知识检索
  580. /// </summary>
  581. /// <param name="dto"></param>
  582. /// <returns></returns>
  583. [HttpPost("knowretrieval")]
  584. public async Task<PagedDto<KnowledgeRetrievalDataDto>> KnowRetrievalWindow([FromBody] KnowledgeRetrievalPagedListDto dto)
  585. {
  586. return (await _knowApplication.KnowRetrievalAsync(dto)).ToPaged();
  587. }
  588. /// <summary>
  589. /// 知识检索
  590. /// </summary>
  591. /// <param name="dto"></param>
  592. /// <returns></returns>
  593. [HttpGet("knowretrieval")]
  594. public async Task<PagedDto<KnowledgeRetrievalDataDto>> KnowRetrieval([FromQuery] KnowledgeRetrievalPagedListDto dto)
  595. {
  596. return (await _knowApplication.KnowRetrievalAsync(dto)).ToPaged();
  597. }
  598. /// <summary>
  599. /// 知识检索页面基础数据
  600. /// </summary>
  601. /// <returns></returns>
  602. [HttpGet("knowretrieval/base_data")]
  603. public async Task<Dictionary<string, dynamic>> GetKnowretrievalBaseData()
  604. {
  605. return _baseDataApplication
  606. .KnowledgeRetrievalType(new[]{3, 4})
  607. .Build();
  608. }
  609. /// <summary>
  610. /// 获取知识审批信息
  611. /// </summary>
  612. /// <param name="id"></param>
  613. /// <returns></returns>
  614. [HttpGet("audit_log")]
  615. public async Task<PagedDto<KnowledgeWorkFlowDto>> KnowRetrieval([FromQuery] AuditLogListPagedDto pagedDto)
  616. {
  617. var (total, temp) = await _knowledgeWorkFlowRepository
  618. .Queryable()
  619. .Includes(x => x.User)
  620. .Includes(x => x.SystemOrganize)
  621. .Includes(x => x.Workflow)
  622. .Where(x => x.KnowledgeId == pagedDto.id)
  623. .Where(x => x.IsDeleted == false)
  624. .OrderBy(x => x.CreationTime)
  625. .ToPagedListAsync(pagedDto.PageIndex, pagedDto.PageSize);
  626. return new PagedDto<KnowledgeWorkFlowDto>(total, _mapper.Map<IReadOnlyList<KnowledgeWorkFlowDto>>(temp));
  627. }
  628. /// <summary>
  629. /// 知识查重
  630. /// </summary>
  631. /// <param name="id"></param>
  632. /// <returns></returns>
  633. [HttpPost("finding_duplicate")]
  634. public async Task<bool> FindingDuplicate([FromBody] KnowledgeFindingDuplicateDto dto)
  635. {
  636. var any = await _knowledgeRepository.Queryable().Where(x => x.Status == EKnowledgeStatus.Auditing || x.Status >= EKnowledgeStatus.OnShelf)
  637. .WhereIF(!string.IsNullOrEmpty(dto.Title), x => x.Title.Equals(dto.Title))
  638. .WhereIF(!string.IsNullOrEmpty(dto.Summary), x => x.Summary.Equals(dto.Summary))
  639. .WhereIF(!string.IsNullOrEmpty(dto.Content), x => x.Content.Equals(dto.Content))
  640. .WhereIF(!string.IsNullOrEmpty(dto.Id), x => x.Id != dto.Id)
  641. .AnyAsync();
  642. return any;
  643. }
  644. #endregion
  645. #region 我的知识删除列表
  646. /// <summary>
  647. /// 我的知识删除列表页面枚举值
  648. /// </summary>
  649. /// <returns></returns>
  650. [HttpGet("delete-status-data")]
  651. public async Task<object> DeleteApplyStatus()
  652. {
  653. return EnumExts.GetDescriptions<EKnowledgeWorkFlowStatus>();
  654. }
  655. /// <summary>
  656. /// 我的知识删除列表
  657. /// </summary>
  658. /// <param name="pagedDto"></param>
  659. /// <returns></returns>
  660. [HttpGet("deletelist")]
  661. public async Task<PagedDto<KnowledgeDeleteApplyDataDto>> GetDeleteApplyList([FromQuery] KnowledgeDeletelPagedListDto pagedDto)
  662. {
  663. var (total, items) = await _knowledgeWorkFlowRepository
  664. .Queryable(includeDeleted: true)
  665. .Includes(it => it.Knowledge)
  666. .Includes(it => it.User)
  667. .Includes(it => it.SystemOrganize)
  668. .Includes(it => it.Knowledge, it => it.KnowledgeType)
  669. .Includes(it => it.Knowledge, it => it.HotspotType)
  670. .Includes(it => it.Workflow)
  671. .Where(d => d.CreatorId == _sessionContext.RequiredUserId && d.WorkflowModuleStatus == EKnowledgeApplyType.Delete && d.WorkflowId != null)
  672. .WhereIF(pagedDto.EKnowledgeWorkFlowStatus.HasValue, d => d.WorkFlowApplyStatus == pagedDto.EKnowledgeWorkFlowStatus)
  673. .WhereIF(pagedDto.StartApplyTime.HasValue, d => d.CreationTime >= pagedDto.StartApplyTime)
  674. .WhereIF(pagedDto.EndApplyTime.HasValue, d => d.CreationTime <= pagedDto.EndApplyTime)
  675. .WhereIF(!string.IsNullOrEmpty(pagedDto.Keyword), d => d.Knowledge.User.Name.Contains(pagedDto.Keyword!)
  676. || d.Knowledge.SystemOrganize.Name.Contains(pagedDto.Keyword!)
  677. || d.Knowledge.Title.Contains(pagedDto.Keyword!))
  678. .OrderByDescending(p => p.CreationTime)
  679. .ToPagedListAsync(pagedDto.PageIndex, pagedDto.PageSize, HttpContext.RequestAborted);
  680. return new PagedDto<KnowledgeDeleteApplyDataDto>(total, _mapper.Map<IReadOnlyList<KnowledgeDeleteApplyDataDto>>(items));
  681. }
  682. /// <summary>
  683. /// 审核管理页面枚举值
  684. /// </summary>
  685. /// <returns></returns>
  686. [HttpGet("approval-base-data")]
  687. public async Task<object> ApprovalBaseData()
  688. {
  689. return new
  690. {
  691. EKnowledgeWorkFlowStatus = EnumExts.GetDescriptions<EKnowledgeWorkFlowStatus>(),
  692. EKnowledgeApplyType = EnumExts.GetDescriptions<EKnowledgeApplyType>()
  693. };
  694. }
  695. /// <summary>
  696. /// 审核管理
  697. /// </summary>
  698. /// <param name="pagedDto"></param>
  699. /// <returns></returns>
  700. [HttpGet("approvedlist")]
  701. public async Task<PagedDto<KnowledgeApprovalDataDto>> ApprovedList([FromQuery] KnowledgeApprovalPagedListDto pagedDto)
  702. {
  703. var (total, items) = await _knowledgeWorkFlowRepository
  704. .Queryable(includeDeleted: true)
  705. .Includes(it => it.Knowledge)
  706. .Includes(it => it.User)
  707. .Includes(it => it.SystemOrganize)
  708. .Includes(it => it.Workflow, d => d.Steps)
  709. .Where(it => it.WorkflowId != null)
  710. .WhereIF(pagedDto.EKnowledgeApplyType.HasValue, d => d.WorkflowModuleStatus == pagedDto.EKnowledgeApplyType)
  711. .WhereIF(pagedDto.EKnowledgeWorkFlowStatus.HasValue, d => d.WorkFlowApplyStatus == pagedDto.EKnowledgeWorkFlowStatus)
  712. .WhereIF(!string.IsNullOrEmpty(pagedDto.Keyword), d => d.Knowledge.User.Name.Contains(pagedDto.Keyword!)
  713. || d.Knowledge.SystemOrganize.Name.Contains(pagedDto.Keyword!)
  714. || d.Knowledge.Title.Contains(pagedDto.Keyword!))
  715. .OrderByDescending(p => p.CreationTime)
  716. .ToPagedListAsync(pagedDto.PageIndex, pagedDto.PageSize, HttpContext.RequestAborted);
  717. foreach (var item in items)
  718. {
  719. if (item.Workflow != null)
  720. //item.CanHandle = item.CanHandle(_sessionContext.RequiredUserId, _sessionContext.RequiredOrgId);
  721. item.CanHandle = item.Workflow.IsCanHandle(
  722. _sessionContext.RequiredUserId, _sessionContext.RequiredOrgId, _sessionContext.Roles);
  723. }
  724. //处理是否可以办理
  725. //items.ForEach(d => d.CanHandle = d.Workflow.CanHandle(_sessionContext.RequiredUserId, _sessionContext.RequiredOrgCode));
  726. return new PagedDto<KnowledgeApprovalDataDto>(total, _mapper.Map<IReadOnlyList<KnowledgeApprovalDataDto>>(items));
  727. }
  728. /// <summary>
  729. /// 工单受理知识检索
  730. /// </summary>
  731. /// <param name="pagedDto"></param>
  732. /// <returns></returns>
  733. [HttpGet("knowpopscreen")]
  734. public async Task<PagedDto<KnowledgeRetrievalDataDto>> KnowPopScreen([FromQuery] KnowledgePopScreenPagedListDto pagedDto)
  735. {
  736. var orgid = string.Empty;
  737. if (pagedDto.RetrievalType == EKnowledgeRetrievalType.Org && !string.IsNullOrEmpty(pagedDto.Keyword))
  738. {
  739. var organize = await _systemOrganizeRepository.GetAsync(x => x.Name == pagedDto.Keyword);
  740. orgid = organize?.Id;
  741. }
  742. var (total, temp) = await _knowledgeRepository.Queryable()
  743. .Includes(x => x.SourceOrganize)
  744. .Where(d => d.Status == EKnowledgeStatus.OnShelf)
  745. .WhereIF(pagedDto.RetrievalType == EKnowledgeRetrievalType.Title && !string.IsNullOrEmpty(pagedDto.Keyword), d => d.Title.Contains(pagedDto.Keyword!))
  746. .WhereIF(pagedDto.RetrievalType == EKnowledgeRetrievalType.Content && !string.IsNullOrEmpty(pagedDto.Keyword), d => d.Content.Contains(pagedDto.Keyword!))
  747. .WhereIF(!string.IsNullOrEmpty(orgid) && pagedDto.RetrievalType == EKnowledgeRetrievalType.Org, x => x.CreatorOrgId.EndsWith(orgid!))
  748. .WhereIF(!string.IsNullOrEmpty(pagedDto.HotspotId), p => p.HotspotId == pagedDto.HotspotId)
  749. .OrderByDescending(p => p.CreationTime)
  750. .ToPagedListAsync(pagedDto.PageIndex, pagedDto.PageSize);
  751. return new PagedDto<KnowledgeRetrievalDataDto>(total, _mapper.Map<IReadOnlyList<KnowledgeRetrievalDataDto>>(temp));
  752. }
  753. ///// <summary>
  754. ///// 新增-开始流程
  755. ///// </summary>
  756. ///// <param name="id">知识id</param>
  757. ///// <param name="dto">流程开启参数</param>
  758. ///// <returns></returns>
  759. //[Permission(EPermission.AddKnowledge)]
  760. //[HttpPost("{id}/add-startflow")]
  761. //public async Task AddStartFlow(string id, [FromBody] StartWorkflowDto dto)
  762. //{
  763. // await StartFlow(id, WorkflowModuleConsts.KnowledgeAdd, EKnowledgeApplyType.Add, dto);
  764. //}
  765. ///// <summary>
  766. ///// 删除-开始流程
  767. ///// </summary>
  768. ///// <param name="id">知识id</param>
  769. ///// <param name="dto">流程开启参数</param>
  770. ///// <returns></returns>
  771. //[Permission(EPermission.KnowledgeDelete)]
  772. //[HttpPost("{id}/remove-startflow")]
  773. //public async Task RemoveStartFlow(string id, [FromBody] StartWorkflowDto dto)
  774. //{
  775. // await StartFlow(id, WorkflowModuleConsts.KnowledgeDelete, EKnowledgeApplyType.Delete, dto);
  776. //}
  777. /// <summary>
  778. /// 查询知识库办理流程开启参数-新增
  779. /// </summary>
  780. /// <returns></returns>
  781. //[Permission(EPermission.AddKnowledge)]
  782. [HttpGet("add-flow-start")]
  783. public async Task<NextStepsDto> GetAddFlowStartOptionsAsync()
  784. {
  785. return await _workflowApplication.GetStartStepsAsync(WorkflowModuleConsts.KnowledgeAdd,
  786. HttpContext.RequestAborted);
  787. }
  788. /// <summary>
  789. /// 查询知识库办理流程开启参数-新增
  790. /// </summary>
  791. /// <returns></returns>
  792. //[Permission(EPermission.AddKnowledge)]
  793. [HttpGet("update-flow-start")]
  794. public async Task<NextStepsDto> GetUpdateFlowStartOptionsAsync()
  795. {
  796. return await _workflowApplication.GetStartStepsAsync(WorkflowModuleConsts.KnowledgeUpdate,
  797. HttpContext.RequestAborted);
  798. }
  799. /// <summary>
  800. /// 查询知识库办理流程开启参数-删除
  801. /// </summary>
  802. /// <returns></returns>
  803. //[Permission(EPermission.KnowledgeDelete)]
  804. [HttpGet("remove-flow-start")]
  805. public async Task<NextStepsDto> GetRemoveFlowStartOptionsAsync()
  806. {
  807. return await _workflowApplication.GetStartStepsAsync(WorkflowModuleConsts.KnowledgeDelete,
  808. HttpContext.RequestAborted);
  809. }
  810. /// <summary>
  811. /// 开始流程
  812. /// </summary>
  813. /// <param name="id">知识ID</param>
  814. /// <param name="moduleCode">知识模板编号</param>
  815. /// <param name="eKnowledgeApplyType">申请类型</param>
  816. /// <param name="dto">流程开启参数</param>
  817. /// <returns></returns>
  818. private async Task<string> StartFlow(string id, string moduleCode, EKnowledgeApplyType eKnowledgeApplyType, StartWorkflowDto dto)
  819. {
  820. var knowledge = await _knowledgeRepository.GetAsync(id, HttpContext.RequestAborted);
  821. if (knowledge == null)
  822. throw UserFriendlyException.SameMessage("无效知识编号");
  823. if (eKnowledgeApplyType == EKnowledgeApplyType.Delete)
  824. {
  825. if (knowledge.IsDeleted == true)
  826. throw UserFriendlyException.SameMessage("知识删除失败");
  827. }
  828. //知识审批主表
  829. await _knowledgeDomainService.AddWorkFlowAsync(id, eKnowledgeApplyType, HttpContext.RequestAborted);
  830. dto.DefinitionModuleCode = moduleCode;
  831. dto.Title = knowledge.Title;
  832. return await _workflowApplication.StartWorkflowAsync(dto, id, cancellationToken: HttpContext.RequestAborted);
  833. }
  834. #endregion
  835. #region 知识库词库
  836. /// <summary>
  837. /// 新增知识库词库
  838. /// </summary>
  839. /// <param name="dtos"></param>
  840. /// <returns></returns>
  841. [Permission(EPermission.AddKnowledgeWord)]
  842. [HttpPost("knowledge_word")]
  843. [LogFilter("新增知识库词库")]
  844. public async Task Add([FromBody] KnowledgeWordAddDto dto)
  845. {
  846. var word = _mapper.Map<KnowledgeWord>(dto);
  847. await _knowledgeWrodRepository.AddAsync(word, HttpContext.RequestAborted);
  848. }
  849. /// <summary>
  850. /// 删除知识库词库
  851. /// </summary>
  852. /// <param name="dto"></param>
  853. /// <returns></returns>
  854. [Permission(EPermission.DeleteKnowledgeWord)]
  855. [HttpDelete("knowledge_word")]
  856. [LogFilter("删除知识库词库")]
  857. public async Task Delete([FromBody] KnowledgeWordDeleteDto dto)
  858. {
  859. await _knowledgeRepository.RemoveKnowledgeWrodBatchAsync(dto.Ids, HttpContext.RequestAborted);
  860. }
  861. /// <summary>
  862. /// 更新知识库词库
  863. /// </summary>
  864. /// <param name="dto"></param>
  865. /// <returns></returns>
  866. [Permission(EPermission.UpdateKnowledgeWord)]
  867. [HttpPut("knowledge_word")]
  868. [LogFilter("更新知识库词库")]
  869. public async Task Update([FromBody] KnowledgeWordUpdateDto dto)
  870. {
  871. var word = await _knowledgeWrodRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  872. if (word is null)
  873. throw UserFriendlyException.SameMessage("无效知识库词库");
  874. _mapper.Map(dto, word);
  875. word.LastModificationName = _sessionContext.UserName;
  876. await _knowledgeWrodRepository.UpdateAsync(word, HttpContext.RequestAborted);
  877. }
  878. /// <summary>
  879. /// 获取知识库词库列表
  880. /// </summary>
  881. /// <param name="dto"></param>
  882. /// <returns></returns>
  883. [HttpGet("knowledge_word/list")]
  884. public async Task<PagedDto<KnowledgeWordDto>> List([FromQuery] KnowledgeWordListDto dto)
  885. {
  886. var (total, items) = await _knowledgeWrodRepository.Queryable()
  887. .WhereIF(!string.IsNullOrEmpty(dto.Tag), x => x.Tag == dto.Tag!)
  888. .WhereIF(!string.IsNullOrEmpty(dto.Classify), x => x.Classify == dto.Classify!)
  889. .WhereIF(dto.IsEnable.HasValue, x => x.IsEnable == dto.IsEnable)
  890. .WhereIF(!string.IsNullOrEmpty(dto.Synonym), x => x.Synonym != null && x.Synonym.Contains(dto.Synonym!))
  891. .OrderByDescending(x => x.CreationTime)
  892. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  893. return new PagedDto<KnowledgeWordDto>(total, _mapper.Map<IReadOnlyList<KnowledgeWordDto>>(items));
  894. }
  895. /// <summary>
  896. /// 获取知识库词库
  897. /// </summary>
  898. /// <param name="id"></param>
  899. /// <returns></returns>
  900. [HttpGet("knowledge_word/{id}")]
  901. public async Task<KnowledgeWord> WordEntity(string id)
  902. {
  903. return await _knowledgeWrodRepository.Queryable()
  904. .FirstAsync(x => x.Id == id);
  905. }
  906. /// <summary>
  907. /// 获取知识库词库基本信息
  908. /// </summary>
  909. /// <returns></returns>
  910. [HttpGet("knowledge_word/base")]
  911. public async Task<object> Base()
  912. {
  913. var rsp = new
  914. {
  915. KnowledgeWordClassify = await _systemDomainService.GetSysDicDataByCodeAsync(SysDicTypeConsts.KnowledgeWordClassify),
  916. };
  917. return rsp;
  918. }
  919. #endregion
  920. #region 知识纠错
  921. /// <summary>
  922. /// 新增知识纠错
  923. /// </summary>
  924. /// <param name="dtos"></param>
  925. /// <returns></returns>
  926. //[Permission(EPermission.AddKnowledgeCorrection)]
  927. [HttpPost("knowledge_correction")]
  928. [LogFilter("新增知识纠错")]
  929. public async Task Add([FromBody] KnowledgeCorrectionAddDto dto)
  930. {
  931. var correction = _mapper.Map<KnowledgeCorrection>(dto);
  932. await _knowledgeCorrectionRepository.AddAsync(correction, HttpContext.RequestAborted);
  933. }
  934. /// <summary>
  935. /// 删除知识纠错
  936. /// </summary>
  937. /// <param name="dto"></param>
  938. /// <returns></returns>
  939. //[Permission(EPermission.DeleteKnowledgeCorrection)]
  940. //[HttpDelete("knowledge_correction")]
  941. //public async Task Delete([FromBody] KnowledgeCorrectionDeleteDto dto)
  942. //{
  943. // await _knowledgeCorrectionRepository.RemoveAsync(x => x.Id == dto.Id);
  944. //}
  945. /// <summary>
  946. /// 更新知识纠错
  947. /// </summary>
  948. /// <param name="dto"></param>
  949. /// <returns></returns>
  950. //[Permission(EPermission.UpdateKnowledgeCorrection)]
  951. //[HttpPut("knowledge_correction")]
  952. //public async Task Update([FromBody] KnowledgeCorrectionUpdateDto dto)
  953. //{
  954. // var correction = await _knowledgeCorrectionRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  955. // if (correction is null)
  956. // throw UserFriendlyException.SameMessage("无效知识纠错");
  957. // _mapper.Map(dto, correction);
  958. // await _knowledgeCorrectionRepository.UpdateAsync(correction, HttpContext.RequestAborted);
  959. //}
  960. /// <summary>
  961. /// 答复知识纠错
  962. /// </summary>
  963. /// <param name="dto"></param>
  964. /// <returns></returns>
  965. [Permission(EPermission.ReplyKnowledgeCorrection)]
  966. [HttpPut("knowledge_correction/Reply")]
  967. [LogFilter("答复知识纠错")]
  968. public async Task Reply([FromBody] KnowledgeCorrectionUpdateDto dto)
  969. {
  970. var correction = await _knowledgeCorrectionRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  971. if (correction is null)
  972. throw UserFriendlyException.SameMessage("无效知识纠错");
  973. _mapper.Map(dto, correction);
  974. correction.ReplyTime = DateTime.Now;
  975. correction.ReplyUserName = _sessionContext.UserName;
  976. correction.State = ECorrectionState.AlreadyAnswered;
  977. await _knowledgeCorrectionRepository.UpdateAsync(correction, HttpContext.RequestAborted);
  978. }
  979. /// <summary>
  980. /// 获取知识纠错列表
  981. /// </summary>
  982. /// <param name="dto"></param>
  983. /// <returns></returns>
  984. [Permission(EPermission.KnowledgeCorrectionList)]
  985. [HttpGet("knowledge_correction/list")]
  986. public async Task<PagedDto<KnowledgeCorrectionDto>> List([FromQuery] KnowledgeCorrectionListDto dto)
  987. {
  988. var typeSpliceName = string.Empty;
  989. if (!string.IsNullOrEmpty(dto.KnowledgeTypeId))
  990. {
  991. var type = await _knowledgeTypeRepository.GetAsync(x => x.Id == dto.KnowledgeTypeId);
  992. typeSpliceName = type?.SpliceName;
  993. }
  994. var (total, items) = await _knowledgeCorrectionRepository.Queryable()
  995. .Includes(x => x.Knowledge)
  996. //.WhereIF(!string.IsNullOrEmpty(dto.KnowledgeTypeId), x => x.Knowledge.KnowledgeTypeId == dto.KnowledgeTypeId!)
  997. .WhereIF(!string.IsNullOrEmpty(dto.CreatorName), x => x.CreatorName == dto.CreatorName!)
  998. //.WhereIF(!string.IsNullOrEmpty(typeSpliceName), x => SqlFunc.JsonLike(x.Knowledge.KnowledgeType, typeSpliceName))
  999. .WhereIF(!string.IsNullOrEmpty(typeSpliceName), x => x.Knowledge.KnowledgeType.Any(t => t.KnowledgeTypeSpliceName.EndsWith(typeSpliceName)))
  1000. .Where(x => !string.IsNullOrEmpty(x.Knowledge.Id))
  1001. .OrderByDescending(x => x.CreationTime)
  1002. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  1003. return new PagedDto<KnowledgeCorrectionDto>(total, _mapper.Map<IReadOnlyList<KnowledgeCorrectionDto>>(items));
  1004. }
  1005. /// <summary>
  1006. /// 获取知识库纠错
  1007. /// </summary>
  1008. /// <param name="id"></param>
  1009. /// <returns></returns>
  1010. //[Permission(EPermission.KnowledgeCorrectionEntity)]
  1011. [HttpGet("knowledge_correction/{id}")]
  1012. public async Task<KnowledgeCorrection> CorrectionEntity(string id)
  1013. {
  1014. return await _knowledgeCorrectionRepository.Queryable()
  1015. .Includes(x => x.Knowledge)
  1016. .FirstAsync(x => x.Id == id);
  1017. }
  1018. #endregion
  1019. #region 知识提问
  1020. /// <summary>
  1021. /// 新增知识提问
  1022. /// </summary>
  1023. /// <param name="dtos"></param>
  1024. /// <returns></returns>
  1025. //[Permission(EPermission.AddKnowledgeQuestions)]
  1026. [HttpPost("knowledge_questions")]
  1027. [LogFilter("新增知识提问")]
  1028. public async Task Add([FromBody] KnowledgeQuestionsAddDto dto)
  1029. {
  1030. var questions = _mapper.Map<KnowledgeQuestions>(dto);
  1031. await _knowledgeQuestionsRepository.AddAsync(questions, HttpContext.RequestAborted);
  1032. }
  1033. /// <summary>
  1034. /// 删除知识提问
  1035. /// </summary>
  1036. /// <param name="dto"></param>
  1037. /// <returns></returns>
  1038. //[Permission(EPermission.DeleteKnowledgeQuestions)]
  1039. //[HttpDelete("knowledge_questions")]
  1040. //public async Task Delete([FromBody] KnowledgeQuestionsDeleteDto dto)
  1041. //{
  1042. // await _knowledgeQuestionsRepository.RemoveAsync(x => x.Id == dto.Id);
  1043. //}
  1044. /// <summary>
  1045. /// 更新知识提问
  1046. /// </summary>
  1047. /// <param name="dto"></param>
  1048. /// <returns></returns>
  1049. //[Permission(EPermission.UpdateKnowledgeQuestions)]
  1050. //[HttpPut("knowledge_questions")]
  1051. //public async Task Update([FromBody] KnowledgeQuestionsUpdateDto dto)
  1052. //{
  1053. // var questions = await _knowledgeQuestionsRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  1054. // if (questions is null)
  1055. // throw UserFriendlyException.SameMessage("无效知识提问");
  1056. // _mapper.Map(dto, questions);
  1057. // await _knowledgeQuestionsRepository.UpdateAsync(questions, HttpContext.RequestAborted);
  1058. //}
  1059. /// <summary>
  1060. /// 答复知识提问
  1061. /// </summary>
  1062. /// <param name="dto"></param>
  1063. /// <returns></returns>
  1064. [Permission(EPermission.ReplyKnowledgeQuestions)]
  1065. [HttpPut("knowledge_questions/Reply")]
  1066. [LogFilter("答复知识提问")]
  1067. public async Task Reply([FromBody] KnowledgeQuestionsUpdateDto dto)
  1068. {
  1069. var questions = await _knowledgeQuestionsRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  1070. if (questions is null)
  1071. throw UserFriendlyException.SameMessage("无效知识提问");
  1072. _mapper.Map(dto, questions);
  1073. questions.ReplyTime = DateTime.Now;
  1074. questions.ReplyUserName = _sessionContext.UserName;
  1075. questions.State = ECorrectionState.AlreadyAnswered;
  1076. await _knowledgeQuestionsRepository.UpdateAsync(questions, HttpContext.RequestAborted);
  1077. }
  1078. /// <summary>
  1079. /// 获取知识提问列表
  1080. /// </summary>
  1081. /// <param name="dto"></param>
  1082. /// <returns></returns>
  1083. [Permission(EPermission.KnowledgeQuestionsList)]
  1084. [HttpGet("knowledge_questions/list")]
  1085. public async Task<PagedDto<KnowledgeQuestionsDto>> List([FromQuery] KnowledgeQuestionsListDto dto)
  1086. {
  1087. var typeSpliceName = string.Empty;
  1088. if (!string.IsNullOrEmpty(dto.KnowledgeTypeId))
  1089. {
  1090. var type = await _knowledgeTypeRepository.GetAsync(x => x.Id == dto.KnowledgeTypeId);
  1091. typeSpliceName = type?.SpliceName;
  1092. }
  1093. var (total, items) = await _knowledgeQuestionsRepository.Queryable()
  1094. .Includes(x => x.Knowledge)
  1095. //.WhereIF(!string.IsNullOrEmpty(dto.KnowledgeTypeId), x => x.Knowledge.KnowledgeTypeId == dto.KnowledgeTypeId!)
  1096. //.WhereIF(!string.IsNullOrEmpty(typeSpliceName), x => SqlFunc.JsonLike(x.Knowledge.KnowledgeType, typeSpliceName))
  1097. .WhereIF(!string.IsNullOrEmpty(typeSpliceName), x => x.Knowledge.KnowledgeType.Any(t => t.KnowledgeTypeSpliceName.EndsWith(typeSpliceName)))
  1098. .WhereIF(!string.IsNullOrEmpty(dto.CreatorName), x => x.CreatorName == dto.CreatorName!)
  1099. .Where(x => !string.IsNullOrEmpty(x.Knowledge.Id))
  1100. .OrderByDescending(x => x.CreationTime)
  1101. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  1102. return new PagedDto<KnowledgeQuestionsDto>(total, _mapper.Map<IReadOnlyList<KnowledgeQuestionsDto>>(items));
  1103. }
  1104. /// <summary>
  1105. /// 获取知识提问
  1106. /// </summary>
  1107. /// <param name="id"></param>
  1108. /// <returns></returns>
  1109. //[Permission(EPermission.KnowledgeQuestionsEntity)]
  1110. [HttpGet("knowledge_questions/{id}")]
  1111. public async Task<KnowledgeQuestions> QuestionsEntity(string id)
  1112. {
  1113. return await _knowledgeQuestionsRepository.Queryable()
  1114. .Includes(x => x.Knowledge)
  1115. .FirstAsync(x => x.Id == id);
  1116. }
  1117. #endregion
  1118. #region 知识收藏
  1119. /// <summary>
  1120. /// 知识收藏列表
  1121. /// </summary>
  1122. /// <param name="dto"></param>
  1123. /// <returns></returns>
  1124. [Permission(EPermission.KnowledgeCollectList)]
  1125. [HttpGet("knowledge_collect/list")]
  1126. public async Task<PagedDto<KnowledgeCollectDto>> List([FromQuery] KnowledgeCollectListDto dto)
  1127. {
  1128. var (total, items) = await _knowledgeCollectRepository.Queryable()
  1129. .Includes(x => x.Knowledge)
  1130. .WhereIF(!string.IsNullOrEmpty(dto.Keyword), x => x.Knowledge.Title.Contains(dto.Keyword!) || (x.Knowledge.Summary != null && x.Knowledge.Summary.Contains(dto.Keyword!)))
  1131. .WhereIF(dto.KnowledgeCollectGroupId.NotNullOrEmpty(), x => x.KnowledgeCollectGroupId == dto.KnowledgeCollectGroupId)
  1132. .Where(x => x.CreatorId == _sessionContext.UserId)
  1133. .Where(x => !string.IsNullOrEmpty(x.Knowledge.Id))
  1134. .Where(x => x.Collect!.Value)
  1135. .OrderByDescending(x => x.CreationTime)
  1136. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  1137. return new PagedDto<KnowledgeCollectDto>(total, _mapper.Map<IReadOnlyList<KnowledgeCollectDto>>(items));
  1138. }
  1139. /// <summary>
  1140. /// 新增知识收藏
  1141. /// </summary>
  1142. /// <param name="dtos"></param>
  1143. /// <returns></returns>
  1144. //[Permission(EPermission.AddKnowledgeCollect)]
  1145. [HttpPost("knowledge_collect")]
  1146. [LogFilter("知识收藏")]
  1147. public async Task Add([FromBody] KnowledgeCollectAddDto dto)
  1148. {
  1149. var collect = await _knowledgeCollectRepository.GetAsync(x => x.KnowledgeId == dto.KnowledgeId && x.CreatorId == _sessionContext.UserId);
  1150. if (collect != null)
  1151. {
  1152. collect.Collect = dto.Collect;
  1153. await _knowledgeCollectRepository.UpdateAsync(collect, HttpContext.RequestAborted);
  1154. }
  1155. else
  1156. {
  1157. var collectNew = _mapper.Map<KnowledgeCollect>(dto);
  1158. await _knowledgeCollectRepository.AddAsync(collectNew, HttpContext.RequestAborted);
  1159. }
  1160. var count = await _knowledgeCollectRepository.Queryable()
  1161. .Where(m => m.KnowledgeId == dto.KnowledgeId && m.Collect == true).CountAsync();
  1162. await _knowledgeRepository.Updateable()
  1163. .Where(m => m.Id == dto.KnowledgeId)
  1164. .SetColumns(m => m.CollectCount == count)
  1165. .ExecuteCommandAsync();
  1166. }
  1167. /// <summary>
  1168. /// 知识评分
  1169. /// </summary>
  1170. /// <param name="dto"></param>
  1171. /// <returns></returns>
  1172. //[Permission(EPermission.AddKnowledgeScore)]
  1173. [HttpDelete("knowledge_score")]
  1174. [LogFilter("知识评分")]
  1175. public async Task Delete([FromBody] KnowledgeCollectAddDto dto)
  1176. {
  1177. var collect = await _knowledgeCollectRepository.GetAsync(x => x.KnowledgeId == dto.KnowledgeId && x.CreatorId == _sessionContext.UserId);
  1178. if (collect != null)
  1179. {
  1180. if (collect.Score > 0)
  1181. throw UserFriendlyException.SameMessage("当前知识已经评分");
  1182. collect.Score = dto.Score;
  1183. await _knowledgeCollectRepository.UpdateAsync(collect, HttpContext.RequestAborted);
  1184. }
  1185. else
  1186. {
  1187. var questions = _mapper.Map<KnowledgeCollect>(dto);
  1188. await _knowledgeCollectRepository.AddAsync(questions, HttpContext.RequestAborted);
  1189. }
  1190. //计算总分
  1191. var sugar = _knowledgeCollectRepository.Queryable().Where(x => x.KnowledgeId == dto.KnowledgeId);
  1192. var count = await sugar.CountAsync();
  1193. var collects = await sugar.SumAsync(x => x.Score);
  1194. var score = collects / count;
  1195. var knowledge = await _knowledgeRepository.GetAsync(x => x.Id == dto.KnowledgeId);
  1196. if (knowledge != null)
  1197. {
  1198. knowledge.Score = decimal.Round(score.Value, 1);
  1199. await _knowledgeRepository.UpdateAsync(knowledge, HttpContext.RequestAborted);
  1200. }
  1201. }
  1202. #endregion
  1203. #region 知识评论
  1204. /// <summary>
  1205. /// 新增知识评论
  1206. /// </summary>
  1207. /// <param name="dto"></param>
  1208. /// <returns></returns>
  1209. [HttpPost("knowledge_comment")]
  1210. public async Task Add([FromBody] KnowledgeCommentAddDto dto)
  1211. {
  1212. var model = _mapper.Map<KnowledgeComment>(dto);
  1213. await _knowledgeCommentRepository.AddAsync(model, HttpContext.RequestAborted);
  1214. if (!string.IsNullOrEmpty(dto.ReplyId))
  1215. {
  1216. var comment = await _knowledgeCommentRepository.GetAsync(dto.ReplyId);
  1217. if (comment != null)
  1218. {
  1219. comment.ReplyNum++;
  1220. await _knowledgeCommentRepository.UpdateAsync(comment, HttpContext.RequestAborted);
  1221. }
  1222. }
  1223. }
  1224. /// <summary>
  1225. /// 删除知识评论
  1226. /// </summary>
  1227. /// <param name="dto"></param>
  1228. /// <returns></returns>
  1229. [HttpDelete("knowledge_comment")]
  1230. public async Task Delete([FromBody] KnowledgeCommentDeleteDto dto)
  1231. {
  1232. var comment = await _knowledgeCommentRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  1233. if (comment is null)
  1234. throw UserFriendlyException.SameMessage("无效评论");
  1235. if (comment.CreatorId != _sessionContext.UserId)
  1236. throw UserFriendlyException.SameMessage("只有评论者可以删除当前评论");
  1237. await _knowledgeCommentRepository.RemoveAsync(x => x.Id == dto.Id);
  1238. }
  1239. /// <summary>
  1240. /// 修改知识评论
  1241. /// </summary>
  1242. /// <param name="dto"></param>
  1243. /// <returns></returns>
  1244. [HttpPut("knowledge_comment")]
  1245. public async Task Update([FromBody] KnowledgeCommentUpdateDto dto)
  1246. {
  1247. var comment = await _knowledgeCommentRepository.GetAsync(dto.Id, HttpContext.RequestAborted);
  1248. if (comment is null)
  1249. throw UserFriendlyException.SameMessage("无效评论");
  1250. _mapper.Map(dto, comment);
  1251. await _knowledgeCommentRepository.UpdateAsync(comment, HttpContext.RequestAborted);
  1252. }
  1253. /// <summary>
  1254. /// 知识评论列表
  1255. /// </summary>
  1256. /// <param name="dto"></param>
  1257. /// <returns></returns>
  1258. [HttpGet("knowledge_comment/list")]
  1259. public async Task<List<KnowledgeCommentDto>> List([FromQuery] KnowledgeCommentListDto dto)
  1260. {
  1261. var comments = await _knowledgeCommentRepository.Queryable()
  1262. .WhereIF(!string.IsNullOrEmpty(dto.KnowledgeId), x => x.KnowledgeId == dto.KnowledgeId)
  1263. .WhereIF(!string.IsNullOrEmpty(dto.ReplyId), x => x.ReplyId == dto.ReplyId)
  1264. .WhereIF(dto.All.HasValue && dto.All == false, x => x.CreatorId == _sessionContext.UserId)
  1265. .OrderByDescending(x => x.CreationTime)
  1266. .ToListAsync();
  1267. return new List<KnowledgeCommentDto>(_mapper.Map<IReadOnlyList<KnowledgeCommentDto>>(comments));
  1268. }
  1269. #endregion
  1270. #region 收藏分组
  1271. /// <summary>
  1272. /// 增加收藏分组
  1273. /// </summary>
  1274. [HttpPost("group")]
  1275. public async Task<KnowledgeCollectGroupOutDto> SaveKnowledgeCoolectGroupAsync([FromBody] KnowledgeCollectGroupInDto dto)
  1276. {
  1277. var entity = dto.Adapt<KnowledgeCollectGroup>();
  1278. if (await _knowledgeCollectGroupRepository
  1279. .Queryable()
  1280. .Where(m => m.Name == dto.Name && m.CreatorId == _sessionContext.UserId)
  1281. .AnyAsync() == true) throw UserFriendlyException.SameMessage("分组名重复, 请重新输入!");
  1282. var key = await _knowledgeCollectGroupRepository.AddAsync(entity);
  1283. if (key.IsNullOrEmpty()) throw UserFriendlyException.SameMessage("添加失败, 请重试");
  1284. var outDto = dto.Adapt<KnowledgeCollectGroupOutDto>();
  1285. outDto.Id = key;
  1286. return outDto;
  1287. }
  1288. /// <summary>
  1289. /// 删除收藏分组
  1290. /// </summary>
  1291. [HttpDelete("group")]
  1292. public async Task DeleteKnowledgeCoolectGroupAsync([FromQuery] string id)
  1293. {
  1294. var entity = await _knowledgeCollectGroupRepository.Queryable()
  1295. .Where(m => m.Id == id && m.CreatorId == _sessionContext.UserId)
  1296. .FirstAsync() ?? throw new UserFriendlyException("数据不存在");
  1297. entity.IsDeleted = true;
  1298. await _knowledgeCollectGroupRepository.UpdateAsync(entity);
  1299. await _knowledgeCollectRepository.Updateable()
  1300. .Where(m => m.KnowledgeCollectGroupId == id && m.CreatorId == _sessionContext.UserId)
  1301. .SetColumns(m => m.IsDeleted == true)
  1302. .ExecuteCommandAsync();
  1303. }
  1304. /// <summary>
  1305. /// 获取分组收藏列表
  1306. /// </summary>
  1307. /// <returns></returns>
  1308. [HttpGet("group")]
  1309. public async Task<PagedDto<KnowledgeCollectGroupOutDto>> GetKnowledgeCollectGroupListAsync([FromQuery] KnowledgeCollectGroupListInDto dto)
  1310. {
  1311. return (await _knowledgeCollectGroupRepository.Queryable()
  1312. .WhereIF(dto.Keyword.NotNullOrEmpty(), m => m.Name.Contains(dto.Keyword))
  1313. .Where(m => m.CreatorId == _sessionContext.UserId)
  1314. .Select<KnowledgeCollectGroupOutDto>()
  1315. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted)
  1316. ).ToPaged();
  1317. }
  1318. #endregion
  1319. #region PageView 浏览记录
  1320. /// <summary>
  1321. /// 浏览记录集合
  1322. /// </summary>
  1323. /// <param name="dto"></param>
  1324. /// <returns></returns>
  1325. [HttpGet("pageview")]
  1326. public async Task<PagedDto<PageViewOutDto>> GetPageViewListAsync([FromQuery] PageViewInDto dto)
  1327. {
  1328. return (await _knowApplication.GetPageViewListAsync(dto, HttpContext.RequestAborted))
  1329. .ToPaged();
  1330. }
  1331. /// <summary>
  1332. /// 浏览记录集合-导出
  1333. /// </summary>
  1334. /// <param name="dto"></param>
  1335. /// <returns></returns>
  1336. [HttpPost("pageview/export")]
  1337. public async Task<FileStreamResult> GetPageViewListAsync([FromBody] ExportExcelDto<PageViewInDto> dto)
  1338. {
  1339. var items = (await _knowApplication.GetPageViewListAsync(dto.QueryDto, HttpContext.RequestAborted))
  1340. .Item2;
  1341. return _exportApplication.GetExcelFile(dto, items, "浏览记录");
  1342. }
  1343. #endregion
  1344. #region 热词
  1345. /// <summary>
  1346. /// 新增热词
  1347. /// </summary>
  1348. /// <param name="dto"></param>
  1349. /// <returns></returns>
  1350. [HttpPost("hotword")]
  1351. public async Task AddKnowledgeHotWordAsync([FromBody] AddKnowledgeHotWordInDto dto)
  1352. {
  1353. await _knowApplication.AddKnowledgeHotWordAsync(dto, HttpContext.RequestAborted);
  1354. }
  1355. /// <summary>
  1356. /// 新增热词页面基础数据
  1357. /// </summary>
  1358. /// <param name="dto"></param>
  1359. /// <returns></returns>
  1360. [HttpGet("hotword/basedata")]
  1361. public async Task<Dictionary<string, dynamic>> AddKnowledgeHotWordBaseDataAsync()
  1362. {
  1363. return _baseDataApplication
  1364. .KnowledgeHotWordType()
  1365. .Build();
  1366. }
  1367. /// <summary>
  1368. /// 热词集合
  1369. /// </summary>
  1370. /// <param name="dto"></param>
  1371. /// <returns></returns>
  1372. [HttpGet("hotword")]
  1373. public async Task<PagedDto<KnowledgeHotWordOutDto>> GetKnowledgeHotWordListAsync([FromQuery] KnowledgeHotWordInDto dto)
  1374. {
  1375. return (await _knowApplication.GetKnowledgeHotWordListAsync(dto, HttpContext.RequestAborted))
  1376. .ToPaged();
  1377. }
  1378. /// <summary>
  1379. /// 修改热词
  1380. /// </summary>
  1381. /// <param name="dto"></param>
  1382. /// <returns></returns>
  1383. [HttpPut("hotword")]
  1384. public async Task UpdateKnowledgeHotWordAsync([FromBody] UpdateKnowledgeHotWordInDto dto)
  1385. {
  1386. await _knowApplication.UpdateKnowledgeHotWordAsync(dto, HttpContext.RequestAborted);
  1387. }
  1388. /// <summary>
  1389. /// 删除热词
  1390. /// </summary>
  1391. /// <param name="id"></param>
  1392. /// <returns></returns>
  1393. [HttpDelete("hotword")]
  1394. public async Task DeleteKnowledgeHotWordAsync([FromQuery] string id)
  1395. {
  1396. await _knowledgeHotWordRepository
  1397. .RemoveAsync(id);
  1398. }
  1399. #endregion
  1400. }
  1401. }