PoseidonController.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <?php
  2. namespace App\Http\Controllers\Server;
  3. use App\Services\ServerService;
  4. use App\Services\UserService;
  5. use Illuminate\Http\Request;
  6. use App\Http\Controllers\Controller;
  7. use App\Models\User;
  8. use App\Models\Plan;
  9. use App\Models\Server;
  10. use App\Models\ServerLog;
  11. use Illuminate\Support\Facades\Log;
  12. use Illuminate\Support\Facades\Cache;
  13. class PoseidonController extends Controller
  14. {
  15. CONST SERVER_CONFIG = '{"api":{"services":["HandlerService","StatsService"],"tag":"api"},"stats":{},"inbound":{"port":443,"protocol":"vmess","settings":{"clients":[]},"sniffing":{"enabled": true,"destOverride": ["http","tls"]},"streamSettings":{"network":"tcp"},"tag":"proxy"},"inboundDetour":[{"listen":"0.0.0.0","port":23333,"protocol":"dokodemo-door","settings":{"address":"0.0.0.0"},"tag":"api"}],"log":{"loglevel":"debug","access":"access.log","error":"error.log"},"outbound":{"protocol":"freedom","settings":{}},"outboundDetour":[{"protocol":"blackhole","settings":{},"tag":"block"}],"routing":{"rules":[{"inboundTag":"api","outboundTag":"api","type":"field"}]},"policy":{"levels":{"0":{"handshake":4,"connIdle":300,"uplinkOnly":5,"downlinkOnly":30,"statsUserUplink":true,"statsUserDownlink":true}}}}';
  16. // 后端获取用户
  17. public function user(Request $request)
  18. {
  19. if ($r = $this->verifyToken($request)) { return $r; }
  20. $nodeId = $request->input('node_id');
  21. $server = Server::find($nodeId);
  22. if (!$server) {
  23. return $this->error("server could not be found", 404);
  24. }
  25. Cache::put('server_last_check_at_' . $server->id, time());
  26. $serverService = new ServerService();
  27. $users = $serverService->getAvailableUsers(json_decode($server->group_id));
  28. $result = [];
  29. foreach ($users as $user) {
  30. $user->v2ray_user = [
  31. "uuid" => $user->v2ray_uuid,
  32. "email" => sprintf("%s@v2board.user", $user->v2ray_uuid),
  33. "alter_id" => $user->v2ray_alter_id,
  34. "level" => $user->v2ray_level,
  35. ];
  36. unset($user['v2ray_uuid']);
  37. unset($user['v2ray_alter_id']);
  38. unset($user['v2ray_level']);
  39. array_push($result, $user);
  40. }
  41. return $this->success($result);
  42. }
  43. // 后端提交数据
  44. public function submit(Request $request)
  45. {
  46. if ($r = $this->verifyToken($request)) { return $r; }
  47. // Log::info('serverSubmitData:' . $request->input('node_id') . ':' . file_get_contents('php://input'));
  48. $server = Server::find($request->input('node_id'));
  49. if (!$server) {
  50. return $this->error("server could not be found", 404);
  51. }
  52. $data = file_get_contents('php://input');
  53. $data = json_decode($data, true);
  54. $serverService = new ServerService();
  55. $userService = new UserService();
  56. foreach ($data as $item) {
  57. $u = $item['u'] * $server->rate;
  58. $d = $item['d'] * $server->rate;
  59. if (!$userService->trafficFetch($u, $d, $item['user_id'])) {
  60. return response([
  61. 'ret' => 0,
  62. 'msg' => 'user fetch fail'
  63. ]);
  64. }
  65. $serverService->log(
  66. $item['user_id'],
  67. $request->input('node_id'),
  68. $u,
  69. $d,
  70. $server->rate
  71. );
  72. }
  73. return $this->success('');
  74. }
  75. // 后端获取配置
  76. public function config(Request $request)
  77. {
  78. if ($r = $this->verifyToken($request)) { return $r; }
  79. $nodeId = $request->input('node_id');
  80. $localPort = $request->input('local_port');
  81. if (empty($nodeId) || empty($localPort)) {
  82. return $this->error('invalid parameters', 400);
  83. }
  84. $serverService = new ServerService();
  85. try {
  86. $json = $serverService->getConfig($nodeId, $localPort);
  87. $json->poseidon = [
  88. 'license_key' => (string)config('v2board.server_license'),
  89. ];
  90. return $this->success($json);
  91. } catch (\Exception $e) {
  92. return $this->error($e->getMessage(), 500);
  93. }
  94. }
  95. protected function verifyToken(Request $request)
  96. {
  97. $token = $request->input('token');
  98. if (empty($token)) {
  99. return $this->error("token must be set");
  100. }
  101. if ($token !== config('v2board.server_token')) {
  102. return $this->error("invalid token");
  103. }
  104. }
  105. protected function error($msg, int $status = 400) {
  106. return response([
  107. 'msg' => $msg,
  108. ], $status);
  109. }
  110. protected function success($data) {
  111. return response([
  112. 'msg' => 'ok',
  113. 'data' => $data,
  114. ]);
  115. }
  116. }