V2RayController.php 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. <?php
  2. namespace App\Http\Controllers\Api\WebApi;
  3. use App\Models\Node;
  4. use App\Models\NodeCertificate;
  5. use Illuminate\Http\JsonResponse;
  6. use Illuminate\Http\Request;
  7. class V2RayController extends BaseController {
  8. // 获取节点信息
  9. public function getNodeInfo($id): JsonResponse {
  10. $node = Node::find($id);
  11. $nodeDv = NodeCertificate::whereDomain($node->v2_host)->first();
  12. return $this->returnData('获取节点信息成功', 'success', 200, [
  13. 'id' => $node->id,
  14. 'is_udp' => $node->is_udp? true : false,
  15. 'speed_limit' => $node->speed_limit,
  16. 'client_limit' => $node->client_limit,
  17. 'push_port' => $node->push_port,
  18. 'redirect_url' => sysConfig('redirect_url'),
  19. 'secret' => $node->auth->secret,
  20. 'key' => $nodeDv? $nodeDv->key : '',
  21. 'pem' => $nodeDv? $nodeDv->pem : '',
  22. 'v2_license' => sysConfig('v2ray_license'),
  23. 'v2_alter_id' => $node->v2_alter_id,
  24. 'v2_port' => $node->v2_port,
  25. 'v2_method' => $node->v2_method,
  26. 'v2_net' => $node->v2_net,
  27. 'v2_type' => $node->v2_type,
  28. 'v2_host' => $node->v2_host,
  29. 'v2_path' => $node->v2_path,
  30. 'v2_tls' => $node->v2_tls? true : false,
  31. 'v2_tls_provider' => $node->tls_provider?: sysConfig('v2ray_tls_provider'),
  32. ]);
  33. }
  34. // 获取节点可用的用户列表
  35. public function getUserList($id): JsonResponse {
  36. $users = Node::find($id)->node_access_users;
  37. $data = [];
  38. foreach($users as $user){
  39. $data[] = [
  40. 'uid' => $user->id,
  41. 'vmess_uid' => $user->vmess_id,
  42. 'speed_limit' => $user->speed_limit
  43. ];
  44. }
  45. return $this->returnData('获取用户列表成功', 'success', 200, $data, ['updateTime' => time()]);
  46. }
  47. // 上报节点伪装域名证书信息
  48. public function addCertificate(Request $request, $id): JsonResponse {
  49. $key = $request->input('key');
  50. $pem = $request->input('pem');
  51. if($request->has(['key', 'pem'])){
  52. $node = Node::find($id);
  53. $Dv = NodeCertificate::whereDomain($node->v2_host)->first();
  54. if($Dv){
  55. $ret = NodeCertificate::whereId($Dv->id)->update(['key' => $key, 'pem' => $pem]);
  56. }else{
  57. $ret = new NodeCertificate();
  58. $ret->domain = $node->server;
  59. $ret->key = $request->input('key');
  60. $ret->pem = $request->input('pem');
  61. $ret->save();
  62. }
  63. if($ret){
  64. return $this->returnData('上报节点伪装域名证书成功', 'success', 200);
  65. }
  66. }
  67. return $this->returnData('上报节点伪装域名证书失败,请检查字段');
  68. }
  69. }