LogsController.php 9.7 KB

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