LogsController.php 10.0 KB

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