UserQueue.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace app\admin\command;
  3. use think\console\Command;
  4. use think\console\Input;
  5. use think\console\Output;
  6. use app\admin\model\User;
  7. use app\admin\model\Config;
  8. use app\admin\model\KefuWork;
  9. use app\admin\model\KefuLog;
  10. use app\enterprise\model\{Message,Friend};
  11. use Exception;
  12. use think\facade\Db;
  13. /**
  14. * Worker 命令行类
  15. */
  16. class UserQueue extends Command
  17. {
  18. public function configure()
  19. {
  20. $this->setName('user:queue')
  21. ->setDescription('用户排队,自动分配客服');
  22. }
  23. public function execute(Input $input, Output $output)
  24. {
  25. $where = [
  26. ['status', '=', 1],
  27. ['is_online', '=', 1],
  28. ['role', '=', 3],
  29. ];
  30. while(true) {
  31. //排队用户
  32. $list = User::where('status', 1)->where('is_online', 1)->where('service_status', 0)
  33. ->order('service_start', 'asc')
  34. ->select()
  35. ->toArray();
  36. if (empty($list)) {
  37. sleep(5);
  38. }
  39. foreach ($list as $item) {
  40. //查询当前最少接线数的客服
  41. // $kefu_chat_max = Config::getKefuChatMax();//单个客服接线上限
  42. $kefu_chat_max = (int)Config::where('field','kefu_chat_max')->value('val');
  43. $where[] = ['chat_num', '<', $kefu_chat_max];
  44. $cs_user = User::where($where)->order('chat_num', 'asc')->find();
  45. if (!$cs_user) {
  46. break;
  47. }
  48. $this->handleChat($item, $cs_user->user_id, $cs_user->uid);
  49. }
  50. }
  51. }
  52. /**
  53. * 自动接线
  54. */
  55. public function handleChat($user, $cs_uid, $admin_id)
  56. {
  57. try {
  58. Db::startTrans();
  59. $user_id = $user['user_id'];
  60. User::where('user_id', $user_id)->update(['cs_uid'=>$cs_uid,'service_status' => 1, 'service_start' => time(), 'timeout_type' => 0]);
  61. //更新客服接线数量
  62. User::where('user_id', $cs_uid)->update(['chat_num'=>Db::raw('chat_num+1')]);
  63. //客服接线次数更新
  64. KefuWork::addNum($admin_id, 'chat_num');
  65. $friend = Friend::where('create_user', $user_id)->order('create_time', 'desc')->find();
  66. if ($friend) {
  67. $robot_id = $friend->friend_user_id;
  68. $friend->friend_user_id = $cs_uid;
  69. $friend->save();
  70. $chat_identify = $cs_uid . '-' . $user_id;
  71. Message::where(['from_user' => $user_id, 'to_user' => $robot_id])->update(['to_user' => $cs_uid, 'chat_identify' => $chat_identify, 'is_read' => 1]);
  72. Message::where(['from_user' => $robot_id, 'to_user' => $user_id])->update(['from_user' => $cs_uid, 'chat_identify' => $chat_identify, 'is_read' => 1]);
  73. }
  74. //客服对接记录表
  75. KefuLog::addData($cs_uid, $user_id, 3);
  76. Db::commit();
  77. //通知客服已接线
  78. wsSendMsg(0,'handleChat',['user_id'=>$user_id]);
  79. //自动回复-人工客服接线成功
  80. Message::sendAutoReply('transfer_to_human_success', $user_id, $cs_uid);
  81. } catch (\Exception $e) {
  82. Db::rollback();
  83. }
  84. }
  85. }