ChatController.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Http\Controllers\Controller;
  4. use App\Module\Base;
  5. use App\Module\Chat;
  6. use App\Module\Users;
  7. use DB;
  8. use Request;
  9. /**
  10. * @apiDefine chat
  11. *
  12. * 聊天
  13. */
  14. class ChatController extends Controller
  15. {
  16. public function __invoke($method, $action = '')
  17. {
  18. $app = $method ? $method : 'main';
  19. if ($action) {
  20. $app .= "__" . $action;
  21. }
  22. return (method_exists($this, $app)) ? $this->$app() : Base::ajaxError("404 not found (" . str_replace("__", "/", $app) . ").");
  23. }
  24. /**
  25. * 对话列表
  26. */
  27. public function dialog__lists()
  28. {
  29. $user = Users::authE();
  30. if (Base::isError($user)) {
  31. return $user;
  32. } else {
  33. $user = $user['data'];
  34. }
  35. //
  36. $lists = Base::DBC2A(DB::table('chat_dialog')
  37. ->where(function ($query) use ($user) {
  38. return $query->where('user1', $user['username'])->where('del1', 0);
  39. })
  40. ->orWhere(function ($query) use ($user) {
  41. return $query->where('user2', $user['username'])->where('del2', 0);
  42. })
  43. ->orderByDesc('lastdate')
  44. ->take(200)
  45. ->get());
  46. if (count($lists) <= 0) {
  47. return Base::retError('暂无对话记录');
  48. }
  49. $hasUnset = false;
  50. foreach ($lists AS $key => $item) {
  51. $tmpUserInfo = Users::username2basic($item['user1'] == $user['username'] ? $item['user2'] : $item['user1']);
  52. if (empty($tmpUserInfo)) {
  53. DB::table('chat_dialog')->where('id', $item['id'])->update(['del1' => 1, 'del2' => 1]);
  54. $hasUnset = true;
  55. unset($lists[$key]);
  56. continue;
  57. }
  58. $lists[$key] = array_merge($item, $tmpUserInfo);
  59. $lists[$key]['lastdate'] = $item['lastdate'] ?: $item['indate'];
  60. $unread = 0;
  61. if ($item['user1'] == $user['username']) $unread+= $item['unread1'];
  62. if ($item['user2'] == $user['username']) $unread+= $item['unread2'];
  63. $lists[$key]['unread'] = $unread;
  64. }
  65. if ($hasUnset) {
  66. $lists = array_values($lists);
  67. }
  68. return Base::retSuccess('success', $lists);
  69. }
  70. /**
  71. * 清空聊天记录(删除对话)
  72. *
  73. * @apiParam {String} username 用户名
  74. * @apiParam {Number} [delete] 是否删除对话,1:是
  75. */
  76. public function dialog__clear()
  77. {
  78. $user = Users::authE();
  79. if (Base::isError($user)) {
  80. return $user;
  81. } else {
  82. $user = $user['data'];
  83. }
  84. //
  85. $delete = intval(Request::input('delete'));
  86. $res = Chat::openDialog($user['username'], trim(Request::input('username')));
  87. if (Base::isError($res)) {
  88. return $res;
  89. }
  90. $dialog = $res['data'];
  91. $lastMsg = Base::DBC2A(DB::table('chat_msg')
  92. ->select(['id'])
  93. ->where('did', $dialog['id'])
  94. ->orderByDesc('indate')
  95. ->orderByDesc('id')
  96. ->first());
  97. $upArray = [
  98. ($dialog['recField'] == 1 ? 'lastid2' : 'lastid1') => $lastMsg ? $lastMsg['id'] : 0
  99. ];
  100. if ($delete === 1) {
  101. $upArray[($dialog['recField'] == 1 ? 'del2' : 'del1')] = 1;
  102. }
  103. DB::table('chat_dialog')->where('id', $dialog['id'])->update($upArray);
  104. Chat::forgetDialog($dialog['user1'], $dialog['user2']);
  105. return Base::retSuccess($delete ? '删除成功!' : '清除成功!');
  106. }
  107. /**
  108. * 消息列表
  109. *
  110. * @apiParam {String} username 用户名
  111. */
  112. public function message__lists()
  113. {
  114. $user = Users::authE();
  115. if (Base::isError($user)) {
  116. return $user;
  117. } else {
  118. $user = $user['data'];
  119. }
  120. //
  121. $res = Chat::openDialog($user['username'], trim(Request::input('username')));
  122. if (Base::isError($res)) {
  123. return $res;
  124. }
  125. $dialog = $res['data'];
  126. $lastid = $dialog[($dialog['recField'] == 1 ? 'lastid2' : 'lastid1')];
  127. $whereArray = [];
  128. $whereArray[] = ['did', '=', $dialog['id']];
  129. if ($lastid > 0) {
  130. $whereArray[] = ['id', '>', $lastid];
  131. }
  132. $lists = DB::table('chat_msg')
  133. ->where($whereArray)
  134. ->orderByDesc('indate')
  135. ->orderByDesc('id')
  136. ->paginate(Min(Max(Base::nullShow(Request::input('pagesize'), 10), 1), 100));
  137. $lists = Base::getPageList($lists, false);
  138. //
  139. foreach ($lists['lists'] AS $key => $item) {
  140. $basic = Users::username2basic($item['username']);
  141. $item['nickname'] = $basic ? $basic['nickname'] : ($item['nickname'] || '');
  142. $item['userimg'] = $basic ? $basic['userimg'] : ($item['userimg'] || '');
  143. $item['message'] = Base::string2array($item['message']);
  144. $lists['lists'][$key] = $item;
  145. }
  146. //
  147. return Base::retSuccess('success', $lists);
  148. }
  149. }