V4Controller.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. <?php
  2. namespace App\Http\Controllers\Api\Client;
  3. use App\Http\Controllers\ClientController;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\Node;
  6. use App\Models\ReferralLog;
  7. use App\Models\User;
  8. use Illuminate\Http\Request;
  9. use DB;
  10. use Response;
  11. class V4Controller extends Controller
  12. {
  13. public function __construct()
  14. {
  15. $this->middleware('auth:api')->except('login', 'register', 'shop', 'getConfig','version','buy','ClashConfig','getsysconfig','GetV2rayNode','checkNodeWeihu','UserDis','NodeWeihu');
  16. auth()->shouldUse('api');
  17. }
  18. //刷新用户信息
  19. public function GetUserinfo(Request $request)
  20. {
  21. $user = auth()->user();
  22. $userinfo = $user->profile();
  23. if (empty($userinfo)){
  24. return response()->json(['ret' => 0, 'msg' => "获取用户信息失败"]);
  25. }
  26. return response()->json(['ret' => 1, 'data' => $userinfo], 200);
  27. }
  28. public function NodeWeihu() {
  29. $query = Node::with(['onlineLogs', 'dailyDataFlows']);
  30. $nodeList = $query->where("country_code","=","us")->get();
  31. $nodeOlin = [];
  32. foreach ($nodeList as $key => $node) {
  33. // 在线人数
  34. $online_log = $node->onlineLogs()->where('log_time', '>=', strtotime('-5 minutes'))->latest('log_time')->first();
  35. $online_users = $online_log->online_user ?? 0;
  36. $nodeOlin[$key]["name"] =$node->name;
  37. $nodeOlin[$key]["id"] =$node->id;
  38. $nodeOlin[$key]["online_user"] = $online_users;
  39. }
  40. // var_dump($nodeOlin); die();
  41. $logInfo = [];
  42. foreach ($nodeOlin as $key => $vva) {
  43. $input = [
  44. "status" => $vva["online_user"] > 0 ? 1 : 0
  45. ];
  46. $post = Node::find($vva["id"]);
  47. // var_dump($post["name"]);
  48. // var_dump($post["status"]); die();
  49. if($post->update($input)){
  50. $logInfo[$key]["id"] = $vva["id"];
  51. $logInfo[$key]["name"] =$vva["name"];
  52. $logInfo[$key]["status"] = "{$input["status"]}更新成功";
  53. }else{
  54. $logInfo[$key]["id"] = $vva["id"];
  55. $logInfo[$key]["name"] =$vva["name"];
  56. $logInfo[$key]["status"] = "{$input["status"]}更新失败";
  57. }
  58. // var_dump($logInfo);
  59. // die();
  60. }
  61. return response()->json(['ret' => 1, 'data' => $logInfo], 200);
  62. }
  63. public function checkNodeWeihu() {
  64. $query = Node::with(['onlineLogs', 'dailyDataFlows']);
  65. $nodeList = $query->where("country_code","=","hk")->get();
  66. $nodeOlin = [];
  67. foreach ($nodeList as $key => $node) {
  68. // 在线人数
  69. $online_log = $node->onlineLogs()->where('log_time', '>=', strtotime('-5 minutes'))->latest('log_time')->first();
  70. $online_users = $online_log->online_user ?? 0;
  71. $nodeOlin[$key]["name"] =$node->name;
  72. $nodeOlin[$key]["id"] =$node->id;
  73. $nodeOlin[$key]["online_user"] = $online_users;
  74. }
  75. // var_dump($nodeOlin); die();
  76. $logInfo = [];
  77. foreach ($nodeOlin as $key => $vva) {
  78. $input = [
  79. "status" => $vva["online_user"] > 10 ? 1 : 0
  80. ];
  81. $post = Node::find($vva["id"]);
  82. // var_dump($post["name"]);
  83. // var_dump($post["status"]); die();
  84. if($post->update($input)){
  85. $logInfo[$key]["id"] = $vva["id"];
  86. $logInfo[$key]["name"] =$vva["name"];
  87. $logInfo[$key]["status"] = "{$input["status"]}更新成功";
  88. }else{
  89. $logInfo[$key]["id"] = $vva["id"];
  90. $logInfo[$key]["name"] =$vva["name"];
  91. $logInfo[$key]["status"] = "{$input["status"]}更新失败";
  92. }
  93. // var_dump($logInfo);
  94. // die();
  95. }
  96. return response()->json(['ret' => 1, 'data' => $logInfo], 200);
  97. }
  98. public function GetV2rayNode(Request $request){
  99. $user = User::query();
  100. $node = Node::query();
  101. $userinfo = $user->where('email','=','17624688@qq.com')->get();
  102. //$query = $query->nodes()->with(['labels', 'level_table','onlineLogs']);
  103. $retlist = $node->where('type','=',2)->get();
  104. $servers = [];
  105. foreach ($retlist as $key => $v ){
  106. $servers[] = $v->config($userinfo[0]);
  107. }
  108. return (new ClientController)->config("", $userinfo[0], $servers);
  109. //return response()->json(['ret' => 1, 'data' => $servers]);
  110. //return response()->json(['ret' => 1, 'data' => ['userinfo'=>$userinfo,'servers'=>$servers],'']);
  111. }
  112. public function AutoNode(Request $request){
  113. $auth_user = auth()->user();
  114. //select b.node_id, max(b.online_user) as online_user from node_online_log as b group by b.node_id
  115. $sub_query = 'select b.node_id, max(b.online_user) as online_user from node_online_log as b group by b.node_id';
  116. $query = Node::query();
  117. //select aa.online_user, aa.node_id, bb.* from (select b.node_id, max(log_time), b.online_user from node_online_log as b group by b.node_id) as aa left join node as bb on bb.id = aa.node_id where bb.country_code = 'hk' group by aa.online_user
  118. //limit 1
  119. $nodeList = $query->from(DB::raw('('.$sub_query.') as a'))
  120. ->leftJoin('node as bb','bb.id','=','a.node_id')
  121. ->where('bb.country_code','=','hk')
  122. ->groupBy('a.online_user')
  123. ->limit(1)
  124. ->get(['a.online_user','bb.*']);
  125. $keys = "online_users";
  126. foreach ($nodeList as $key => $v ){
  127. $servers = $v->config($auth_user);
  128. $servers[$keys] = $v["online_user"];
  129. }
  130. return response()->json(['ret' => 1, 'data' => $servers], 200);
  131. }
  132. /**
  133. * 获取全部节点
  134. * @param int|null $id
  135. * @return \Illuminate\Http\JsonResponse
  136. */
  137. public function nodeList(Request $request,int $id = null)
  138. {
  139. $isVless = $request->input("vless");
  140. $debug = $request->input("isdebug");
  141. $user = auth()->user();
  142. $query = $user->nodes()->with(['labels', 'level_table','onlineLogs']);
  143. if (empty($isVless)){
  144. $isVless = 0;
  145. }
  146. if ($isVless == 1){
  147. $nodeList = $query->orderByDesc('sort')->orderBy('id')->get();
  148. } else {
  149. $nodeList = $query->where("vless",'=',0)->orderByDesc('sort')->orderBy('id')->get();
  150. }
  151. if(isset($debug))
  152. {
  153. foreach ($nodeList as $node) {
  154. // 在线人数
  155. $online_log = $node->onlineLogs()->where('log_time', '>=', strtotime('-5 minutes'))->latest('log_time')->first();
  156. $node->leables = $node->labels;
  157. $node->online_users = $online_log->online_user ?? 0;
  158. $firstnode[] = $node;
  159. }
  160. foreach ($firstnode as $key => $val){
  161. $namesString = "";
  162. foreach ($firstnode[$key]["leables"] as $label) {
  163. $namesString .= $label["name"] . ", ";
  164. }
  165. // 移除最后一个逗号和空格
  166. $namesString = rtrim($namesString, ", ");
  167. $servers[] = $val->config($user);
  168. $servers[$key]["ip"] = $firstnode[$key]["ip"];
  169. $servers[$key]["online_users"] = $firstnode[$key]["online_users"];
  170. $servers[$key]["leables"] = $namesString;
  171. $servers[$key]["leables_level"] = $firstnode[$key]["level_table"]["level"];
  172. $servers[$key]["country_code"] = $firstnode[$key]["country_code"];
  173. }
  174. return response()->json($servers);
  175. }
  176. //var_dump($nodes); die();
  177. if (isset($id)) {
  178. $nodes = $user->nodes()->get();
  179. $node = $nodes->find($id);
  180. if (empty($node)) {
  181. return response()->json([], 204);
  182. }
  183. return response()->json($node->config($user));
  184. }
  185. $temp = array();
  186. $servers = [];
  187. $firstnode = [];
  188. foreach ($nodeList as $node) {
  189. // 在线人数
  190. $online_log = $node->onlineLogs()->where('log_time', '>=', strtotime('-5 minutes'))->latest('log_time')->first();
  191. $node->leables = $node->labels;
  192. $node->online_users = $online_log->online_user ?? 0;
  193. $firstnode[] = $node;
  194. }
  195. foreach ($firstnode as $key => $val){
  196. $namesString = "";
  197. foreach ($firstnode[$key]["leables"] as $label) {
  198. $namesString .= $label["name"] . ", ";
  199. }
  200. $namesString = rtrim($namesString, ", ");
  201. $servers[] = $val->config($user);
  202. $servers[$key]["ip"] = $firstnode[$key]["ip"];
  203. $servers[$key]["online_users"] = $firstnode[$key]["online_users"];
  204. $servers[$key]["country_code"] = $firstnode[$key]["country_code"];
  205. $servers[$key]["leables"] = $namesString;
  206. $servers[$key]["leables_level"] = $firstnode[$key]["level_table"]["level"];
  207. $servers[$key]["traffic_rate"] = $firstnode[$key]["traffic_rate"];
  208. }
  209. return response()->json(['ret' => 1, 'data' => $servers]);
  210. }
  211. public function UserDis(Request $request){
  212. $id = $request->input('id');
  213. // 从请求中获取需要更新的数据
  214. $data = [
  215. 'enable' => 0,
  216. 'expired_at' => '2023-05-01 15:35:19',
  217. 'remark' => '已经退款'
  218. ];
  219. // 使用Eloquent ORM查找对应的用户记录
  220. $user = User::find($id);
  221. // 使用update()方法更新用户记录
  222. return $user->update($data);
  223. }
  224. }