whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%{$username}%"); }); }); $request->whenFilled('sn', function ($value) use ($query) { $query->where('sn', 'like', "%{$value}%"); }); $request->whenFilled('start', function ($value) use ($query) { $query->where('created_at', '>=', $value); }); $request->whenFilled('end', function ($value) use ($query) { $query->where('created_at', '<=', $value.' 23:59:59'); }); $request->whenFilled('is_coupon', function ($value) use ($query) { if ($value) { $query->where('coupon_id', '<>', null); } else { $query->where('coupon_id', 'null'); } }); foreach (['is_expire', 'pay_way', 'status'] as $field) { $request->whenFilled($field, function ($value) use ($query, $field) { if (is_array($value)) { $query->whereIn($field, $value); } else { $query->where($field, $value); } }); } return view('admin.logs.order', ['orders' => $query->sortable(['id' => 'desc'])->paginate(15)->appends($request->except('page'))]); } public function changeOrderStatus(Request $request) { $order = Order::findOrFail($request->input('oid')); $status = (int) $request->input('status'); if ($order->status === 3 && $status === 2 && $order->goods->type === 2 && Order::userActivePlan($order->user_id)->exists()) { return Response::json(['status' => 'fail', 'message' => '更新失败, 订单冲突']); // 防止预支付订单假激活 } if ($order->update(['is_expire' => 0, 'expired_at' => null, 'status' => $status])) { return Response::json(['status' => 'success', 'message' => '更新成功']); } return Response::json(['status' => 'fail', 'message' => '更新失败']); } // 流量日志 public function trafficLog(Request $request) { $query = UserDataFlowLog::with(['user', 'node']); $request->whenFilled('port', function ($value) use ($query) { $query->whereHas('user', function ($query) use ($value) { $query->wherePort($value); }); }); foreach (['user_id', 'node_id'] as $field) { $request->whenFilled($field, function ($value) use ($query, $field) { $query->where($field, $value); }); } $request->whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%{$username}%"); }); }); $request->whenFilled('start', function ($value) use ($query) { $query->where('log_time', '>=', strtotime($value)); }); $request->whenFilled('end', function ($value) use ($query) { $query->where('log_time', '<=', strtotime($value) + 86399); }); $totalTraffic = flowAutoShow($query->sum('u') + $query->sum('d')); // 在分页前,计算总使用流量 $dataFlowLogs = $query->latest('log_time')->paginate(20)->appends($request->except('page')); foreach ($dataFlowLogs as $log) { $log->u = flowAutoShow($log->u); $log->d = flowAutoShow($log->d); $log->log_time = date('Y-m-d H:i:s', $log->log_time); } $nodes = Node::whereStatus(1)->orderByDesc('sort')->latest()->get(); return view('admin.logs.traffic', compact(['totalTraffic', 'dataFlowLogs', 'nodes'])); } // 邮件发送日志列表 public function notificationLog(Request $request) { $query = NotificationLog::query(); $request->whenFilled('username', function ($username) use ($query) { $query->where('address', 'like', "%{$username}%"); }); $request->whenFilled('type', function ($type) use ($query) { $query->whereType($type); }); return view('admin.logs.notification', ['notificationLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]); } // 在线IP监控(实时) public function onlineIPMonitor(Request $request, $id = null) { $query = NodeOnlineIp::with(['node:id,name', 'user:id,username'])->where('created_at', '>=', strtotime('-2 minutes')); if ($id !== null) { $query->whereHas('user', static function ($query) use ($id) { $query->whereId($id); }); } $request->whenFilled('ip', function ($ip) use ($query) { $query->whereIp($ip); }); $request->whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%{$username}%"); }); }); $request->whenFilled('port', function ($port) use ($query) { $query->whereHas('user', function ($query) use ($port) { $query->wherePort($port); }); }); $request->whenFilled('node_id', function ($nodeId) use ($query) { $query->whereHas('node', function ($query) use ($nodeId) { $query->whereId($nodeId); }); }); $onlineIPLogs = $query->groupBy('user_id', 'node_id')->latest()->paginate(20)->appends($request->except('page')); foreach ($onlineIPLogs as $log) { // 跳过上报多IP的 if ($log->ip === null || str_contains($log->ip, ',')) { continue; } $ipInfo = IP::getIPInfo($log->ip); $log->ipInfo = implode(' ', $ipInfo); } return view('admin.logs.onlineIPMonitor', [ 'onlineIPLogs' => $onlineIPLogs, 'nodes' => Node::whereStatus(1)->orderByDesc('sort')->latest()->get(), ]); } // 用户余额变动记录 public function userCreditLogList(Request $request) { $query = UserCreditLog::with('user:id,username')->latest(); $request->whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%{$username}%"); }); }); return view('admin.logs.userCreditHistory', ['userCreditLogs' => $query->paginate(15)->appends($request->except('page'))]); } // 用户封禁记录 public function userBanLogList(Request $request) { $query = UserBanedLog::with('user:id,username,t'); $request->whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%{$username}%"); }); }); return view('admin.logs.userBanHistory', ['userBanLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]); } // 用户流量变动记录 public function userTrafficLogList(Request $request) { $query = UserDataModifyLog::with(['user:id,username', 'order.goods:id,name']); $request->whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%{$username}%"); }); }); return view('admin.logs.userTraffic', ['userTrafficLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]); } // 用户在线IP记录 public function userOnlineIPList(Request $request) { $query = User::activeUser(); foreach (['username', 'wechat', 'qq'] as $field) { $request->whenFilled($field, function ($value) use ($query, $field) { $query->where($field, 'like', "%{$value}%"); }); } foreach (['id', 'port'] as $field) { $request->whenFilled($field, function ($value) use ($query, $field) { $query->where($field, $value); }); } $userList = $query->orderBy('id')->paginate(15)->appends($request->except('page')); $nodeOnlineIPs = NodeOnlineIp::with('node:id,name')->where('created_at', '>=', strtotime('-10 minutes'))->latest()->distinct()->get(); foreach ($userList as $user) { //Todo node_online_ip表 api可以用user_id // 最近5条在线IP记录,如果后端设置为60秒上报一次,则为10分钟内的在线IP $user->onlineIPList = $nodeOnlineIPs->where('port', $user->port)->take(5); } return view('admin.logs.userOnlineIP', ['userList' => $userList]); } // 用户流量监控 public function userTrafficMonitor(User $user) { return view('admin.logs.userMonitor', array_merge(['username' => $user->username], $this->dataFlowChart($user->id))); } // 回调日志 public function callbackList(Request $request) { $query = PaymentCallback::query(); foreach (['trade_no', 'out_trade_no', 'status'] as $field) { $request->whenFilled($field, function ($value) use ($query, $field) { $query->where($field, $value); }); } return view('admin.logs.callback', ['callbackLogs' => $query->latest()->paginate(10)->appends($request->except('page'))]); } }