XthxController.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. using Hotline.Application.Xthx;
  2. using Hotline.Caching.Interfaces;
  3. using Hotline.CallCenter.Tels;
  4. using Hotline.Settings;
  5. using Hotline.Share.Dtos.CallCenter;
  6. using Hotline.Share.Enums.CallCenter;
  7. using MapsterMapper;
  8. using Microsoft.AspNetCore.Authorization;
  9. using Microsoft.AspNetCore.Mvc;
  10. using SqlSugar;
  11. using System.Text.Json;
  12. using XF.Domain.Authentications;
  13. using XF.Domain.Exceptions;
  14. using XF.Domain.Repository;
  15. namespace Hotline.Api.Controllers
  16. {
  17. /// <summary>
  18. /// 兴唐恒信
  19. /// </summary>
  20. public class XthxController : BaseController
  21. {
  22. #region 注入
  23. private readonly IMapper _mapper;
  24. private readonly ISessionContext _sessionContext;
  25. private readonly IXthxApplication _xthxApplication;
  26. private readonly ISystemSettingCacheManager _systemSettingCacheManager; //系统参数
  27. private readonly IRepository<TelOperationXthx> _telOperationXthxRepository; //坐席动作类型
  28. private readonly IRepository<TelOperationXthxLog> _telOperationXthxLogRepository; //坐席动作类型
  29. public XthxController(
  30. IMapper mapper,
  31. ISessionContext sessionContext,
  32. IXthxApplication xthxApplication,
  33. ISystemSettingCacheManager systemSettingCacheManager,
  34. IRepository<TelOperationXthx> telOperationXthxRepository,
  35. IRepository<TelOperationXthxLog> telOperationXthxLogRepository)
  36. {
  37. _mapper = mapper;
  38. _sessionContext = sessionContext;
  39. _xthxApplication = xthxApplication;
  40. _systemSettingCacheManager = systemSettingCacheManager;
  41. _telOperationXthxRepository = telOperationXthxRepository;
  42. _telOperationXthxLogRepository = telOperationXthxLogRepository;
  43. }
  44. #endregion
  45. #region 分机状态变更接收
  46. /// <summary>
  47. /// 分机状态变更接收
  48. /// </summary>
  49. /// <param name="dto"></param>
  50. /// <returns></returns>
  51. [HttpPost("status/add")]
  52. [AllowAnonymous]
  53. public async Task<string> AddOperationAsync([FromBody] TelOperationXthxDto dto)
  54. {
  55. #region 描述
  56. /*
  57. 1、根据分机号(telNo)和员工号(staffNo)确定唯一关系。
  58. 2、设计话机动作状态【签入、示忙、小休】
  59. 3、当【签入】时记录签入状态、开始时间,当【签出】时找到未结束的签入记录更新结束时间。
  60. 先结束之前的【签入】,再重新【签入】
  61. 4、当【示忙】时记录示忙状态、开始时间,当传入非【示忙】状态,并且有未结束的【示忙】状态时更新结束时间。
  62. 先结束之前的【示忙】,再重新【示忙】
  63. 5、当【小休】时记录小休状态、开始时间,当传入非【小休】状态,并且有未结束的【小休】状态时更新结束时间。
  64. 先结束之前的【小休】,再重新【小休】
  65. 6、当【空闲】时,需要检查示忙、小休是否结束,未结束需要结束
  66. 7、当【签出】时,需要检查示忙、小休是否结束,未结束需要结束
  67. 8、除了【签入签出】状态,其他状态都要验证当前是否有【签入】,没有则新增签入
  68. */
  69. #endregion
  70. #region 鉴权
  71. var settingBase = _systemSettingCacheManager.GetSetting(SettingConstants.XthxVerificationStatusAdd)?.SettingValue[0];
  72. if (settingBase != null)
  73. {
  74. TelAppXthxDto telAppDto = JsonSerializer.Deserialize<TelAppXthxDto>(settingBase);
  75. if (dto.appId != telAppDto.appId || dto.appSecret != telAppDto.appSecret)
  76. throw UserFriendlyException.SameMessage("appId或者appSecret错误");
  77. }
  78. #endregion
  79. // 查询日期间隔天数
  80. var day = 3;
  81. // 增加动作日志
  82. var id = await _xthxApplication.AddOperationLogAsync(dto, HttpContext.RequestAborted);
  83. if (!string.IsNullOrEmpty(id))
  84. {
  85. if (dto.Status == EOperationStatus.SignIn)
  86. {
  87. #region 签入 100
  88. var xthxList = await _telOperationXthxRepository.Queryable()
  89. .Where(x => x.TelNo == dto.TelNo &&
  90. x.StaffNo == dto.StaffNo &&
  91. x.OperationStatus == EOperationStatus.SignIn &&
  92. SqlFunc.DateDiff(DateType.Day, x.CreationTime, DateTime.Now) < day).ToListAsync();
  93. if (xthxList != null && xthxList.Count > 0)
  94. {
  95. // 判断是否存在数据,存在数据需要判断结束时间是否为空
  96. var rowSign = xthxList.Where(x => x.EndTime == null).ToList();//.Select("EndTime is null");
  97. if (rowSign != null && rowSign.Count > 0)
  98. {// 如果结束时间为空 结束之前的(签收、示忙、小休)
  99. foreach (var item in rowSign)
  100. {
  101. await _xthxApplication.UpdateOperationAsync(id, item.Id, HttpContext.RequestAborted);
  102. }
  103. }
  104. }
  105. await _xthxApplication.AddOperationAsync(dto, id, HttpContext.RequestAborted);
  106. #endregion
  107. }
  108. if (dto.Status == EOperationStatus.ShowBusy)
  109. {
  110. #region 示忙 202
  111. var xthxList = await _telOperationXthxRepository.Queryable()
  112. .Where(x => x.TelNo == dto.TelNo &&
  113. x.StaffNo == dto.StaffNo &&
  114. x.OperationStatus == EOperationStatus.ShowBusy &&
  115. SqlFunc.DateDiff(DateType.Day, x.CreationTime, DateTime.Now) < day).ToListAsync();
  116. if (xthxList != null && xthxList.Count > 0)
  117. {
  118. // 判断是否存在数据,存在数据需要判断结束时间是否为空
  119. var rowSign = xthxList.Where(x => x.EndTime == null).ToList();//.Select("EndTime is null");
  120. if (rowSign != null && rowSign.Count > 0)
  121. {// 如果结束时间为空 结束之前的(签收、示忙、小休)
  122. foreach (var item in rowSign)
  123. {
  124. await _xthxApplication.UpdateOperationAsync(id, item.Id, HttpContext.RequestAborted);
  125. }
  126. }
  127. }
  128. await _xthxApplication.AddOperationAsync(dto, id, HttpContext.RequestAborted);
  129. #endregion
  130. }
  131. if (dto.Status == EOperationStatus.ShortBreak)
  132. {
  133. #region 小休 201
  134. var xthxList = await _telOperationXthxRepository.Queryable()
  135. .Where(x => x.TelNo == dto.TelNo &&
  136. x.StaffNo == dto.StaffNo &&
  137. x.OperationStatus == EOperationStatus.ShortBreak &&
  138. SqlFunc.DateDiff(DateType.Day, x.CreationTime, DateTime.Now) < day).ToListAsync();
  139. if (xthxList != null && xthxList.Count > 0)
  140. {
  141. // 判断是否存在数据,存在数据需要判断结束时间是否为空
  142. var rowSign = xthxList.Where(x => x.EndTime == null).ToList();//.Select("EndTime is null");
  143. if (rowSign != null && rowSign.Count > 0)
  144. {// 如果结束时间为空 结束之前的(签收、示忙、小休)
  145. foreach (var item in rowSign)
  146. {
  147. await _xthxApplication.UpdateOperationAsync(id, item.Id, HttpContext.RequestAborted);
  148. }
  149. }
  150. }
  151. await _xthxApplication.AddOperationAsync(dto, id, HttpContext.RequestAborted);
  152. #endregion
  153. }
  154. else if (dto.Status == EOperationStatus.FreeTime)
  155. {
  156. #region 空闲 200
  157. // 当【空闲】时,需要检查示忙、小休是否结束,未结束需要结束
  158. var sign = await _telOperationXthxRepository.Queryable()
  159. .Where(x => x.TelNo == dto.TelNo &&
  160. x.StaffNo == dto.StaffNo &&
  161. (x.OperationStatus == EOperationStatus.ShowBusy ||
  162. x.OperationStatus == EOperationStatus.ShortBreak) &&
  163. x.StartTime != null &&
  164. x.EndTime == null)
  165. .ToListAsync();
  166. if (sign != null)
  167. {
  168. // 判断是否有签入未结束的动作
  169. foreach (var item in sign)
  170. {
  171. await _xthxApplication.UpdateOperationAsync(id, item.Id!, HttpContext.RequestAborted);
  172. }
  173. }
  174. #endregion
  175. }
  176. else if (dto.Status == EOperationStatus.SignOut)
  177. {
  178. #region 签出 0
  179. // 当【签出】时,需要检查示忙、小休是否结束,未结束需要结束
  180. var sign = await _telOperationXthxRepository.Queryable()
  181. .Where(x => x.TelNo == dto.TelNo &&
  182. x.StaffNo == dto.StaffNo &&
  183. (x.OperationStatus == EOperationStatus.SignIn ||
  184. x.OperationStatus == EOperationStatus.ShowBusy ||
  185. x.OperationStatus == EOperationStatus.ShortBreak) &&
  186. x.StartTime != null &&
  187. x.EndTime == null)
  188. .ToListAsync();
  189. if (sign != null)
  190. {
  191. // 判断是否有签入未结束的动作
  192. foreach (var item in sign)
  193. {
  194. await _xthxApplication.UpdateOperationAsync(id, item.Id!, HttpContext.RequestAborted);
  195. }
  196. }
  197. #endregion
  198. }
  199. else
  200. {
  201. #region 其他动作
  202. // 除了【签入签出】状态,其他状态都要验证当前是否有【签入】,没有则新增
  203. var sign = await _telOperationXthxRepository.Queryable()
  204. .Where(x => x.TelNo == dto.TelNo &&
  205. x.StaffNo == dto.StaffNo &&
  206. x.OperationStatus == EOperationStatus.SignIn &&
  207. x.StartTime != null &&
  208. x.EndTime == null)
  209. .ToListAsync();
  210. if (sign.Count == 0)
  211. {
  212. // 未找到数据 新增
  213. dto.Status = EOperationStatus.SignIn;
  214. await _xthxApplication.AddOperationAsync(dto, id, HttpContext.RequestAborted);
  215. }
  216. #endregion
  217. }
  218. }
  219. return id;
  220. }
  221. #endregion
  222. }
  223. }