where('is_online', '>', 0)->count(); //当前客服在线人数 $data['handling_count'] = User::where('service_status',2)->count(); //当前客服接线中的总数 $data['today_handling_count'] = KefuTime::where('type', 3)->where('created_at', '>=', date('Y-m-d'))->count(); //今日客服接线总数 return $this->success($data); } /** * @api {get} /today 今日在线客服列表 */ public function today() { try { $params = $this->request->param(); $page = $params['page'] ?? 1; $limit = $params['limit'] ?? 15; $query = KefuWork::alias('kefu_work')->join('admin', 'kefu_work.admin_id = admin.id', 'left') ->join('user', 'admin.id = user.uid', 'left') ->where('kefu_work.created_at', '>=', date('Y-m-d 00:00:00')); if (isset($params['is_online'])) { if ($params['is_online'] == 1) { $query->where('user.is_online', '>', 0); } else { $query->where('user.is_online', 0); } } $count = $query->count(); $list = $query->field(['distinct kefu_work.id', 'admin.nickname','user.is_online', 'kefu_work.chat_num','kefu_work.transfer_num','kefu_work.intervention_num','kefu_work.completed_num']) ->order('admin.id', 'asc') ->limit($limit) ->page($page) ->select(); foreach ($list as &$value) { $value['chat_num'] = intval($value['chat_num']); $value['transfer_num'] = intval($value['transfer_num']); $value['intervention_num'] = intval($value['intervention_num']); $value['completed_num'] = intval($value['completed_num']); $value['inprocess'] = User::where('cs_uid',$value['id'])->where('service_status',2)->count();//进行中 $value['unprocessed'] = User::where('cs_uid',$value['id'])->where('service_status',1)->count();//待处理 } } catch (Exception $e) { return $this->error($e->getMessage()); } return $this->success(['count' => $count, 'list' => $list]); } /** * @api {get} /list 客服数据展板列表 */ public function list() { try { $params = $this->request->param(); $page = $params['page'] ?? 1; $limit = $params['limit'] ?? 15; $order_field = $params['field'] ?? 'kefu_work.id'; $order = $params['order'] ?? 'desc'; $query = KefuWork::alias('kefu_work') ->join('admin', 'kefu_work.admin_id = admin.id', 'left') ->join('user', 'kefu_work.admin_id = user.uid', 'left') ->where('user.from', 0); if (isset($params['is_online'])) { $query->where('user.is_online', $params['is_online']); } if (!empty($params['start_time'])) { $query->where('kefu_work.created_at', '>=', $params['start_time'].' 00:00:00'); } if (!empty($params['end_time'])) { $query->where('kefu_work.created_at', '<=', $params['end_time'].' 23:59:59'); } $count = $query->count(); $list = $query->field(['admin.username','admin.nickname','user.is_online', 'kefu_work.*']) ->order($order_field, $order) ->order('kefu_work.id', 'desc') ->limit($limit) ->page($page) ->select(); foreach ($list as &$value) { $value['avg_time'] = $value['service_time'] && $value['chat_num'] ? intval($value['service_time'] / $value['chat_num']) : 0; //客服平均服务时间 $value['online_time'] = formatSecondsToTime($value['online_time']); $value['busy_time'] = formatSecondsToTime($value['busy_time']); $value['chat_time'] = formatSecondsToTime($value['chat_time']); $value['service_time'] = formatSecondsToTime($value['service_time']); } } catch (Exception $e) { return $this->error($e->getMessage()); } return $this->success(['count' => $count, 'list' => $list]); } /** * @api {get} /chat 总接线数据 */ public function chat() { try { $params = $this->request->param(); $start_time = empty($params['start_time']) ? date('Y-m-d') : $params['start_time']; $end_time = empty($params['end_time']) ? date('Y-m-d') : $params['end_time']; $list = OperationData::where('type', 1) ->where('date', '>=', $start_time) ->where('date', '<=', $end_time) ->limit(100) ->field(['num','date']) ->select(); if ($start_time == date('Y-m-d') || $end_time == date('Y-m-d')) { $list[] = [ 'num' => KefuTime::where('type', 3) ->where('created_at', '>=', date('Y-m-d 00:00:00')) ->where('created_at', '<=', date('Y-m-d 23:59:59')) ->count(), 'date' => date('Y-m-d'), ]; } } catch (Exception $e) { return $this->error($e->getMessage()); } return $this->success(['count' => count($list), 'list' => $list]); } //客服签到 public function sign() { try { $admin_id = $this->admin_id; KefuWork::addNum($admin_id, 'sign_num');//客服签到次数更新 $sign = Sign::where('admin_id', $admin_id)->where('created_at', '>=', date('Y-m-d'))->order('id', 'desc')->find(); if ($sign && $sign->time == 0) { $sign->time = time() - strtotime($sign->created_at); $sign->updated_at = date('Y-m-d H:i:s'); $sign->save(); } //签到记录 Sign::create([ 'admin_id' => $admin_id, ]); } catch (\Exception $e) { return $this->error($e->getMessage()); } //通知客服已签到 $user_id = User::getCsId($admin_id); wsSendMsg($user_id,'sign',['is_sign'=>0]); //上线通知 wsSendMsg(0,'isOnline',['id'=>$user_id, 'is_online'=>1]); return $this->success([], '签到成功'); } /** * 客服接线 */ public function handleChat() { try { Db::startTrans(); $user_id = $this->request->param('user_id'); $user = User::where('user_id', $user_id)->find(); if (!$user) { return $this->error('用户不存在'); } if ($user->service_status >= 1) { return $this->error('用户已接线'); } $cs_uid = User::getCsId($this->admin_id); $user->cs_uid = $cs_uid; $user->service_status = 2; $user->service_start = time(); $user->save(); //更新客服接线数量 User::where('user_id', $cs_uid)->update(['chat_num'=>Db::raw('chat_num+1')]); $friend = Friend::where('create_user', $user_id)->order('create_time', 'desc')->find(); if ($friend) { $robot_id = $friend->friend_user_id; $friend->friend_user_id = $cs_uid; $friend->save(); $chat_identify = $cs_uid . '-' . $user_id; Message::where(['from_user' => $user_id, 'to_user' => $robot_id])->update(['to_user' => $cs_uid, 'chat_identify' => $chat_identify]); Message::where(['from_user' => $robot_id, 'to_user' => $user_id])->update(['from_user' => $cs_uid, 'chat_identify' => $chat_identify]); } KefuWork::addNum($this->admin_id, 'chat_num');//客服接线次数更新 Db::commit(); //通知客服已接线 wsSendMsg(0,'handleChat',['user_id'=>$user_id]); } catch (\Exception $e) { Db::rollback(); return $this->error($e->getMessage()); } return $this->success([], ''); } /** * 客服转线 */ public function transferChat() { try { Db::startTrans(); $user_id = $this->request->param('user_id'); $cs_uid = $this->request->param('cs_uid'); $user = User::where('user_id', $user_id)->find(); if (!$user) { return $this->error('用户不存在'); } $admin_id = User::getAdminId($cs_uid); $user->cs_uid = $cs_uid; $user->service_status = 1; $user->service_start = time(); $user->save(); //更新客服接线数量 User::where('user_id', $cs_uid)->update(['chat_num'=>Db::raw('chat_num+1')]); $friend = Friend::where('create_user', $user_id)->order('create_time', 'desc')->find(); if ($friend) { $old_cs_uid = $friend->friend_user_id; $friend->friend_user_id = $cs_uid; $friend->save(); //更新客服接线数量 User::where('user_id', $old_cs_uid)->update(['chat_num'=>Db::raw('chat_num-1')]); $chat_identify = $cs_uid . '-' . $user_id; Message::where(['from_user' => $user_id, 'to_user' => $old_cs_uid])->update(['to_user' => $cs_uid, 'chat_identify' => $chat_identify]); Message::where(['from_user' => $old_cs_uid, 'to_user' => $user_id])->update(['from_user' => $cs_uid, 'chat_identify' => $chat_identify]); KefuTime::endData($old_cs_uid, 3); //结束接线时间 } KefuWork::addNum($admin_id, 'chat_num');//客服接线次数更新 Db::commit(); //通知客服已接线 wsSendMsg(0,'handleChat',['user_id'=>$user_id]); } catch (\Exception $e) { Db::rollback(); return $this->error($e->getMessage()); } return $this->success([], ''); } /** * 选择上级及部门一下的其他客服 */ public function select() { $department_id = Admin::where('id', $this->admin_id)->value('department_id'); $parent_department_id = Department::where('id', $department_id)->value('parent_id'); $where[] = ['department_id', '=', $parent_department_id]; $list = Admin::alias('admin')->join('user', 'admin.id = user.uid', 'left') ->where('user.role', '>', 0) ->where('user.status', 1) ->where('admin.department_id', $department_id)->whereOr(function ($query) use ($parent_department_id) { if ($parent_department_id) { $query->where('admin.department_id', $parent_department_id); } }) ->where('admin.id','<>', $this->admin_id) ->order('admin.department_id', 'asc') ->order('user.is_online', 'desc') ->field(['user.user_id','user.account','user.realname','user.avatar','user.is_online','admin.nickname','admin.username']) ->select() ->toArray(); return $this->success($list); } /** * 客服结束会话 */ public function finishedChat() { try { Db::startTrans(); $user_id = $this->request->param('user_id'); $user = User::where('user_id', $user_id)->find(); if (!$user) { return $this->error('用户不存在'); } if ($user->service_status != 3) { KefuTime::endData($user->cs_uid, 3); //结束接线时间 $old_cs_uid = $user->cs_uid; //更新客服接线数量 User::where('user_id', $old_cs_uid)->update(['chat_num'=>Db::raw('chat_num-1')]); //转成机器人聊天 $user->service_status = -1; $user->service_time = 0; $autoTask = \app\manage\model\Config::autoTask(); $user->cs_uid = isset($autoTask['user_id']) ? $autoTask['user_id'] : 0; $user->save(); $cs_uid = $user->cs_uid; $friend = Friend::where('create_user', $user_id)->order('create_time', 'desc')->find(); if ($friend) { $old_cs_uid = $friend->friend_user_id; $friend->friend_user_id = $cs_uid; $friend->save(); $chat_identify = $cs_uid . '-' . $user_id; Message::where(['from_user' => $user_id, 'to_user' => $old_cs_uid])->update(['to_user' => $cs_uid, 'chat_identify' => $chat_identify]); Message::where(['from_user' => $old_cs_uid, 'to_user' => $user_id])->update(['from_user' => $cs_uid, 'chat_identify' => $chat_identify]); KefuTime::endData($old_cs_uid, 3); //结束接线时间 } Db::commit(); //通知客服已结束 wsSendMsg(0,'handleChat',['user_id'=>$user_id]); //给用户发送客服评分的消息 $user_open_comment = Config::where('field', 'user_open_comment')->value('val'); if ($user_open_comment == 1 ) { $param = [ 'id' => \utils\Str::getUuid(), 'type' => 'text', 'status' => 'going', 'sendTime' => time() * 1000, 'toContactId' => $user_id, 'content' => Config::where('field','kefu_finished_chat')->value('val'), 'file_id' => 0, 'is_group' => 0, 'user_id' => $user->cs_uid, ]; Message::sendMsg($param, 0); } } } catch (\Exception $e) { Db::rollback(); return $this->error($e->getMessage()); } return $this->success([], ''); } }