LogsController.php 9.4 KB

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