Index.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <?php
  2. namespace app\service\controller;
  3. /**
  4. * 客服系统首页类
  5. */
  6. class Index extends Common
  7. {
  8. /**
  9. * 获取用户详情
  10. *
  11. * @access public
  12. * @return array JsonString
  13. */
  14. public function userInfo()
  15. {
  16. // 验证token.
  17. $tokenStatus = $this->verifyToken();
  18. $code = -2;
  19. $msg = '错误';
  20. if ($tokenStatus === false) {
  21. return json(['code' => $code, 'data' => [], 'msg' => $msg]);
  22. }
  23. try {
  24. $getUserToken = input('server.HTTP_userToken');
  25. $usersField = [
  26. 'a.id',
  27. 'user_name',
  28. 'user_avatar',
  29. 'b.name',
  30. ];
  31. // 关联信息.
  32. $join['groups b'] = 'a.group_id = b.id';
  33. $usersWhere['token'] = $getUserToken;
  34. // 获取用户信息.
  35. $usersInfo = model('users')->findInfo($usersField, $usersWhere, $join);
  36. return json(['code' => 200, 'data' => $usersInfo, 'msg' => '成功']);
  37. } catch (\Exception $e) {
  38. return json(['code' => $code, 'data' => [], 'msg' => $msg]);
  39. }//end try
  40. }//end userInfo()
  41. /**
  42. * 获取用户快捷语
  43. *
  44. * @access public
  45. * @return array JsonString
  46. */
  47. public function userWords()
  48. {
  49. // 验证token.
  50. $tokenStatus = $this->verifyToken();
  51. $code = -2;
  52. $msg = '错误';
  53. if ($tokenStatus === false) {
  54. return json(['code' => $code, 'data' => [], 'msg' => $msg]);
  55. }
  56. try {
  57. // 获取用户信息.
  58. $getUserInfo = $this->getUserInfo();
  59. // 获取快捷语.
  60. $wordsField = [
  61. 'id',
  62. 'content',
  63. ];
  64. $sysWordsWhere['status'] = 1;
  65. $sysWordsWhere['user_id'] = 0;
  66. // 查询系统快捷语.
  67. $sysWords = model('words')->selectWords($wordsField, $sysWordsWhere);
  68. // 查询用户私有快捷语条件.
  69. $userWordsWhere['user_id'] = $getUserInfo->id;
  70. // 查询用户私有快捷语.
  71. $userWords = model('words')->selectWords($wordsField, $userWordsWhere);
  72. $result = [
  73. 'sysWords' => $sysWords,
  74. 'userWords' => $userWords,
  75. ];
  76. return json(['code' => 200, 'data' => $result, 'msg' => '成功']);
  77. } catch (\Exception $e) {
  78. return json(['code' => $code, 'data' => [], 'msg' => $msg]);
  79. }//end try
  80. }//end userWords()
  81. public function index()
  82. {
  83. $getUserInfo = $this->getUserInfo();
  84. // 客服信息
  85. $userInfo = db('users')->where('id', 1)->find();
  86. $this->assign([
  87. 'uinfo' => $userInfo,
  88. 'word' => db('words')->select(),
  89. 'groups' => db('groups')->where('status', 1)->select(),
  90. 'status' => db('kf_config')->where('id', 1)->find()
  91. ]);
  92. return $this->fetch();
  93. }
  94. // 获取服务用户列表
  95. // 此方法是为了防止客服工作期间错误的刷新工作台,导致服务人员消失的问题
  96. public function getUserList()
  97. {
  98. if(request()->isAjax()){
  99. // 此处只查询过去 三个小时 内的未服务完的用户
  100. $userList = db('service_log')
  101. ->where(function ($query) {
  102. $query = $query->where('status', 1);
  103. $query = $query->whereOr('status', 3);
  104. return $query;
  105. })
  106. ->select();
  107. return json(['code' => 1, 'data' => $userList, 'msg' => 'ok']);
  108. }
  109. }
  110. // 获取聊天记录
  111. public function getChatLog()
  112. {
  113. if(request()->isAjax()){
  114. $param = input('param.');
  115. $limit = 10; // 一次显示10 条聊天记录
  116. $offset = ($param['page'] - 1) * $limit;
  117. $logs = db('chat_log')->where(function($query) use($param){
  118. $query->where('from_id', $param['uid'])->where('to_id', 'KF' . cookie('l_user_id'));
  119. })->whereOr(function($query) use($param){
  120. $query->where('from_id', 'KF' . cookie('l_user_id'))->where('to_id', $param['uid']);
  121. })->limit($offset, $limit)->order('id', 'desc')->select();
  122. $total = db('chat_log')->where(function($query) use($param){
  123. $query->where('from_id', $param['uid'])->where('to_id', 'KF' . cookie('l_user_id'));
  124. })->whereOr(function($query) use($param){
  125. $query->where('from_id', 'KF' . cookie('l_user_id'))->where('to_id', $param['uid']);
  126. })->count();
  127. foreach($logs as $key=>$vo){
  128. $logs[$key]['type'] = 'user';
  129. $logs[$key]['time_line'] = date('Y-m-d H:i:s', $vo['time_line']);
  130. if($vo['from_id'] == 'KF' . cookie('l_user_id')){
  131. $logs[$key]['type'] = 'mine';
  132. }
  133. }
  134. return json(['code' => 1, 'data' => $logs, 'msg' => intval($param['page']), 'total' => ceil($total / $limit)]);
  135. }
  136. }
  137. // ip 定位
  138. public function getCity()
  139. {
  140. $ip = input('param.ip');
  141. $ip2region = new \Ip2Region();
  142. $info = $ip2region->btreeSearch($ip);
  143. $city = explode('|', $info['region']);
  144. if(0 != $info['city_id']){
  145. return json(['code' => 1, 'data' => $city['2'] . $city['3'] . $city['4'], 'msg' => 'ok']);
  146. }else{
  147. return json(['code' => 1, 'data' => $city['0'], 'msg' => 'ok']);
  148. }
  149. }
  150. }