LogsController.php 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Components\IP;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\Node;
  6. use App\Models\NodeOnlineIp;
  7. use App\Models\NotificationLog;
  8. use App\Models\Order;
  9. use App\Models\PaymentCallback;
  10. use App\Models\User;
  11. use App\Models\UserBanedLog;
  12. use App\Models\UserCreditLog;
  13. use App\Models\UserDataFlowLog;
  14. use App\Models\UserDataModifyLog;
  15. use Illuminate\Http\Request;
  16. use Response;
  17. class LogsController extends Controller
  18. {
  19. // 订单列表
  20. public function orderList(Request $request)
  21. {
  22. $query = Order::with(['user:id,username', 'goods:id,name', 'coupon:id,name,sn']);
  23. $request->whenFilled('username', function ($username) use ($query) {
  24. $query->whereHas('user', function ($query) use ($username) {
  25. $query->where('username', 'like', "%{$username}%");
  26. });
  27. });
  28. $request->whenFilled('sn', function ($value) use ($query) {
  29. $query->where('sn', 'like', "%{$value}%");
  30. });
  31. $request->whenFilled('start', function ($value) use ($query) {
  32. $query->where('created_at', '>=', $value);
  33. });
  34. $request->whenFilled('end', function ($value) use ($query) {
  35. $query->where('created_at', '<=', $value.' 23:59:59');
  36. });
  37. $request->whenFilled('is_coupon', function ($value) use ($query) {
  38. if ($value) {
  39. $query->where('coupon_id', '<>', null);
  40. } else {
  41. $query->where('coupon_id', 'null');
  42. }
  43. });
  44. foreach (['is_expire', 'pay_way', 'status'] as $field) {
  45. $request->whenFilled($field, function ($value) use ($query, $field) {
  46. $query->where($field, $value);
  47. });
  48. }
  49. return view('admin.logs.order', ['orders' => $query->sortable(['id' => 'desc'])->paginate(15)->appends($request->except('page'))]);
  50. }
  51. public function changeOrderStatus(Request $request)
  52. {
  53. $order = Order::findOrFail($request->input('oid'));
  54. $status = (int) $request->input('status');
  55. if ($order->update(['status' => $status])) {
  56. return Response::json(['status' => 'success', 'message' => '更新成功']);
  57. }
  58. return Response::json(['status' => 'fail', 'message' => '更新失败']);
  59. }
  60. // 流量日志
  61. public function trafficLog(Request $request)
  62. {
  63. $query = UserDataFlowLog::with(['user', 'node']);
  64. $request->whenFilled('port', function ($value) use ($query) {
  65. $query->whereHas('user', function ($query) use ($value) {
  66. $query->wherePort($value);
  67. });
  68. });
  69. foreach (['user_id', 'node_id'] as $field) {
  70. $request->whenFilled($field, function ($value) use ($query, $field) {
  71. $query->where($field, $value);
  72. });
  73. }
  74. $request->whenFilled('username', function ($username) use ($query) {
  75. $query->whereHas('user', function ($query) use ($username) {
  76. $query->where('username', 'like', "%{$username}%");
  77. });
  78. });
  79. $request->whenFilled('start', function ($value) use ($query) {
  80. $query->where('log_time', '>=', strtotime($value));
  81. });
  82. $request->whenFilled('end', function ($value) use ($query) {
  83. $query->where('log_time', '<=', strtotime($value) + 86399);
  84. });
  85. $totalTraffic = flowAutoShow($query->sum('u') + $query->sum('d')); // 在分页前,计算总使用流量
  86. $dataFlowLogs = $query->latest('log_time')->paginate(20)->appends($request->except('page'));
  87. foreach ($dataFlowLogs as $log) {
  88. $log->u = flowAutoShow($log->u);
  89. $log->d = flowAutoShow($log->d);
  90. $log->log_time = date('Y-m-d H:i:s', $log->log_time);
  91. }
  92. $nodes = Node::whereStatus(1)->orderByDesc('sort')->latest()->get();
  93. return view('admin.logs.traffic', compact(['totalTraffic', 'dataFlowLogs', 'nodes']));
  94. }
  95. // 邮件发送日志列表
  96. public function notificationLog(Request $request)
  97. {
  98. $query = NotificationLog::query();
  99. $request->whenFilled('username', function ($username) use ($query) {
  100. $query->where('address', 'like', "%{$username}%");
  101. });
  102. $request->whenFilled('type', function ($type) use ($query) {
  103. $query->whereType($type);
  104. });
  105. return view('admin.logs.notification', ['notificationLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]);
  106. }
  107. // 在线IP监控(实时)
  108. public function onlineIPMonitor(Request $request, $id = null)
  109. {
  110. $query = NodeOnlineIp::with(['node:id,name', 'user:id,username'])->where('created_at', '>=', strtotime('-2 minutes'));
  111. if ($id !== null) {
  112. $query->whereHas('user', static function ($query) use ($id) {
  113. $query->whereId($id);
  114. });
  115. }
  116. $request->whenFilled('ip', function ($ip) use ($query) {
  117. $query->whereIp($ip);
  118. });
  119. $request->whenFilled('username', function ($username) use ($query) {
  120. $query->whereHas('user', function ($query) use ($username) {
  121. $query->where('username', 'like', "%{$username}%");
  122. });
  123. });
  124. $request->whenFilled('port', function ($port) use ($query) {
  125. $query->whereHas('user', function ($query) use ($port) {
  126. $query->wherePort($port);
  127. });
  128. });
  129. $request->whenFilled('node_id', function ($nodeId) use ($query) {
  130. $query->whereHas('node', function ($query) use ($nodeId) {
  131. $query->whereId($nodeId);
  132. });
  133. });
  134. $onlineIPLogs = $query->groupBy('user_id', 'node_id')->latest()->paginate(20)->appends($request->except('page'));
  135. foreach ($onlineIPLogs as $log) {
  136. // 跳过上报多IP的
  137. if ($log->ip === null || str_contains($log->ip, ',')) {
  138. continue;
  139. }
  140. $ipInfo = IP::getIPInfo($log->ip);
  141. $log->ipInfo = implode(' ', $ipInfo);
  142. }
  143. return view('admin.logs.onlineIPMonitor', [
  144. 'onlineIPLogs' => $onlineIPLogs,
  145. 'nodes' => Node::whereStatus(1)->orderByDesc('sort')->latest()->get(),
  146. ]);
  147. }
  148. // 用户余额变动记录
  149. public function userCreditLogList(Request $request)
  150. {
  151. $query = UserCreditLog::with('user:id,username')->latest();
  152. $request->whenFilled('username', function ($username) use ($query) {
  153. $query->whereHas('user', function ($query) use ($username) {
  154. $query->where('username', 'like', "%{$username}%");
  155. });
  156. });
  157. return view('admin.logs.userCreditHistory', ['userCreditLogs' => $query->paginate(15)->appends($request->except('page'))]);
  158. }
  159. // 用户封禁记录
  160. public function userBanLogList(Request $request)
  161. {
  162. $query = UserBanedLog::with('user:id,username,t');
  163. $request->whenFilled('username', function ($username) use ($query) {
  164. $query->whereHas('user', function ($query) use ($username) {
  165. $query->where('username', 'like', "%{$username}%");
  166. });
  167. });
  168. return view('admin.logs.userBanHistory', ['userBanLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]);
  169. }
  170. // 用户流量变动记录
  171. public function userTrafficLogList(Request $request)
  172. {
  173. $query = UserDataModifyLog::with(['user:id,username', 'order.goods:id,name']);
  174. $request->whenFilled('username', function ($username) use ($query) {
  175. $query->whereHas('user', function ($query) use ($username) {
  176. $query->where('username', 'like', "%{$username}%");
  177. });
  178. });
  179. return view('admin.logs.userTraffic', ['userTrafficLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]);
  180. }
  181. // 用户在线IP记录
  182. public function userOnlineIPList(Request $request)
  183. {
  184. $query = User::activeUser();
  185. foreach (['username', 'wechat', 'qq'] as $field) {
  186. $request->whenFilled($field, function ($value) use ($query, $field) {
  187. $query->where($field, 'like', "%{$value}%");
  188. });
  189. }
  190. foreach (['id', 'port'] as $field) {
  191. $request->whenFilled($field, function ($value) use ($query, $field) {
  192. $query->where($field, $value);
  193. });
  194. }
  195. $userList = $query->orderBy('id')->paginate(15)->appends($request->except('page'));
  196. $nodeOnlineIPs = NodeOnlineIp::with('node:id,name')->where('created_at', '>=', strtotime('-10 minutes'))->latest()->distinct()->get();
  197. foreach ($userList as $user) {
  198. //Todo node_online_ip表 api可以用user_id
  199. // 最近5条在线IP记录,如果后端设置为60秒上报一次,则为10分钟内的在线IP
  200. $user->onlineIPList = $nodeOnlineIPs->where('port', $user->port)->take(5);
  201. }
  202. return view('admin.logs.userOnlineIP', ['userList' => $userList]);
  203. }
  204. // 用户流量监控
  205. public function userTrafficMonitor(User $user)
  206. {
  207. return view('admin.logs.userMonitor', array_merge(['username' => $user->username], $this->dataFlowChart($user->id)));
  208. }
  209. // 回调日志
  210. public function callbackList(Request $request)
  211. {
  212. $query = PaymentCallback::query();
  213. foreach (['trade_no', 'out_trade_no', 'status'] as $field) {
  214. $request->whenFilled($field, function ($value) use ($query, $field) {
  215. $query->where($field, $value);
  216. });
  217. }
  218. return view('admin.logs.callback', ['callbackLogs' => $query->latest()->paginate(10)->appends($request->except('page'))]);
  219. }
  220. }