input('email'); $sn = $request->input('sn'); $is_coupon = $request->input('is_coupon'); $is_expire = $request->input('is_expire'); $pay_way = $request->input('pay_way'); $status = $request->input('status'); $range_time = $request->input('range_time'); $sort = $request->input('sort'); // 0-按创建时间降序、1-按创建时间升序 $order_id = $request->input('id'); $trade_no = $request->input('trade_no'); $query = Order::with(['user:id,email', 'goods:id,name', 'coupon:id,name,sn']); if (isset($email)) { $query->whereHas('user', static function ($q) use ($email) { $q->where('email', 'like', '%'.$email.'%'); }); } if (isset($sn)) { $query->where('sn', 'like', '%'.$sn.'%'); } if (isset($is_coupon)) { if ($is_coupon) { $query->where('coupon_id', '<>', null); } else { $query->whereCouponId(null); } } if (isset($is_expire)) { $query->whereIsExpire($is_expire); } if (isset($pay_way)) { $query->wherePayWay($pay_way); } if (isset($status)) { $query->whereStatus($status); } if (isset($range_time) && $range_time !== ',') { $range_time = explode(',', $range_time); $query->where('created_at', '>=', $range_time[0])->where('created_at', '<=', $range_time[1]); } if (isset($order_id)) { $query->whereId($order_id); } if ($sort) { $query->orderBy('id'); } else { $query->orderByDesc('id'); } if (isset($trade_no)){ $query->whereHas('payment' , function ($q) use ($trade_no) { $q->where('trade_no', 'like', '%'.$trade_no.'%'); }); }else { // $query->payment(); } // //dump( ['orders' => $query->latest()->paginate(15)->appends($request->except('page'))]); die(); // $data = $query->latest()->paginate(15)->appends($request->except('page')); // foreach ($data as $key => $v){ // echo $v; // } // die(); // var_dump($query->latest()->paginate(15)->appends($request->except('page'))); die(); return view('admin.logs.order', ['orders' => $query->latest()->paginate(15)->appends($request->except('page'))]); } // 流量日志 public function trafficLog(Request $request) { $port = $request->input('port'); $user_id = $request->input('user_id'); $email = $request->input('email'); $nodeId = $request->input('nodeId'); $startTime = $request->input('startTime'); $endTime = $request->input('endTime'); $lastHours = $request->input('last_hours'); $isAbnormal = $request->input('is_abnormal'); // 新增异常用户筛选 $query = UserDataFlowLog::with(['user', 'node']); if (isset($port)) { $query->whereHas('user', static function ($q) use ($port) { $q->wherePort($port); }); } if (isset($user_id)) { $query->whereUserId($user_id); } if (isset($email)) { $query->whereHas('user', static function ($q) use ($email) { $q->where('email', 'like', '%'.$email.'%'); }); } if (isset($nodeId)) { $query->whereNodeId($nodeId); } // 处理时间范围 if ($lastHours) { $query->where('log_time', '>=', time() - 3600 * intval($lastHours)); } else { if (isset($startTime)) { $query->where('log_time', '>=', strtotime($startTime)); } if (isset($endTime)) { $query->where('log_time', '<=', strtotime($endTime)); } } $baseTrafficBanValue = sysConfig('traffic_ban_value') * GB; if ($isAbnormal) { // 只查最近N小时,避免全表扫描 $hours = $lastHours ?: 1; $since = time() - 3600 * intval($hours); // 先查出最近N小时内所有流量日志 $logs = UserDataFlowLog::with('node') ->where('log_time', '>=', $since) ->get(); // 统计每个用户的"加权流量" $userWeighted = []; foreach ($logs as $log) { $rate = ($log->node && $log->node->traffic_rate) ? $log->node->traffic_rate : 1; if ($rate <= 0) $rate = 1; $weighted = ($log->u + $log->d) / $rate; if (!isset($userWeighted[$log->user_id])) { $userWeighted[$log->user_id] = 0; } $userWeighted[$log->user_id] += $weighted; } // 找出超限的用户ID $abnormalUserIds = []; foreach ($userWeighted as $userId => $total) { if ($total > $baseTrafficBanValue) { $abnormalUserIds[] = $userId; } } // 只查异常用户 $query->whereIn('user_id', $abnormalUserIds); } $dataFlowLogs = $query->latest('log_time')->paginate(20)->appends($request->except('page')); foreach ($dataFlowLogs as $log) { $rate = ($log->node && $log->node->traffic_rate) ? $log->node->traffic_rate : 1; if ($rate <= 0) $rate = 1; $weighted = ($log->u + $log->d) / $rate; $log->weighted_traffic = $weighted; $log->is_abnormal = $weighted > $baseTrafficBanValue; // 先保存原始流量值 $original_u = $log->u; $original_d = $log->d; // 转换为可读格式 $log->u = flowAutoShow($original_u); $log->d = flowAutoShow($original_d); // 增加转换后的流量显示(转换为1倍流量) if ($rate != 1) { $converted_u = $original_u / $rate; $converted_d = $original_d / $rate; $log->converted_u = flowAutoShow($converted_u); $log->converted_d = flowAutoShow($converted_d); } $log->log_time = date('Y-m-d H:i:s', $log->log_time); } return view('admin.logs.traffic', [ 'totalTraffic' => flowAutoShow($query->sum('u') + $query->sum('d')), 'dataFlowLogs' => $dataFlowLogs, 'nodes' => Node::whereStatus(1)->orderByDesc('sort')->latest()->get(), 'isAbnormal' => $isAbnormal // 传递筛选状态到视图 ]); } // 邮件发送日志列表 public function notificationLog(Request $request) { $email = $request->input('email'); $type = $request->input('type'); $query = NotificationLog::query(); if (isset($email)) { $query->where('address', 'like', '%'.$email.'%'); } if (isset($type)) { $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) { $ip = $request->input('ip'); $email = $request->input('email'); $port = $request->input('port'); $nodeId = $request->input('nodeId'); $query = NodeOnlineIp::with(['node:id,name', 'user:id,email'])->where('created_at', '>=', strtotime('-2 minutes')); if (isset($ip)) { $query->whereIp($ip); } if (isset($email)) { $query->whereHas('user', static function ($q) use ($email) { $q->where('email', 'like', '%'.$email.'%'); }); } if (isset($port)) { $query->whereHas('user', static function ($q) use ($port) { $q->wherePort($port); }); } if (isset($nodeId)) { $query->whereHas('node', static function ($q) use ($nodeId) { $q->whereId($nodeId); }); } if (isset($id)) { $query->whereHas('user', static function ($q) use ($id) { $q->whereId($id); }); } $onlineIPLogs = $query->groupBy('user_id', 'node_id')->latest()->paginate(20)->appends($request->except('page')); // foreach ($onlineIPLogs as $log) { // // 跳过上报多IP的 // if ($log->ip === null || strpos($log->ip, ',') !== false) { // 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) { $email = $request->input('email'); $query = UserCreditLog::with('user:id,email')->latest(); if (isset($email)) { $query->whereHas('user', static function ($q) use ($email) { $q->where('email', 'like', '%'.$email.'%'); }); } return view('admin.logs.userCreditHistory', ['userCreditLogs' => $query->paginate(15)->appends($request->except('page'))]); } // 用户封禁记录 public function userBanLogList(Request $request) { $email = $request->input('email'); $isBanned = $request->input('is_banned'); // 新增封禁状态筛选 $query = UserBanedLog::with('user:id,email,t')->latest(); if (isset($email)) { $query->whereHas('user', static function ($q) use ($email) { $q->where('email', 'like', '%'.$email.'%'); }); } // 添加封禁状态筛选 if (isset($isBanned)) { if ($isBanned == 1) { $query->where('time', '>', 0); // 有封禁时长的记录 } else { $query->where('time', 0); // 无封禁时长的记录 } } return view('admin.logs.userBanHistory', [ 'userBanLogs' => $query->paginate(15)->appends($request->except('page')), 'isBanned' => $isBanned // 传递当前筛选状态到视图 ]); } // 用户流量变动记录 public function userTrafficLogList(Request $request) { $email = $request->input('email'); $query = UserDataModifyLog::with(['user:id,email', 'order.goods:id,name']); if (isset($email)) { $query->whereHas('user', static function ($q) use ($email) { $q->where('email', 'like', '%'.$email.'%'); }); } return view('admin.logs.userTraffic', ['userTrafficLogs' => $query->latest()->paginate(15)->appends($request->except('page'))]); } // 用户在线IP记录 public function userOnlineIPList(Request $request) { $email = $request->input('email'); $port = $request->input('port'); $wechat = $request->input('wechat'); $qq = $request->input('qq'); $query = User::activeUser(); if (isset($email)) { $query->where('email', 'like', '%'.$email.'%'); } if (isset($wechat)) { $query->where('wechat', 'like', '%'.$wechat.'%'); } if (isset($qq)) { $query->where('qq', 'like', '%'.$qq.'%'); } if (isset($port)) { $query->wherePort($port); } $userList = $query->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(['email' => $user->email], $this->dataFlowChart($user->id))); } // 回调日志 public function callbackList(Request $request) { $status = $request->input('status', 0); $out_trade_no = $request->input('out_trade_no', 0); $query = PaymentCallback::query(); if (isset($status)) { $query->whereStatus($status); } if (isset($out_trade_no)){ $query->where('out_trade_no',"=",$out_trade_no); } $data = $query->latest()->paginate(10)->appends($request->except('page')); // die(); return view('admin.logs.callback', ['callbackLogs' => $data]); } }