GroupChatRepository.cs 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading.Tasks;
  4. using System.Transactions;
  5. using AutoMapper;
  6. using GxPress.Common.AppOptions;
  7. using GxPress.Common.Exceptions;
  8. using GxPress.Common.Tools;
  9. using GxPress.Entity;
  10. using GxPress.EnumConst;
  11. using GxPress.Repository.Interface;
  12. using GxPress.Request.App.IM;
  13. using GxPress.Request.GroupChat;
  14. using Microsoft.AspNetCore.Hosting;
  15. using Microsoft.Extensions.Options;
  16. using Newtonsoft.Json;
  17. using Datory;
  18. using System.Linq;
  19. using GxPress.Result.App.GroupChat;
  20. using Dapper;
  21. namespace GxPress.Repository.Implement
  22. {
  23. public class GroupChatRepository : IGroupChatRepository
  24. {
  25. private readonly Repository<GroupChat> _repository;
  26. private readonly Repository<User> _userRepository;
  27. private readonly Repository<GroupChatUser> _groupChatUserRepository;
  28. private readonly Repository<OftenContact> _oftenContactRepository;
  29. private readonly IWebHostEnvironment _environment;
  30. private readonly Repository<Entity.Middle.Middle> _middleRepository;
  31. private readonly IMapper _mapper;
  32. private readonly string _connectionString;
  33. private readonly string _databaseTypeStr;
  34. public GroupChatRepository(IOptionsMonitor<DatabaseOptions> dbOptionsAccessor, IMapper mapper, IWebHostEnvironment environment)
  35. {
  36. _databaseTypeStr = dbOptionsAccessor.CurrentValue.DatabaseType;
  37. _connectionString = dbOptionsAccessor.CurrentValue.ConnectionString;
  38. var databaseType = StringUtils.ToEnum<DatabaseType>(dbOptionsAccessor.CurrentValue.DatabaseType, DatabaseType.MySql);
  39. var database = new Database(databaseType, dbOptionsAccessor.CurrentValue.ConnectionString);
  40. _repository = new Repository<GroupChat>(database);
  41. _userRepository = new Repository<User>(database);
  42. _groupChatUserRepository = new Repository<GroupChatUser>(database);
  43. _oftenContactRepository = new Repository<OftenContact>(database);
  44. _middleRepository = new Repository<Entity.Middle.Middle>(database);
  45. _environment = environment;
  46. _mapper = mapper;
  47. }
  48. public IDatabase Database => _repository.Database;
  49. public string TableName => _repository.TableName;
  50. public List<TableColumn> TableColumns => _repository.TableColumns;
  51. /// <summary>
  52. /// 添加群
  53. /// </summary>
  54. /// <param name="request"></param>
  55. /// <returns></returns>
  56. public async Task<bool> InsertAsync(GroupChatInRequest request)
  57. {
  58. var user = await _userRepository.GetAsync(request.UserId);
  59. if (user == null)
  60. throw new BusinessException("用户不存在");
  61. try
  62. {
  63. using (TransactionScope transactionScope = new TransactionScope())
  64. {
  65. //创建群
  66. var groupChat = new GroupChat
  67. {
  68. GroupChatImId = request.GroupChatImId,
  69. Introduce = request.Introduce,
  70. IsAdmin = request.IsAdmin,
  71. IsWords = request.IsWords,
  72. Name = request.Name,
  73. UserId = request.UserId,
  74. IsOpenQrCoder = true
  75. };
  76. if (!string.IsNullOrEmpty(request.AvatarUrl))
  77. groupChat.AvatarUrl = StringUtils.RemoveDomain(request.AvatarUrl);
  78. var groupChatId = await _repository.InsertAsync(groupChat);
  79. //
  80. var groupChatDto = await _repository.GetAsync(groupChatId);
  81. //生成二维码
  82. var qrCodeData = new { key = QRCodeTypeConst.GroupChatInfo, value = groupChatDto.Guid };
  83. var resultPath =
  84. FileHelper.SaveQRCodeFile(StringUtils.GetWebRootPath(_environment.WebRootPath),
  85. JsonConvert.SerializeObject(qrCodeData));
  86. groupChatDto.QRCoder = resultPath.RelativePath;
  87. await _repository.UpdateAsync(groupChatDto);
  88. //默认添加管理员为群成员
  89. var groupChatUser = new GroupChatUser
  90. {
  91. GroupChatId = groupChatId,
  92. UserId = request.UserId,
  93. ImId = user.ImId,
  94. IsAdmin = true,
  95. GroupChatImId = request.GroupChatImId
  96. };
  97. //创建环信Mi群
  98. await _groupChatUserRepository.InsertAsync(groupChatUser);
  99. //建立关系
  100. var oftenContact = new OftenContact
  101. {
  102. ChatType = 2,
  103. ContactUserId = groupChat.GroupChatImId,
  104. IndividualGroupId = 0,
  105. UserId = request.UserId
  106. };
  107. var oftenContactId = await _oftenContactRepository.InsertAsync(oftenContact);
  108. //添加middle
  109. var middle = new Entity.Middle.Middle();
  110. middle.IsAdmin = true;
  111. middle.MiddleId = oftenContactId;
  112. middle.FolderType = 10;
  113. middle.IsDefault = false;
  114. middle.IsDelete = false;
  115. middle.UserId = request.UserId;
  116. middle.IsRead = false;
  117. middle.IsTop = false;
  118. middle.ParentId = request.FolderId;
  119. await _middleRepository.InsertAsync(middle);
  120. //添加用户
  121. // foreach (var userId in request.UserIds)
  122. // {
  123. // if (userId == request.UserId)
  124. // continue;
  125. // oftenContact = new OftenContact
  126. // {
  127. // ChatType = 2,
  128. // ContactUserId = groupChat.GroupChatImId,
  129. // IndividualGroupId = 0,
  130. // UserId = userId
  131. // };
  132. // user = await _userRepository.GetAsync(userId);
  133. // groupChatUser = new GroupChatUser
  134. // {
  135. // GroupChatId = groupChatId,
  136. // UserId = userId,
  137. // ImId = user.ImId,
  138. // IsAdmin = false,
  139. // GroupChatImId = request.GroupChatImId
  140. // };
  141. // //创建环信Mi群
  142. // await _groupChatUserRepository.InsertAsync(groupChatUser);
  143. // }
  144. transactionScope.Complete();
  145. }
  146. }
  147. catch (Exception e)
  148. {
  149. throw new BusinessException(e.Message);
  150. }
  151. return true;
  152. }
  153. /// <summary>
  154. /// 群添加用户
  155. /// </summary>
  156. /// <param name="request"></param>
  157. /// <returns></returns>
  158. public async Task<bool> InsertUsersIntoGroupChatAsync(InsertGroupChatUsersRequest request)
  159. {
  160. try
  161. {
  162. using (TransactionScope transactionScope = new TransactionScope())
  163. {
  164. var groupChat =
  165. await _repository.GetAsync(Q.Where(nameof(GroupChat.GroupChatImId), request.GroupChatImId));
  166. if (groupChat == null)
  167. return false;
  168. //添加用户
  169. foreach (var user in request.Users)
  170. {
  171. if (user.Id == groupChat.UserId)
  172. continue;
  173. var oftenContact = new OftenContact
  174. {
  175. ChatType = 2,
  176. ContactUserId = groupChat.GroupChatImId,
  177. IndividualGroupId = 0,
  178. UserId = user.Id
  179. };
  180. var oftenContactId = await _oftenContactRepository.InsertAsync(oftenContact);
  181. //添加middle
  182. var middle = new Entity.Middle.Middle();
  183. middle.IsAdmin = true;
  184. middle.MiddleId = oftenContactId;
  185. middle.FolderType = 10;
  186. middle.IsDefault = false;
  187. middle.IsDelete = false;
  188. middle.UserId = user.Id;
  189. middle.IsRead = false;
  190. middle.IsTop = false;
  191. middle.ParentId = 0;
  192. await _middleRepository.InsertAsync(middle);
  193. var groupChatUser = new GroupChatUser
  194. {
  195. GroupChatId = groupChat.Id,
  196. UserId = user.Id,
  197. ImId = user.ImId,
  198. GroupChatImId = request.GroupChatImId,
  199. IsAdmin = false
  200. };
  201. //创建环信Mi群
  202. var id = await _groupChatUserRepository.InsertAsync(groupChatUser);
  203. }
  204. transactionScope.Complete();
  205. }
  206. }
  207. catch (Exception e)
  208. {
  209. Console.WriteLine(e);
  210. throw;
  211. }
  212. return true;
  213. }
  214. /// <summary>
  215. /// 删除群用户
  216. /// </summary>
  217. /// <param name="request"></param>
  218. /// <returns></returns>
  219. public async Task<bool> DeleteUsersIntoGroupChatAsync(InsertGroupChatUsersRequest request)
  220. {
  221. try
  222. {
  223. using (TransactionScope transactionScope = new TransactionScope())
  224. {
  225. var groupChat =
  226. await _repository.GetAsync(Q.Where(nameof(GroupChat.GroupChatImId), request.GroupChatImId));
  227. if (groupChat == null)
  228. return false;
  229. //删除群用户
  230. await _groupChatUserRepository.DeleteAsync(Q.Where(nameof(GroupChatUser.GroupChatId), groupChat.Id)
  231. .WhereIn(nameof(GroupChatUser.UserId), request.UserIds));
  232. //删除关系
  233. var oftenContact = await _oftenContactRepository.GetAsync(Q
  234. .Where(nameof(OftenContact.ContactUserId), request.GroupChatImId)
  235. .WhereIn(nameof(OftenContact.UserId), request.UserIds));
  236. //删除middle
  237. await _middleRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.Middle.MiddleId), oftenContact.Id).Where(nameof(Entity.Middle.Middle.FolderType), 10));
  238. await _oftenContactRepository.DeleteAsync(Q
  239. .Where(nameof(OftenContact.ContactUserId), request.GroupChatImId)
  240. .WhereIn(nameof(OftenContact.UserId), request.UserIds));
  241. transactionScope.Complete();
  242. }
  243. }
  244. catch (Exception e)
  245. {
  246. Console.WriteLine(e);
  247. throw;
  248. }
  249. return true;
  250. }
  251. /// <summary>
  252. /// 修改群信息
  253. /// </summary>
  254. /// <param name="request"></param>
  255. /// <returns></returns>
  256. public async Task<bool> UpdateAsync(GroupChatUpRequest request)
  257. {
  258. var groupChat = await _repository.GetAsync(request.Id);
  259. if (groupChat == null)
  260. throw new BusinessException("群不存在");
  261. if (!string.IsNullOrEmpty(request.AvatarUrl))
  262. groupChat.AvatarUrl = StringUtils.RemoveDomain(request.AvatarUrl);
  263. if (!string.IsNullOrEmpty(request.Introduce))
  264. groupChat.Introduce = request.Introduce;
  265. if (!string.IsNullOrEmpty(request.Name))
  266. groupChat.Name = request.Name;
  267. if (!string.IsNullOrEmpty(request.QrCode))
  268. groupChat.QRCoder = StringUtils.RemoveDomain(request.QrCode);
  269. return await _repository.UpdateAsync(groupChat);
  270. }
  271. /// <summary>
  272. /// 删除群
  273. /// </summary>
  274. /// <param name="id"></param>
  275. /// <returns></returns>
  276. public async Task<bool> DeleteAsync(int id)
  277. {
  278. var groupChat = await _repository.GetAsync(id);
  279. if (groupChat == null)
  280. throw new BusinessException("群不存在");
  281. try
  282. {
  283. //增加事务
  284. using (TransactionScope scope = new TransactionScope())
  285. {
  286. //删除群
  287. await _groupChatUserRepository.DeleteAsync(Q.Where(nameof(GroupChatUser.GroupChatId), id));
  288. await _repository.DeleteAsync(id);
  289. //删除middle
  290. var oftenContacts = await _oftenContactRepository.GetAllAsync(Q.WhereIn(nameof(OftenContact.ContactUserId), groupChat.GroupChatImId));
  291. await _middleRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Middle.Middle.MiddleId), oftenContacts.Select(n => n.Id)).Where(nameof(Entity.Middle.Middle.FolderType), 10));
  292. //删除关系界面
  293. await _oftenContactRepository.DeleteAsync(Q.WhereIn(nameof(OftenContact.ContactUserId), groupChat.GroupChatImId));
  294. scope.Complete();
  295. return true;
  296. }
  297. }
  298. catch (Exception e)
  299. {
  300. throw new BusinessException(e.Message);
  301. }
  302. }
  303. /// <summary>
  304. /// 获取用户群
  305. /// </summary>
  306. /// <param name="request"></param>
  307. /// <returns></returns>
  308. public async Task<IEnumerable<GroupChat>> GetGroupChatByUserIdAsync(GroupChatSearchRequest request)
  309. {
  310. //var groupChat = await _repository.GetAsync(request.UserId);
  311. //if (groupChat == null)
  312. // throw new BusinessException("群不存在");
  313. //获取参与群
  314. var groupChatUsers = await _groupChatUserRepository.GetAllAsync(Q.Where(nameof(GroupChatUser.UserId)));
  315. var groupChats = new List<GroupChat>();
  316. foreach (var item in groupChatUsers)
  317. {
  318. groupChats.Add(await _repository.GetAsync(item.GroupChatId));
  319. }
  320. foreach (var groupChatItem in groupChats)
  321. {
  322. groupChatItem.AvatarUrl = StringUtils.AddDomainMin(groupChatItem.AvatarUrl);
  323. }
  324. return groupChats;
  325. }
  326. /// <summary>
  327. /// 修改是否管理员同意
  328. /// </summary>
  329. /// <param name="request"></param>
  330. /// <returns></returns>
  331. public async Task<bool> UpIsAdminAsync(GroupChatUpIsAdminRequest request)
  332. {
  333. var groupChat = await _repository.GetAsync(request.Id);
  334. if (groupChat == null)
  335. throw new BusinessException("群不存在");
  336. return await _repository.UpdateAsync(Q.Where(nameof(GroupChat.Id), request.Id)
  337. .Set(nameof(GroupChat.IsAdmin), !groupChat.IsAdmin)) > 0;
  338. }
  339. /// <summary>
  340. /// 修改是否禁言
  341. /// </summary>
  342. /// <param name="request"></param>
  343. /// <returns></returns>
  344. public async Task<bool> UpIsWordsAsync(GroupChatUpIsWordsRequest request)
  345. {
  346. var groupChat = await _repository.GetAsync(request.Id);
  347. if (groupChat == null)
  348. throw new BusinessException("群不存在");
  349. return await _repository.UpdateAsync(Q.Where(nameof(GroupChat.Id), request.Id).Set(nameof(groupChat.IsWords), !groupChat.IsWords)) > 0;
  350. }
  351. public async Task<GroupChat> FindGroupChatByIdAsync(int id)
  352. {
  353. return await _repository.GetAsync(id);
  354. }
  355. public async Task<GroupChat> GetAsync(int id)
  356. {
  357. return await _repository.GetAsync(id);
  358. }
  359. public async Task<GroupChat> GetAsync(SqlKata.Query query)
  360. {
  361. return await _repository.GetAsync(query);
  362. }
  363. public async Task<GroupChat> GetGroupChatByImIdAsync(string imId)
  364. {
  365. var groupChat = await _repository.GetAsync(Q.Where(nameof(GroupChat.GroupChatImId), imId));
  366. groupChat.AvatarUrl = Common.Tools.StringUtils.AddDomainMin(groupChat.AvatarUrl);
  367. groupChat.QRCoder = Common.Tools.StringUtils.AddDomain(groupChat.QRCoder);
  368. return groupChat;
  369. }
  370. /// <summary>
  371. /// 根据ImId获取群信息
  372. /// </summary>
  373. /// <param name="imId"></param>
  374. /// <returns></returns>
  375. public async Task<GroupChatInfoResult> GetGroupChatInfoByImIdAsync(string imId)
  376. {
  377. var sql = $"select *,(select Name from ccpph.tede_user where id=a.UserId) as UserName from ccpph.tede_group_chat a where a.GroupChatImId='{imId}';";
  378. var databaseType = StringUtils.ToEnum<DatabaseType>(_databaseTypeStr, DatabaseType.MySql);
  379. var database = new Database(databaseType, _connectionString);
  380. var connection = database.GetConnection();
  381. var result = await connection.QueryFirstOrDefaultAsync<GroupChatInfoResult>(sql);
  382. if (result == null)
  383. return new GroupChatInfoResult();
  384. result.QRCoder = StringUtils.AddDomain(result.QRCoder);
  385. result.AvatarUrl = StringUtils.AddDomainMin(result.AvatarUrl);
  386. return result;
  387. }
  388. public async Task<IEnumerable<GroupChat>> GetAllGroupChatAsync()
  389. {
  390. return await _repository.GetAllAsync();
  391. }
  392. /// <summary>
  393. /// 根据Guid获取群信息
  394. /// </summary>
  395. /// <param name="guid"></param>
  396. /// <returns></returns>
  397. public async Task<GroupChat> GetGroupChatByGuidAsync(string guid)
  398. {
  399. return await _repository.GetAsync(Q.Where(nameof(GroupChat.Guid), guid));
  400. }
  401. /// <summary>
  402. /// set群是否开启
  403. /// </summary>
  404. /// <param name="groupChatImId"></param>
  405. /// <param name="userId"></param>
  406. /// <returns></returns>
  407. public async Task<bool> SetIsOpenQrCoderAsync(string groupChatImId, int userId)
  408. {
  409. var groupChat = await _repository.GetAsync(Q.Where(nameof(GroupChat.GroupChatImId), groupChatImId));
  410. if (groupChat.UserId != userId)
  411. throw new BusinessException("不是群主无法设置");
  412. if (groupChat == null)
  413. throw new BusinessException("群不存在");
  414. return await _repository.UpdateAsync(Q.Set(nameof(groupChat.IsOpenQrCoder), !groupChat.IsOpenQrCoder)
  415. .Where(nameof(groupChat.Id), groupChat.Id)) > 0;
  416. }
  417. /// <summary>
  418. /// 获取用户加入的群
  419. /// </summary>
  420. /// <param name="request"></param>
  421. /// <returns></returns>
  422. public async Task<IEnumerable<GroupChat>> GetGroupChatsAsync(GroupChatSearchRequest request)
  423. {
  424. var sqlStr = string.Empty;
  425. if (!string.IsNullOrEmpty(request.KeyWord))
  426. sqlStr = $" and a.Name like '%{request.KeyWord}%'";
  427. string sql = $@"SELECT
  428. *,(select count(1) from tede_group_chat_user where GroupChatId=a.Id) as UserCount
  429. FROM
  430. tede_group_chat a
  431. WHERE
  432. 1=1 {sqlStr} and a.id IN (SELECT
  433. GroupChatId
  434. FROM
  435. tede_group_chat_user
  436. WHERE
  437. UserId = {request.UserId})
  438. ORDER BY a.CreatedDate DESC";
  439. var databaseType = StringUtils.ToEnum<DatabaseType>(_databaseTypeStr, DatabaseType.MySql);
  440. var database = new Database(databaseType, _connectionString);
  441. var connection = database.GetConnection();
  442. var result = await connection.QueryAsync<GroupChat>(sql);
  443. foreach (var item in result)
  444. {
  445. item.QRCoder = StringUtils.AddDomain(item.QRCoder);
  446. item.AvatarUrl = StringUtils.AddDomainMin(item.AvatarUrl);
  447. }
  448. return result;
  449. }
  450. }
  451. }