新野县12345_后端

CallPlanWork.cs 3.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. using CallCenterApi.Model;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace CallCenter.QuartzService
  8. {
  9. public class CallPlanWork : QuartzJob
  10. {
  11. public CallPlanWork()
  12. {
  13. CronExpression = "/30 * * * * ?";
  14. DoWork += MyWork_DoWork;
  15. }
  16. private readonly CallCenterApi.BLL.T_CTI_Task taskBLL = new CallCenterApi.BLL.T_CTI_Task();
  17. private readonly CallCenterApi.BLL.T_Call_TaskTelNum taskNumBLL = new CallCenterApi.BLL.T_Call_TaskTelNum();
  18. private List<long> taskIdList = new List<long>();
  19. private void MyWork_DoWork(object sender, EventArgs e)
  20. {
  21. var now = DateTime.Now;
  22. var taskList = taskBLL.DataTableToList(taskBLL.GetTaskList(" State>0 ").Tables[0]).Where(x => x.PlanStartDate < now && now < x.PlanEndDate).ToList();
  23. #region 外呼任务状态由【暂停】=>【处理中】
  24. var startList = taskList.Where(x => x.State == (int)EnumTaskState.暂停 && ((x.StartTime1.TimeOfDay < now.TimeOfDay && now.TimeOfDay < x.EndTime1.TimeOfDay) || (x.StartTime2.TimeOfDay < now.TimeOfDay && now.TimeOfDay < x.EndTime2.TimeOfDay))).ToList();
  25. if (startList.Count > 0)
  26. {
  27. var startFlag = taskBLL.UpdateStateBatch($" where TaskID in ({string.Join(", ", startList.Select(x => x.TaskID).ToArray())})", (int)EnumTaskState.处理中);
  28. }
  29. #endregion
  30. #region 外呼任务状态由【处理中】=>【处理完成】
  31. var query = taskList.Where(x => x.State == (int)EnumTaskState.处理中).ToList();
  32. foreach (var item in query)
  33. {
  34. var taskNumList = taskNumBLL.DataTableToList(taskNumBLL.GetList(" F_TaskId=" + item.TaskID).Tables[0]);
  35. var allCount = taskNumList.Count();
  36. var connected = taskNumList.Where(x => x.F_YJState == 1).Count();
  37. //item.LoopTime 默认为0; F_HCCount默认为0; 所以这里判断要用 item.LoopTime + 1
  38. var notconnected = taskNumList.Where(x => x.F_YJState == 0 && x.F_HCCount == (item.LoopTime + 1)).Count();
  39. if (allCount == (connected + notconnected))
  40. {
  41. taskIdList.Add(item.TaskID);
  42. }
  43. }
  44. if (taskIdList.Count > 0)
  45. {
  46. taskBLL.UpdateStateBatch($" where TaskID in ({string.Join(", ", taskIdList.Select(x => x).ToArray())})", (int)EnumTaskState.处理完成);
  47. }
  48. #endregion
  49. #region 外呼任务状态由【处理中】=>【暂停】
  50. var closeList = query.Where(x => x.State == (int)EnumTaskState.处理中 && (x.StartTime1.TimeOfDay > now.TimeOfDay || (now.TimeOfDay > x.EndTime1.TimeOfDay && now.TimeOfDay < x.StartTime2.TimeOfDay) || now.TimeOfDay > x.EndTime2.TimeOfDay)).ToList();
  51. if (closeList.Count > 0)
  52. {
  53. var closeFlag = taskBLL.UpdateStateBatch($" where TaskID in ({string.Join(", ", closeList.Select(x => x.TaskID).ToArray())})", (int)EnumTaskState.暂停);
  54. }
  55. #endregion
  56. }
  57. }
  58. }