TmtnPushMsgToService.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. using AutoMapper;
  2. using LinqKit;
  3. using Ropin.Inspection.Common.Accessor.Interface;
  4. using Ropin.Inspection.Common.Helper;
  5. using Ropin.Inspection.Model;
  6. using Ropin.Inspection.Model.Entities;
  7. using Ropin.Inspection.Repository;
  8. using Ropin.Inspection.Repository.Interface;
  9. using System;
  10. using System.Collections.Generic;
  11. using System.Linq;
  12. using System.Linq.Expressions;
  13. using System.Net.Http;
  14. using System.Text;
  15. using System.Threading.Tasks;
  16. namespace Ropin.Inspection.Service
  17. {
  18. public class TmtnPushMsgToService : ITmtnPushMsgToService
  19. {
  20. private readonly ITmtnPushMsgToRepository _repository;
  21. private readonly IMapper _mapper;
  22. private readonly IClaimsAccessor _claims;
  23. private readonly IHttpClientFactory _httpClientFactory;
  24. private readonly ITmtnPushMsgResultRepository _tmtnPushMsgResultRepository;
  25. public TmtnPushMsgToService(IClaimsAccessor claims,
  26. IHttpClientFactory httpClientFactory,
  27. ITmtnPushMsgToRepository repository,
  28. ITmtnPushMsgResultRepository tmtnPushMsgResultRepository,
  29. IMapper mapper)
  30. {
  31. _repository = repository;
  32. _mapper = mapper;
  33. _claims = claims;
  34. _httpClientFactory = httpClientFactory;
  35. _tmtnPushMsgResultRepository = tmtnPushMsgResultRepository;
  36. }
  37. public async Task CreateOneAsync(TmtnPushMsgToViewModel viewModel)
  38. {
  39. var content = _mapper.Map<TMTN_PushMsgTo>(viewModel);
  40. content.C_ID = Guid.NewGuid().ToString();
  41. content.C_CreateBy = _claims.ApiUserId;
  42. content.D_CreateOn = DateTime.Now;
  43. //content.C_Status = "1";
  44. _repository.Create(content);
  45. var result = await _repository.SaveAsync();
  46. if (!result)
  47. {
  48. throw new Exception("创建失败");
  49. }
  50. }
  51. public async Task CreatePushMsgToListAsync(IEnumerable<TmtnPushMsgToViewModel> viewModelList)
  52. {
  53. var itemList = await _repository.GetByConditionAsync(C => C.C_DevStoreCode == viewModelList.FirstOrDefault().C_DevStoreCode);
  54. var bResult = await _repository.RemoveRangeAsync(itemList);
  55. var contentList = _mapper.Map<IEnumerable<TMTN_PushMsgTo>>(viewModelList);
  56. foreach (var item in contentList)
  57. {
  58. item.C_ID = Guid.NewGuid().ToString();
  59. item.C_CreateBy = _claims.ApiUserId;
  60. item.D_CreateOn = DateTime.Now;
  61. }
  62. var result = await _repository.CreateRangeAsync(contentList);
  63. if (result>0)
  64. {
  65. }
  66. else
  67. {
  68. throw new Exception("创建失败");
  69. }
  70. }
  71. public async Task CreatePushMsgToHaveListAsync(TmtnPushMsgToListCreateModel content)
  72. {
  73. await _repository.DeleteByDevPersonIdAsync(content.C_DevStoreCode, content.C_PushPersonCode);
  74. IList<TMTN_PushMsgTo> pushMsgToList = new List<TMTN_PushMsgTo>();
  75. foreach (var typeItem in content.MsgTypeCodeList)
  76. {
  77. foreach (var pushItem in content.PushTypeCodeList)
  78. {
  79. TMTN_PushMsgTo pushMsgTo = new TMTN_PushMsgTo();
  80. pushMsgTo.C_ID = Guid.NewGuid().ToString();
  81. pushMsgTo.C_CreateBy = _claims.ApiUserId;
  82. pushMsgTo.D_CreateOn = DateTime.Now;
  83. pushMsgTo.C_DevStoreCode = content.C_DevStoreCode;
  84. pushMsgTo.C_PushPersonCode = content.C_PushPersonCode;
  85. pushMsgTo.C_MsgTypeCode = typeItem;
  86. pushMsgTo.C_PushTypeCode = pushItem;
  87. pushMsgToList.Add(pushMsgTo);
  88. }
  89. }
  90. var result = await _repository.CreateRangeAsync(pushMsgToList);
  91. }
  92. public async Task<bool> DeleteByDevPersonIdAsync(TmtnPushMsgToListDelete model)
  93. {
  94. string pushPersonStr = string.Join("','", model.pushPersonList);
  95. int result= await _repository.DeleteByDevPersonIdMultipleAsync(model.C_DevStoreCode, pushPersonStr);
  96. return result>0;
  97. }
  98. public async Task DeleteAsync(Guid id)
  99. {
  100. var content = await _repository.GetByIdAsync(id.ToString());
  101. if (content == null)
  102. {
  103. throw new Exception("数据库中没有此数据");
  104. }
  105. //_repository.Delete(content);
  106. //var result = await _repository.SaveAsync();
  107. //content.C_LastUpdatedBy = _claims.ApiUserId;
  108. //content.D_LastUpdatedOn = DateTime.Now;
  109. //content.C_Status = "0";
  110. _repository.Update(content);
  111. var result = await _repository.SaveAsync();
  112. if (!result)
  113. {
  114. throw new Exception("删除失败");
  115. }
  116. }
  117. public async Task DeleteAsync(string code)
  118. {
  119. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  120. var content = items.FirstOrDefault();
  121. if (content == null)
  122. {
  123. throw new Exception("没有此数据");
  124. }
  125. //content.C_LastUpdatedBy = _claims.ApiUserId;
  126. //content.D_LastUpdatedOn = DateTime.Now;
  127. //content.C_Status = "0";
  128. _repository.Update(content);
  129. var result = await _repository.SaveAsync();
  130. if (!result)
  131. {
  132. throw new Exception("删除失败");
  133. }
  134. }
  135. public async Task<IEnumerable<TmtnPushMsgToViewModel>> GetAllAsync()
  136. {
  137. var pagedList = await _repository.GetAllAsync();
  138. var contentDtoList = _mapper.Map<IEnumerable<TmtnPushMsgToViewModel>>(pagedList.ToList());
  139. return contentDtoList.ToList();
  140. }
  141. public async Task<IEnumerable<TmtnPushMsgToViewModel>> GetConditionAsync(TmtnPushMsgToSearchModel searchModel)
  142. {
  143. var predicate = PredicateBuilder.New<TMTN_PushMsgTo>(true);//查询条件,推荐后台使用这种方式灵活筛选
  144. #region 添加条件查询
  145. //predicate = predicate.And(i => i.C_Status.Equals("1"));
  146. if (!string.IsNullOrEmpty(searchModel.C_DevStoreCode))
  147. {
  148. predicate = predicate.And(i => i.C_DevStoreCode.Equals(searchModel.C_DevStoreCode));
  149. }
  150. if (!string.IsNullOrEmpty(searchModel.C_ID))
  151. {
  152. predicate = predicate.And(i => i.C_ID.Equals(searchModel.C_ID));
  153. }
  154. if (!string.IsNullOrEmpty(searchModel.C_PushPersonCode))
  155. {
  156. predicate = predicate.And(i => i.C_PushPersonCode.Equals(searchModel.C_PushPersonCode));
  157. }
  158. if (!string.IsNullOrEmpty(searchModel.C_MsgTypeCode))
  159. {
  160. predicate = predicate.And(i => i.C_MsgTypeCode.Equals(searchModel.C_MsgTypeCode));
  161. }
  162. if (!string.IsNullOrEmpty(searchModel.C_PushTypeCode))
  163. {
  164. predicate = predicate.And(i => i.C_PushTypeCode.Equals(searchModel.C_PushTypeCode));
  165. }
  166. #endregion
  167. var list = await _repository.GetPageAsync(predicate, "C_DevStoreCode,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  168. searchModel.TotalCount = list.Totals;
  169. var dtoList = _mapper.Map<List<TMTN_PushMsgTo>, List<TmtnPushMsgToViewModel>>(list.Rows);
  170. //List<T_User> userList = new UserTokenBLL().GetAllList();
  171. //var query = from a in dtoList
  172. // join b in userList
  173. // on a.C_CreateBy equals b.C_UserID
  174. // select new SubjectBookViewModel
  175. // {
  176. // K_ID = a.K_ID,
  177. // C_StoreCode = a.C_StoreCode,
  178. // C_Code = a.C_Code,
  179. // C_Name = a.C_Name,
  180. // C_Type = a.C_Type,
  181. // C_ParentCode = a.C_ParentCode,
  182. // C_SubjectPath = a.C_SubjectPath,
  183. // I_Sort = a.I_Sort,
  184. // C_Remark = a.C_Remark,
  185. // C_CreateBy = a.C_CreateBy,
  186. // C_CreateByName = b.C_Name,
  187. // D_CreateOn = a.D_CreateOn,
  188. // C_LastUpdatedBy = a.C_LastUpdatedBy,
  189. // C_LastUpdatedByName = b.C_Name,
  190. // D_LastUpdatedOn = a.D_LastUpdatedOn,
  191. // C_Status = a.C_Status,
  192. // };
  193. //return query.ToList();
  194. return dtoList;
  195. }
  196. public async Task<IEnumerable<TmtnPushMsgToViewModel>> GetPushMsgToHaveListAsync(TmtnPushMsgToSearchModel searchModel)
  197. {
  198. var predicate = PredicateBuilder.New<TMTN_PushMsgTo>(true);//查询条件,推荐后台使用这种方式灵活筛选
  199. #region 添加条件查询
  200. //predicate = predicate.And(i => i.C_Status.Equals("1"));
  201. if (!string.IsNullOrEmpty(searchModel.C_DevStoreCode))
  202. {
  203. predicate = predicate.And(i => i.C_DevStoreCode.Equals(searchModel.C_DevStoreCode));
  204. }
  205. if (!string.IsNullOrEmpty(searchModel.C_ID))
  206. {
  207. predicate = predicate.And(i => i.C_ID.Equals(searchModel.C_ID));
  208. }
  209. if (!string.IsNullOrEmpty(searchModel.C_PushPersonCode))
  210. {
  211. predicate = predicate.And(i => i.C_PushPersonCode.Equals(searchModel.C_PushPersonCode));
  212. }
  213. if (!string.IsNullOrEmpty(searchModel.C_MsgTypeCode))
  214. {
  215. predicate = predicate.And(i => i.C_MsgTypeCode.Equals(searchModel.C_MsgTypeCode));
  216. }
  217. if (!string.IsNullOrEmpty(searchModel.C_PushTypeCode))
  218. {
  219. predicate = predicate.And(i => i.C_PushTypeCode.Equals(searchModel.C_PushTypeCode));
  220. }
  221. #endregion
  222. var list = await _repository.GetPageAsync(predicate, "C_DevStoreCode,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  223. searchModel.TotalCount = list.Totals;
  224. //list.Rows.GroupBy(x => x.C_MsgTypeCode).Select(g=>new
  225. // )
  226. var dtoList = _mapper.Map<List<TMTN_PushMsgTo>, List<TmtnPushMsgToViewModel>>(list.Rows);
  227. return dtoList;
  228. }
  229. public async Task<TmtnPushMsgToViewModel> GetByIdAsync(Guid id)
  230. {
  231. var content = await _repository.GetByIdAsync(id.ToString());
  232. var contentDto = _mapper.Map<TmtnPushMsgToViewModel>(content);
  233. return contentDto;
  234. }
  235. public async Task UpdateAsync(string code, TmtnPushMsgToUpdateModel updateModel)
  236. {
  237. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  238. var content = items.FirstOrDefault();
  239. if (content == null)
  240. {
  241. throw new Exception("没有此数据");
  242. }
  243. //content.C_LastUpdatedBy = _claims.ApiUserId;
  244. //content.D_LastUpdatedOn = DateTime.Now;
  245. _mapper.Map(updateModel, content, typeof(TmtnPushMsgToUpdateModel), typeof(TMTN_PushMsgTo));
  246. _repository.Update(content);
  247. var result = await _repository.SaveAsync();
  248. if (!result)
  249. {
  250. throw new Exception("更新失败");
  251. }
  252. }
  253. public async Task<IEnumerable<TmtnPushMsgToUserViewModel>> GetPushMsgToUsersByAsync(string devStoreCode)
  254. {
  255. var users = await _repository.GetPushMsgToUsersByAsync(devStoreCode);
  256. return users;
  257. }
  258. public async Task<TmtnUserPushMsgToViewModel> GetPushMsgTosByAsync(string devStoreCode, string userCode)
  259. {
  260. var conten = await _repository.GetPushMsgTosByAsync(devStoreCode, userCode);
  261. return conten;
  262. }
  263. public async Task<bool> PushAlarmMsgAsync(TpushMsgModel pushModel)
  264. {
  265. var conten = await _repository.PushAlarmMsgAsync(pushModel);
  266. return conten;
  267. }
  268. public async Task PushMsgAsync(string devStoreCode,string msgTypeCode, TmtnPushMsgResultCreateModel createModel)
  269. {
  270. var users = await _repository.GetPushMsgUserByAsync(devStoreCode, msgTypeCode);
  271. var msg = new
  272. {
  273. thing2 = new { value = "niu" ?? "" },
  274. time4 = new { value = DateTime.Now.ToString("yyyy-MM-dd hh:mm") },
  275. thing5 = new { value = "异常" ?? "" },
  276. thing6 = new { value = "大门损坏" ?? "" },
  277. thing9 = new { value = "msg" ?? "" }
  278. };
  279. List<string> userlist = users.Where(x=>x.C_WechatID!=null).Select(x=>x.C_WechatID).ToList();
  280. new WeChatHelper(_httpClientFactory).PushMessageToUser(userlist, msg);
  281. var content = _mapper.Map<TMTN_PushMsgResult>(createModel);
  282. content.C_ID = Guid.NewGuid().ToString();
  283. content.C_CreateBy = _claims.ApiUserId;
  284. content.D_CreateOn = DateTime.Now;
  285. content.C_Status = "1";
  286. _tmtnPushMsgResultRepository.Create(content);
  287. var result = await _repository.SaveAsync();
  288. if (!result)
  289. {
  290. throw new Exception("创建失败");
  291. }
  292. }
  293. public Task<int> UpdateOneAsync(TmtnPushMsgToViewModel viewModel, params string[] fields)
  294. {
  295. throw new NotImplementedException();
  296. }
  297. public Task<bool> IsExistAsync(Guid id)
  298. {
  299. throw new NotImplementedException();
  300. }
  301. public Task<IEnumerable<TmtnPushMsgToViewModel>> GetByConditionAsync(Expression<Func<TmtnPushMsgToViewModel, bool>> expression)
  302. {
  303. throw new NotImplementedException();
  304. }
  305. public Task UpdateAsync(string code, TpntAreaUpdateModel updateModel)
  306. {
  307. throw new NotImplementedException();
  308. }
  309. public Task<IEnumerable<TmtnPushMsgToViewModel>> GetConditionAsync(TpntAreaSearchModel searchModel)
  310. {
  311. throw new NotImplementedException();
  312. }
  313. }
  314. }