private void endCall()
        {
            CallLogController callLogController = new CallLogController();

            callLog.TimeEnded = DateTime.Now;
            callLogController.Create(callLog);
        }
Beispiel #2
0
        public void Execute(IJobExecutionContext context)
        {
            log.Info("----------now sync calllog----------");
            StudyOnlineEntities entities = new StudyOnlineEntities();

            //过滤条件要求是在当前时间2个小时之前的数据才处理,防止和现在的正在进行的通话冲突处理,因为如果此时正有一个通话,那么他的学生平衡就是不为1的
            DateTime       deadlineTime = DateTime.Now.AddHours(-2);
            List <CallLog> chats        = entities.CallLog.OrderByDescending(o => o.Start).Where(o => o.Start < deadlineTime && o.Finish == null && o.Refresh != null).ToList();

            log.Info("deadlineTime" + deadlineTime.ToString("yyyy-MM-dd HH:mm:ss"));

            foreach (var item in chats)
            {
                //记录下这记录的原始开始时间和结束时间
                log.Info(item.Id + " start:" + item.Start.Value.ToString("yyyy-MM-dd HH:mm:ss") + " refersh:" + item.Refresh.Value.ToString("yyyy-MM-dd HH:mm:ss"));
                item.Finish = item.Refresh;//当结束标记为空的时候,用最后的刷新时间代替
                CallLogController.Balance(item);
            }
            entities.SaveChanges();
            entities.Dispose();
        }
Beispiel #3
0
 public void SetController(CallLogController controller)
 {
     _controller = controller;
 }