MiddleService.cs 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. using GxPress.Common.Exceptions;
  6. using GxPress.Repository.Interface;
  7. using GxPress.Request.App.Middle;
  8. using GxPress.Request.Notice;
  9. using GxPress.Service.Interface.Middle;
  10. using Datory;
  11. using GxPress.Entity.Middle;
  12. using GxPress.Result.App.Middle;
  13. using System.Transactions;
  14. using GxPress.Repository.Interface.Collection;
  15. using GxPress.Repository.Interface.Note;
  16. using GxPress.Repository.Interface.Missive;
  17. using GxPress.Common.Tools;
  18. using GxPress.Repository.Interface.Analyze;
  19. using GxPress.Service.Interface.UserMiddle;
  20. using GxPress.Repository.Interface.RecordFolder;
  21. using GxPress.Service.Interface.Analyze;
  22. using GxPress.Request.App.Analyze;
  23. namespace GxPress.Service.Implement.Middle
  24. {
  25. public class MiddleService : IMiddleService
  26. {
  27. private readonly IMiddleRepository _middleRepository;
  28. private readonly IFolderUserRepository _folderUserRepository;
  29. private readonly IUserRepository _userRepository;
  30. private readonly ICollectionRepository _collectionRepository;
  31. private readonly INoteRepository _noteRepository;
  32. private readonly IMissiveRepository _missiveRepository;
  33. private readonly IGroupRepository _groupRepository;
  34. private readonly IAnalyzeRepository _analyzeRepository;
  35. private readonly INoticeRepository _noticeRepository;
  36. private readonly IUserMiddleService _userMiddleService;
  37. private readonly IAddresseeRepository _addresseeRepository;
  38. private readonly IRecordFolderRepository recordFolderRepository;
  39. private readonly IAnalyzeService analyzeService;
  40. public MiddleService(IMiddleRepository middleRepository, IFolderUserRepository folderUserRepository,
  41. IUserRepository userRepository, ICollectionRepository collectionRepository, INoteRepository noteRepository,
  42. IMissiveRepository missiveRepository, IGroupRepository groupRepository, INoticeRepository noticeRepository, IAnalyzeRepository analyzeRepository, IUserMiddleService userMiddleService, IAddresseeRepository addresseeRepository, IRecordFolderRepository recordFolderRepository, IAnalyzeService analyzeService)
  43. {
  44. _middleRepository = middleRepository;
  45. _folderUserRepository = folderUserRepository;
  46. _userRepository = userRepository;
  47. _collectionRepository = collectionRepository;
  48. _noteRepository = noteRepository;
  49. _missiveRepository = missiveRepository;
  50. _groupRepository = groupRepository;
  51. _noticeRepository = noticeRepository;
  52. _analyzeRepository = analyzeRepository;
  53. _userMiddleService = userMiddleService;
  54. _addresseeRepository = addresseeRepository;
  55. this.recordFolderRepository = recordFolderRepository;
  56. this.analyzeService = analyzeService;
  57. }
  58. /// <summary>
  59. /// 添加文件夹
  60. /// </summary>
  61. /// <param name="request"></param>
  62. /// <returns></returns>
  63. public async Task<int> InsertAsync(MiddleInsertRequest request)
  64. {
  65. var folderRoleId = new List<int> { 1, 2, 3 };
  66. if (!folderRoleId.Contains(request.RoleId) && (request.FolderType == 3 || request.FolderType == 4))
  67. throw new BusinessException("文件夹权限有误!");
  68. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  69. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  70. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  71. .Where(nameof(Entity.Middle.Middle.FolderType), request.FolderType)
  72. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  73. .Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId).Where(nameof(Entity.Middle.Middle.IsDelete), false));
  74. if (string.IsNullOrEmpty(request.FolderName))
  75. throw new BusinessException("文件名称未填写!");
  76. if (oldMiddle != null)
  77. throw new BusinessException("文件夹名称重复,请重新命名!");
  78. var middle = new Entity.Middle.Middle
  79. {
  80. FolderName = request.FolderName,
  81. FolderType = request.FolderType,
  82. IsTop = false,
  83. AttributeValue = 2,
  84. ParentId = request.ParentId,
  85. RoleId = request.RoleId,
  86. UserId = request.UserId,
  87. Sort = 0
  88. };
  89. //存在父级
  90. var middleDto = new Entity.Middle.Middle();
  91. if (request.ParentId > 0)
  92. {
  93. //获取父级数据
  94. middleDto = await _middleRepository.GetMiddleAsync(request.ParentId);
  95. if (middleDto != null)
  96. {
  97. middle.RoleId = middleDto.RoleId;
  98. request.RoleId = middleDto.RoleId;
  99. if (middleDto.ParentId == 0)
  100. middle.MiddleSonId = middleDto.Id;
  101. else middle.MiddleSonId = middleDto.MiddleSonId;
  102. }
  103. }
  104. if (request.RoleId == 0)
  105. middle.RoleId = 1;
  106. if (request.RoleId == 3)
  107. {
  108. if (request.UserIds == null)
  109. request.UserIds = new List<int>();
  110. if (request.UserIds.Count == 0 && request.UserMiddles.Count == 0 && request.ParentId == 0)
  111. throw new BusinessException("共享用户必须");
  112. }
  113. if (request.RoleId > 0)
  114. middle.RoleId = request.RoleId;
  115. var middleId = await _middleRepository.InsertAsync(middle);
  116. if (middle.ParentId == 0)
  117. {
  118. middle = await _middleRepository.GetMiddleAsync(middleId);
  119. if (middle != null)
  120. {
  121. middle.MiddleSonId = middleId;
  122. await _middleRepository.UpdateAsync(middle);
  123. }
  124. }
  125. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.Sort), middleId)
  126. .Where(nameof(Entity.Middle.Middle.Id), middleId));
  127. if (request.RoleId == 3 && request.ParentId == 0)
  128. //添加人员
  129. await InsertFolderUsers(request, middleId);
  130. return middleId;
  131. }
  132. /// <summary>
  133. /// 添加文件夹用户
  134. /// </summary>
  135. /// <param name="userIds"></param>
  136. /// <param name="middleId"></param>
  137. /// <returns></returns>
  138. public async Task<bool> InsertFolderUsers(MiddleInsertRequest request, int middleId)
  139. {
  140. //添加
  141. if (request.UserMiddles.Count > 0)
  142. {
  143. foreach (var item in request.UserMiddles)
  144. {
  145. item.DataSourceId = middleId;
  146. item.MiddleType = request.FolderType;
  147. }
  148. //添加中间表
  149. await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  150. var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, middleId);
  151. request.UserIds = users.Select(n => n.Id).ToList();
  152. }
  153. if (request.UserIds.Count > 0)
  154. {
  155. var users = await _userRepository.GetAllAsync(Q.WhereIn(nameof(Entity.User.Id), request.UserIds));
  156. //插入用户
  157. var folderUsers = new List<FolderUser>();
  158. foreach (var user in users)
  159. {
  160. var folderUser = new FolderUser();
  161. folderUser.UserId = user.Id;
  162. folderUser.UserName = user.Name;
  163. folderUser.MiddleId = middleId;
  164. folderUsers.Add(folderUser);
  165. }
  166. return await _folderUserRepository.InsertsAsync(folderUsers.ToList());
  167. }
  168. return false;
  169. }
  170. /// <summary>
  171. /// 修改文件夹名称
  172. /// </summary>
  173. /// <param name="request"></param>
  174. /// <returns></returns>
  175. public async Task<bool> UpdateNameAsync(MiddleUpdateNameRequest request)
  176. {
  177. var middle =
  178. await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.MiddleId)
  179. .Where(nameof(Entity.Middle.Middle.AttributeValue), 1));
  180. if (middle == null)
  181. throw new BusinessException("文件不存在");
  182. return await _middleRepository.UpdateAsync(
  183. Q.Set(nameof(Entity.Middle.Middle.FolderName), request.FolderName).Where(
  184. nameof(Entity.Middle.Middle.Id),
  185. request.MiddleId));
  186. }
  187. /// <summary>
  188. /// 添加数据
  189. /// </summary>
  190. /// <param name="request"></param>
  191. /// <returns></returns>
  192. public async Task<int> InsertAsync(MiddleInsertTypeRequest request)
  193. {
  194. var middle = new Entity.Middle.Middle
  195. {
  196. MiddleId = request.MiddleId,
  197. FolderType = request.FolderType,
  198. IsTop = false,
  199. AttributeValue = request.AttributeValue,
  200. ParentId = request.FolderId,
  201. UserId = request.UserId,
  202. MiddleSonId = request.MiddleSonId,
  203. IsAdmin = request.IsAdmin,
  204. NoticeAddresseeType = request.NoticeAddresseeType,
  205. Title=request.Title,
  206. IsRead = false,
  207. IsUpload = false,
  208. TitleLong=request.TitleLong,
  209. Content="",
  210. AddressUser=request.AddressUser,
  211. CcUser=request.CcUser,
  212. CcUserComplete=request.CcUserComplete,
  213. AddressUserComplete=request.AddressUserComplete,
  214. IsRecall=false
  215. };
  216. if (request.AttributeValue == 0)
  217. middle.AttributeValue = 1;
  218. var middleId = await _middleRepository.InsertAsync(middle);
  219. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.Sort), middleId)
  220. .Where(nameof(Entity.Middle.Middle.Id), middleId));
  221. return middleId;
  222. }
  223. /// <summary>
  224. /// 添加数据
  225. /// </summary>
  226. /// <param name="request"></param>
  227. /// <returns></returns>
  228. public async Task<bool> AddOrUpdateAsync(MiddleInsertTypeRequest request)
  229. {
  230. var middle = await _middleRepository.GetMiddleAsync(Q
  231. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  232. .Where(nameof(Entity.Middle.Middle.AttributeValue), 3)
  233. .Where(nameof(Entity.Middle.Middle.FolderType), request.FolderType));
  234. if (middle == null)
  235. {
  236. middle = new Entity.Middle.Middle
  237. {
  238. MiddleId = request.MiddleId,
  239. FolderType = request.FolderType,
  240. IsTop = false,
  241. AttributeValue = request.AttributeValue,
  242. ParentId = request.FolderId,
  243. UserId = request.UserId,
  244. MiddleSonId = request.MiddleSonId
  245. };
  246. var middleId = await _middleRepository.InsertAsync(middle);
  247. //修改Middle sort
  248. await _middleRepository.UpdateAsync(Q.Where(nameof(Entity.Middle.Middle.Id), middleId).Set(nameof(Entity.Middle.Middle.Sort), middleId));
  249. return true;
  250. }
  251. return await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), false)
  252. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  253. .Where(nameof(Entity.Middle.Middle.AttributeValue), 3));
  254. }
  255. /// <summary>
  256. /// 排序
  257. /// </summary>
  258. /// <param name="request"></param>
  259. /// <returns></returns>
  260. public async Task<bool> MiddleSortAsync(MiddleSortRequest request)
  261. {
  262. return await _middleRepository.SetSortAsync(request);
  263. }
  264. /// <summary>
  265. /// 设置置顶
  266. /// </summary>
  267. /// <param name="id"></param>
  268. /// <returns></returns>
  269. public async Task<bool> SetTopAsync(int id)
  270. {
  271. return await _middleRepository.SetTopAsync(id);
  272. }
  273. /// <summary>
  274. /// 删除 1 通知 2话题 3 收藏 4笔记 5 普通站内信 6匿名站内信 7 小组
  275. /// </summary>
  276. /// <param name="request"></param>
  277. /// <returns></returns>
  278. public async Task<bool> DeleteAsync(NoticeDeRequest request)
  279. {
  280. try
  281. {
  282. using TransactionScope transactionScope = new TransactionScope();
  283. //查询middle
  284. var middles = await _middleRepository.FindAsync(Q.WhereIn(nameof(Entity.Middle.Middle.Id), request.MiddleIds));
  285. var ids = middles.Select(n => n.MiddleId).ToList();
  286. //收藏
  287. if (request.FolderType == 3)
  288. {
  289. //查询收藏
  290. var collections = await _collectionRepository.GetAllAsync(Q.WhereIn(nameof(Entity.Collection.Id), ids));
  291. foreach (var item in collections)
  292. {
  293. var analyzeRequest = new AnalyzeRequest();
  294. analyzeRequest.AnalyzeType = 3;
  295. analyzeRequest.SourceId = item.CollectionDataId;
  296. analyzeRequest.UserId = item.UserId;
  297. //删除文章收藏
  298. if (item.CollectionType == 1)
  299. {
  300. analyzeRequest.TypeValue = 0;
  301. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  302. if (analyze != null)
  303. await _analyzeRepository.DeleteAsync(analyze.Id);
  304. }
  305. //删除话题收藏
  306. if (item.CollectionType == 2)
  307. {
  308. analyzeRequest.TypeValue = 1;
  309. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  310. if (analyze != null)
  311. await _analyzeRepository.DeleteAsync(analyze.Id);
  312. }
  313. //删除笔记收藏
  314. if (item.CollectionType == 4)
  315. {
  316. analyzeRequest.TypeValue = 3;
  317. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  318. if (analyze != null)
  319. await _analyzeRepository.DeleteAsync(analyze.Id);
  320. }
  321. //删除通知收藏
  322. if (item.CollectionType == 5)
  323. {
  324. analyzeRequest.TypeValue = 2;
  325. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  326. if (analyze != null)
  327. await _analyzeRepository.DeleteAsync(analyze.Id);
  328. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true));
  329. }
  330. //删除站内信收藏
  331. if (item.CollectionType == 6)
  332. {
  333. analyzeRequest.TypeValue = 4;
  334. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  335. if (analyze != null)
  336. await _analyzeRepository.DeleteAsync(analyze.Id);
  337. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true));
  338. }
  339. //删除收藏会议
  340. if (item.CollectionType == 8)
  341. {
  342. analyzeRequest.TypeValue = 10;
  343. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  344. if (analyze != null)
  345. await _analyzeRepository.DeleteAsync(analyze.Id);
  346. }
  347. //收藏笔记文件夹
  348. if (item.CollectionType == 12 || item.CollectionType == 13)
  349. {
  350. analyzeRequest.TypeValue = item.CollectionType;
  351. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  352. if (analyze != null)
  353. await _analyzeRepository.DeleteAsync(analyze.Id);
  354. }
  355. }
  356. //删除收藏
  357. request.IsDelete = true;
  358. //删除
  359. await _collectionRepository.RecursionDeleteAsync(request.MiddleIds);
  360. }
  361. //删除笔记
  362. if (request.FolderType == 4)
  363. {
  364. await _noteRepository.UpdateAsync(Q.WhereIn(nameof(Entity.Note.Note.Id), ids).Set(nameof(Entity.Note.Note.IsDelete), true));
  365. //删除默认共享文件夹
  366. await recordFolderRepository.DeleteAsync(request.FolderType, request.UserId, request.MiddleIds);
  367. }
  368. //站内信
  369. // if (request.FolderType == 5)
  370. // await _missiveRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Missive.Missive.Id), ids));
  371. //小组
  372. if (request.FolderType == 7)
  373. await _groupRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Group.Id), ids));
  374. // //删除通知
  375. // if (request.FolderType == 1 && request.IsDelete)
  376. // await _noticeRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Notice.Id), middles.Select(n => n.MiddleId)));
  377. // //删除站内信
  378. // if (request.FolderType == 5 && request.IsDelete)
  379. // await _missiveRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Missive.Missive.Id), middles.Select(n => n.MiddleId)));
  380. //删除通知
  381. if (request.FolderType == 1)
  382. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true).Set(nameof(Entity.Addressee.IsRead), true));
  383. //删除站内信
  384. if (request.FolderType == 5)
  385. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true).Set(nameof(Entity.Addressee.IsRead), true));
  386. if (request.FolderType == 1 || request.FolderType == 5)
  387. {
  388. foreach (var item in middles)
  389. {
  390. if (item.AttributeValue == 2)
  391. {
  392. //永久删除文件夹
  393. await _middleRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.Middle.Id), item.Id));
  394. //修改文件夹下级数据
  395. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), 1).Where(nameof(Entity.Middle.Middle.ParentId), item.Id));
  396. }
  397. }
  398. }
  399. //删除信源以及文件夹
  400. if (request.FolderType == 10)
  401. {
  402. foreach (var middle in middles)
  403. {
  404. //判断是否文件夹
  405. if (middle.AttributeValue == 2)
  406. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.ParentId), 0).Where(nameof(Entity.Middle.Middle.ParentId), middle.Id).Where(nameof(Entity.Middle.Middle.FolderType), 10));
  407. }
  408. }
  409. await _middleRepository.DeleteAsync(request);
  410. transactionScope.Complete();
  411. }
  412. catch (Exception ex)
  413. {
  414. throw new BusinessException(ex.Message);
  415. }
  416. return true;
  417. }
  418. public async Task<bool> RecoverDeleteAsync(NoticeDeRequest request)
  419. {
  420. return await _middleRepository.RecoverDeleteAsync(request);
  421. }
  422. public async Task<bool> SetMove(MiddleMoveRequest request)
  423. {
  424. return await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.ParentId), request.ParentId).WhereIn(nameof(Entity.Middle.Middle.Id), request.Ids));
  425. }
  426. /// <summary>
  427. /// 恢复全部
  428. /// </summary>
  429. /// <param name="folderType"></param>
  430. /// <returns></returns>
  431. public async Task<bool> RecoverAllAsync(int folderType, int userId)
  432. {
  433. return await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), false).Where(nameof(Entity.Middle.Middle.FolderType), folderType).Where(nameof(Entity.Middle.Middle.UserId), userId));
  434. }
  435. /// <summary>
  436. /// 修改文件夹名称
  437. /// </summary>
  438. /// <param name="request"></param>
  439. /// <returns></returns>
  440. public async Task<bool> UpdateFolderNameAsync(MiddleFolderNameRequest request)
  441. {
  442. var middle = await _middleRepository.GetMiddleAsync(request.Id);
  443. if (middle == null)
  444. throw new BusinessException("文件夹不存在");
  445. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  446. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  447. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  448. .Where(nameof(Entity.Middle.Middle.FolderType), middle.FolderType)
  449. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  450. .Where(nameof(Entity.Middle.Middle.IsDelete), false));
  451. if (oldMiddle != null && oldMiddle.Id != middle.Id)
  452. throw new BusinessException("文件夹名称重复,请重新命名!");
  453. return await _middleRepository.UpdateFolderNameAsync(request);
  454. }
  455. /// <summary>
  456. /// 查询文件夹
  457. /// </summary>
  458. /// <param name="request"></param>
  459. /// <returns></returns>
  460. public async Task<List<MiddleSearchFolderResult>> SearchFolderAsync(MiddleSearchFolderRequest request)
  461. {
  462. var query = Q.NewQuery();
  463. query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId)
  464. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  465. .Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId)
  466. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  467. .Where(nameof(Entity.Middle.Middle.IsDelete), false).WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  468. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  469. query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  470. if (request.RoleId > 0)
  471. query.Where(nameof(Entity.Middle.Middle.RoleId), request.RoleId);
  472. var middles = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.IsTop), nameof(Entity.Middle.Middle.Sort), nameof(Entity.Middle.Middle.LastModifiedDate)));
  473. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  474. foreach (var item in middles)
  475. {
  476. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  477. {
  478. Name = item.FolderName,
  479. Id = item.Id,
  480. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  481. RoleId = item.RoleId,
  482. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  483. IsTop = item.IsTop
  484. };
  485. if (item.RoleId == 3)
  486. {
  487. var sourceId = item.Id;
  488. if (item.ParentId != 0)
  489. sourceId = item.MiddleSonId;
  490. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  491. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  492. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  493. }
  494. result.Add(middleSearchFolderResult);
  495. }
  496. return result;
  497. }
  498. /// <summary>
  499. /// 修改权限
  500. /// </summary>
  501. /// <param name="request"></param>
  502. /// <returns></returns>
  503. public async Task<bool> UpdateFolderRoleAsync(MiddleUpdateFolderRoleRequest request)
  504. {
  505. var middle = await _middleRepository.GetMiddleAsync(request.MiddleId);
  506. if (middle == null)
  507. throw new BusinessException("文件夹不存在");
  508. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  509. .Where(nameof(Entity.Middle.Middle.UserId), middle.UserId)
  510. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  511. .Where(nameof(Entity.Middle.Middle.FolderType), middle.FolderType)
  512. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  513. .Where(nameof(Entity.Middle.Middle.ParentId), middle.ParentId).Where(nameof(Entity.Middle.Middle.IsDelete), false));
  514. if (string.IsNullOrEmpty(request.FolderName))
  515. throw new BusinessException("文件名称未填写");
  516. if (oldMiddle != null && oldMiddle.Id != middle.Id)
  517. throw new BusinessException("文件夹名称重复,请重新命名!");
  518. if (middle.RoleId == 3)
  519. {
  520. if (request.RoleId != 3)
  521. {
  522. //删除共享用户
  523. await _folderUserRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.FolderUser.MiddleId), middle.Id));
  524. //删除
  525. await _userMiddleService.DeleteAsync(middle.Id, middle.FolderType);
  526. }
  527. }
  528. if (request.RoleId == 3 && middle.ParentId == 0)
  529. {
  530. if (request.UserIds.Count == 0 && request.UserMiddles.Count == 0)
  531. throw new BusinessException("共享成员必须");
  532. //添加人员
  533. await _folderUserRepository.DeleteAsync(Q.Where(nameof(FolderUser.MiddleId), request.MiddleId));
  534. var middleInsertRequest = new MiddleInsertRequest();
  535. middleInsertRequest.UserIds = request.UserIds;
  536. middleInsertRequest.UserMiddles = request.UserMiddles;
  537. middleInsertRequest.FolderType = middle.FolderType;
  538. if (request.UserMiddles.Count > 0)
  539. {
  540. //删除原有的数据
  541. await _userMiddleService.DeleteAsync(middle.Id, middle.FolderType);
  542. //await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  543. //查询用户
  544. // var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, middle.UserId);
  545. // middleInsertRequest.UserIds = users.Select(n => n.Id).ToList();
  546. }
  547. await InsertFolderUsers(middleInsertRequest, request.MiddleId);
  548. }
  549. middle.RoleId = request.RoleId;
  550. middle.FolderName = request.FolderName;
  551. await _middleRepository.UpdateAsync(middle);
  552. //修改子集权限
  553. if (middle.ParentId == 0)
  554. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.RoleId), request.RoleId).Where(nameof(Entity.Middle.Middle.MiddleSonId), middle.Id));
  555. return true;
  556. }
  557. /// <summary>
  558. /// 修改共享文件夹下的所有文件夹属性
  559. /// </summary>
  560. /// <param name="request"></param>
  561. /// <returns></returns>
  562. public async Task<bool> UpdateChildrenMiddleFolder(MiddleUpdateFolderRoleRequest request)
  563. {
  564. //获取下级数据
  565. var middles = await _middleRepository.GetMiddleChildrenAsync(request.MiddleId);
  566. if (middles.Count() == 0)
  567. return true;
  568. foreach (var item in middles)
  569. {
  570. if (request.UserMiddles.Count > 0)
  571. {
  572. var middleInsertRequest = new MiddleInsertRequest();
  573. middleInsertRequest.UserIds = request.UserIds;
  574. middleInsertRequest.UserMiddles = request.UserMiddles;
  575. //删除原有的数据
  576. await _userMiddleService.DeleteAsync(item.Id, item.FolderType);
  577. await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  578. //查询用户
  579. var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, item.UserId);
  580. middleInsertRequest.UserIds = users.Select(n => n.Id).ToList();
  581. //插入共享成员
  582. await InsertFolderUsers(middleInsertRequest, request.MiddleId);
  583. item.RoleId = request.RoleId;
  584. item.FolderName = request.FolderName;
  585. //修改
  586. await _middleRepository.UpdateAsync(item);
  587. request.MiddleId = item.Id;
  588. //修改下级权限和共享范围人
  589. await UpdateChildrenMiddleFolder(request);
  590. }
  591. }
  592. return true;
  593. }
  594. /// <summary>
  595. /// 根据文件夹ID获取文件夹信息
  596. /// </summary>
  597. /// <param name="middleId"></param>
  598. /// <returns></returns>
  599. public async Task<MiddleFolderInfoResult> GetFolderInfo(int middleId)
  600. {
  601. if (middleId == 0)
  602. throw new Common.Exceptions.BusinessException("文件夹不存在");
  603. var result = new MiddleFolderInfoResult();
  604. var middle = await _middleRepository.GetMiddleAsync(middleId);
  605. result.Id = middle.Id;
  606. result.FolderName = middle.FolderName;
  607. result.FolderType = middle.FolderType == 3 ? 12 : 13;
  608. result.UserId = middle.UserId;
  609. result.RoleId = middle.RoleId;
  610. result.FolderUsers = await _folderUserRepository.GetAllAsync(middleId);
  611. //获取共享人员
  612. if (result.RoleId == 3)
  613. {
  614. var sourceId = middle.Id;
  615. if (middle.ParentId > 0)
  616. sourceId = middle.MiddleSonId;
  617. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, sourceId);
  618. result.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  619. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), middle.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  620. // result.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  621. }
  622. result.UserMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, middleId);
  623. return result;
  624. }
  625. /// <summary>
  626. /// 获取默认的共享文件夹范围
  627. /// </summary>
  628. /// <param name="userId"></param>
  629. /// <returns></returns>
  630. public async Task<MiddleDefaultResult> GetEnjoyDefaultAsync(int userId, int folderType)
  631. {
  632. // var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.UserId), userId).WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 1, 3 }).Where(nameof(Entity.Middle.Middle.IsDefault), true));
  633. // var result = new MiddleDefaultResult();
  634. // result.IsDefault = middle != null;
  635. // result.FolderName = middle == null ? "" : middle.FolderName;
  636. // result.MiddleId = middle == null ? 0 : middle.Id;
  637. var recordFolder = await recordFolderRepository.GetAsync(folderType, userId);
  638. var result = new MiddleDefaultResult();
  639. result.IsDefault = recordFolder != null;
  640. result.FolderName = recordFolder == null ? "" : recordFolder.FolderName;
  641. result.FolderType = recordFolder == null ? 0 : recordFolder.FolderType;
  642. result.MiddleId = recordFolder == null ? 0 : recordFolder.FolderId;
  643. return result;
  644. }
  645. /// <summary>
  646. /// 获取话题 笔记共享范围文件夹
  647. /// </summary>
  648. /// <param name="request"></param>
  649. /// <returns></returns>
  650. public async Task<List<MiddleSearchFolderResult>> SearchNoteFolderAsync(MiddleSearchFolderRequest request)
  651. {
  652. var query = Q.NewQuery();
  653. query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId)
  654. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  655. .Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId)
  656. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  657. .Where(nameof(Entity.Middle.Middle.IsDelete), false).WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds).WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int>() { 1, 3 });
  658. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  659. query.Where(nameof(Entity.Middle.Middle.FolderName), request.KeyWord);
  660. var middles = await _middleRepository.FindAsync(query.OrderByDesc(
  661. nameof(Entity.Middle.Middle.AttributeValue), nameof(Entity.Middle.Middle.IsTop),
  662. nameof(Entity.Middle.Middle.CreatedDate)));
  663. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  664. foreach (var item in middles)
  665. {
  666. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  667. {
  668. Name = item.FolderName,
  669. Id = item.Id,
  670. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  671. RoleId = item.RoleId,
  672. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  673. IsTop = item.IsTop
  674. };
  675. if (item.RoleId == 3)
  676. {
  677. var sourceId = item.Id;
  678. if (item.ParentId != 0)
  679. sourceId = item.MiddleSonId;
  680. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  681. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  682. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  683. //middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  684. }
  685. result.Add(middleSearchFolderResult);
  686. }
  687. return result;
  688. }
  689. /// <summary> =-
  690. /// 删除全部
  691. /// </summary>
  692. /// <param name="folderType"></param>
  693. /// <param name="userId"></param>
  694. /// <returns></returns>
  695. public async Task<bool> DeleteAllAsync(int folderType, int userId)
  696. {
  697. return await _middleRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.Middle.FolderType), folderType).Where(nameof(Entity.Middle.Middle.UserId), userId).Where(nameof(Entity.Middle.Middle.IsDelete), true));
  698. }
  699. }
  700. }