UserQueue.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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. $auto_cs_uid = getAutoCsUid();
  26. $where = [
  27. ['status', '=', 1],
  28. ['is_online', '=', 1],
  29. ['role', '=', 3],
  30. ['user_id', '<>', $auto_cs_uid],
  31. ];
  32. while(true) {
  33. //排队用户
  34. $list = User::where('status', 1)->where('is_online', 1)->where('service_status', 0)
  35. ->order('service_start', 'asc')
  36. ->select()
  37. ->toArray();
  38. if (empty($list)) {
  39. sleep(5);
  40. }
  41. foreach ($list as $item) {
  42. //查询当前最少接线数的客服
  43. // $kefu_chat_max = Config::getKefuChatMax();//单个客服接线上限
  44. $kefu_chat_max = (int)Config::where('field','kefu_chat_max')->value('val');
  45. $where[] = ['chat_num', '<', $kefu_chat_max];
  46. $cs_user = User::where($where)->order('chat_num', 'asc')->find();
  47. if (!$cs_user) {
  48. break;
  49. }
  50. $this->handleChat($item, $cs_user->user_id, $cs_user->uid);
  51. }
  52. }
  53. }
  54. /**
  55. * 自动接线
  56. */
  57. public function handleChat($user, $cs_uid, $admin_id)
  58. {
  59. try {
  60. Db::startTrans();
  61. $user_id = $user['user_id'];
  62. User::where('user_id', $user_id)->update(['cs_uid'=>$cs_uid,'service_status' => 1, 'service_start' => time(), 'timeout_type' => 0]);
  63. //更新客服接线数量
  64. User::where('user_id', $cs_uid)->update(['chat_num'=>Db::raw('chat_num+1')]);
  65. //客服接线次数更新
  66. KefuWork::addNum($admin_id, 'chat_num');
  67. $friend = Friend::where('create_user', $user_id)->order('create_time', 'desc')->find();
  68. if ($friend) {
  69. $robot_id = $friend->friend_user_id;
  70. $friend->friend_user_id = $cs_uid;
  71. $friend->save();
  72. $chat_identify = chat_identify($cs_uid,$user_id);
  73. Message::where(['from_user' => $user_id, 'to_user' => $robot_id])->update(['to_user' => $cs_uid, 'chat_identify' => $chat_identify, 'is_read' => 1]);
  74. Message::where(['from_user' => $robot_id, 'to_user' => $user_id])->update(['from_user' => $cs_uid, 'chat_identify' => $chat_identify, 'is_read' => 1]);
  75. }
  76. //客服对接记录表
  77. KefuLog::addData($cs_uid, $user_id, 3);
  78. Db::commit();
  79. //通知客服已接线
  80. wsSendMsg(0,'handleChat',['user_id'=>$user_id]);
  81. //自动回复-人工客服接线成功
  82. Message::sendAutoReply('transfer_to_human_success', $user_id, $cs_uid, $user['language_code']);
  83. //自动回复-人工客服接线成功欢迎语
  84. Message::sendAutoReply('transfer_to_human_success_reply', $user_id, $cs_uid,$user['language_code']);
  85. } catch (\Exception $e) {
  86. Db::rollback();
  87. }
  88. }
  89. }