UserController.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. <?php
  2. namespace App\Controllers\Mod_Mu;
  3. use App\Models\Node;
  4. use App\Models\TrafficLog;
  5. use App\Models\User;
  6. use App\Models\NodeOnlineLog;
  7. use App\Models\Ip;
  8. use App\Models\DetectLog;
  9. use App\Controllers\BaseController;
  10. use App\Utils\Tools;
  11. use Ramsey\Uuid\Uuid;
  12. class UserController extends BaseController
  13. {
  14. // User List
  15. public function index($request, $response, $args)
  16. {
  17. $params = $request->getQueryParams();
  18. $node_id = $params['node_id'];
  19. $node = Node::where("id", "=", $node_id)->first();
  20. if ($node == null) {
  21. $res = [
  22. "ret" => 0
  23. ];
  24. return $this->echoJson($response, $res);
  25. }
  26. $node->node_heartbeat=time();
  27. $node->save();
  28. if ($node->node_group!=0) {
  29. $users_raw = User::where(
  30. function ($query) use ($node){
  31. $query->where(
  32. function ($query1) use ($node){
  33. $query1->where("class", ">=", $node->node_class)
  34. ->where("node_group", "=", $node->node_group);
  35. }
  36. )->orwhere('is_admin', 1);
  37. }
  38. )
  39. ->where("enable", 1)->where("expire_in", ">", date("Y-m-d H:i:s"))->get();
  40. } else {
  41. $users_raw = User::where(
  42. function ($query) use ($node){
  43. $query->where(
  44. function ($query1) use ($node){
  45. $query1->where("class", ">=", $node->node_class);
  46. }
  47. )->orwhere('is_admin', 1);
  48. }
  49. )->where("enable", 1)->where("expire_in", ">", date("Y-m-d H:i:s"))->get();
  50. }
  51. if ($node->node_bandwidth_limit!=0) {
  52. if ($node->node_bandwidth_limit < $node->node_bandwidth) {
  53. $users=null;
  54. $res = [
  55. "ret" => 1,
  56. "data" => $users
  57. ];
  58. return $this->echoJson($response, $res);
  59. }
  60. }
  61. $users = array();
  62. $key_list = array('email', 'method', 'obfs', 'obfs_param', 'protocol', 'protocol_param',
  63. 'forbidden_ip', 'forbidden_port', 'node_speedlimit', 'disconnect_ip',
  64. 'is_multi_user', 'id', 'port', 'passwd', 'u', 'd');
  65. foreach ($users_raw as $user_raw) {
  66. if ($user_raw->transfer_enable > $user_raw->u + $user_raw->d) {
  67. $user_raw = Tools::keyFilter($user_raw, $key_list);
  68. $user_raw->uuid = Uuid::uuid3(Uuid::NAMESPACE_DNS, $user_raw->passwd);
  69. array_push($users, $user_raw);
  70. }
  71. }
  72. $res = [
  73. "ret" => 1,
  74. "data" => $users
  75. ];
  76. return $this->echoJson($response, $res);
  77. }
  78. // Update Traffic
  79. public function addTraffic($request, $response, $args)
  80. {
  81. $params = $request->getQueryParams();
  82. $data = $request->getParam('data');
  83. $this_time_total_bandwidth = 0;
  84. $node_id = $params['node_id'];
  85. $node = Node::find($node_id);
  86. if ($node == null) {
  87. $res = [
  88. "ret" => 0
  89. ];
  90. return $this->echoJson($response, $res);
  91. }
  92. if (count($data) > 0) {
  93. foreach ($data as $log) {
  94. $u = $log['u'];
  95. $d = $log['d'];
  96. $user_id = $log['user_id'];
  97. $user = User::find($user_id);
  98. if($user == NULL) {
  99. continue;
  100. }
  101. $user->t = time();
  102. $user->u += $u * $node->traffic_rate;
  103. $user->d += $d * $node->traffic_rate;
  104. $this_time_total_bandwidth += $u + $d;
  105. if (!$user->save()) {
  106. $res = [
  107. "ret" => 0,
  108. "data" => "update failed",
  109. ];
  110. return $this->echoJson($response, $res);
  111. }
  112. // log
  113. $traffic = new TrafficLog();
  114. $traffic->user_id = $user_id;
  115. $traffic->u = $u;
  116. $traffic->d = $d;
  117. $traffic->node_id = $node_id;
  118. $traffic->rate = $node->traffic_rate;
  119. $traffic->traffic = Tools::flowAutoShow(($u + $d) * $node->traffic_rate);
  120. $traffic->log_time = time();
  121. $traffic->save();
  122. }
  123. }
  124. $node->node_bandwidth += $this_time_total_bandwidth;
  125. $node->save();
  126. $online_log = new NodeOnlineLog();
  127. $online_log->node_id = $node_id;
  128. $online_log->online_user = count($data);
  129. $online_log->log_time = time();
  130. $online_log->save();
  131. $res = [
  132. "ret" => 1,
  133. "data" => "ok",
  134. ];
  135. return $this->echoJson($response, $res);
  136. }
  137. public function addAliveIp($request, $response, $args)
  138. {
  139. $params = $request->getQueryParams();
  140. $data = $request->getParam('data');
  141. $node_id = $params['node_id'];
  142. $node = Node::find($node_id);
  143. if ($node == null) {
  144. $res = [
  145. "ret" => 0
  146. ];
  147. return $this->echoJson($response, $res);
  148. }
  149. if (count($data) > 0) {
  150. foreach ($data as $log) {
  151. $ip = $log['ip'];
  152. $userid = $log['user_id'];
  153. // log
  154. $ip_log = new Ip();
  155. $ip_log->userid = $userid;
  156. $ip_log->nodeid = $node_id;
  157. $ip_log->ip = $ip;
  158. $ip_log->datetime = time();
  159. $ip_log->save();
  160. }
  161. }
  162. $res = [
  163. "ret" => 1,
  164. "data" => "ok",
  165. ];
  166. return $this->echoJson($response, $res);
  167. }
  168. public function addDetectLog($request, $response, $args)
  169. {
  170. $params = $request->getQueryParams();
  171. $data = $request->getParam('data');
  172. $node_id = $params['node_id'];
  173. $node = Node::find($node_id);
  174. if ($node == null) {
  175. $res = [
  176. "ret" => 0
  177. ];
  178. return $this->echoJson($response, $res);
  179. }
  180. if (count($data) > 0) {
  181. foreach ($data as $log) {
  182. $list_id = $log['list_id'];
  183. $user_id = $log['user_id'];
  184. // log
  185. $detect_log = new DetectLog();
  186. $detect_log->user_id = $user_id;
  187. $detect_log->list_id = $list_id;
  188. $detect_log->node_id = $node_id;
  189. $detect_log->datetime = time();
  190. $detect_log->save();
  191. }
  192. }
  193. $res = [
  194. "ret" => 1,
  195. "data" => "ok",
  196. ];
  197. return $this->echoJson($response, $res);
  198. }
  199. }