update: vless

This commit is contained in:
v2board 2023-08-02 01:52:25 +08:00
parent 07de70d8ab
commit 31c5cf1c2b
4 changed files with 23 additions and 5 deletions

View File

@ -6,6 +6,7 @@ use App\Http\Controllers\Controller;
use App\Models\ServerVless; use App\Models\ServerVless;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use ParagonIE_Sodium_Compat as SodiumCompat; use ParagonIE_Sodium_Compat as SodiumCompat;
use App\Utils\Helper;
class VlessController extends Controller class VlessController extends Controller
{ {
@ -19,7 +20,7 @@ class VlessController extends Controller
'host' => 'required', 'host' => 'required',
'port' => 'required', 'port' => 'required',
'server_port' => 'required', 'server_port' => 'required',
'tls' => 'required|in:0,1', 'tls' => 'required|in:0,1,2',
'tls_settings' => 'nullable|array', 'tls_settings' => 'nullable|array',
'flow' => 'nullable|in:xtls-rprx-vision', 'flow' => 'nullable|in:xtls-rprx-vision',
'network' => 'required', 'network' => 'required',
@ -30,13 +31,14 @@ class VlessController extends Controller
'sort' => 'nullable' 'sort' => 'nullable'
]); ]);
if (isset($params['tls_settings']) && (int)$params['tls_settings']['reality']) { if (isset($params['tls']) && (int)$params['tls'] === 2) {
$keyPair = SodiumCompat::crypto_box_keypair(); $keyPair = SodiumCompat::crypto_box_keypair();
$params['tls_settings'] = $params['tls_settings'] ?? [];
if (!isset($params['tls_settings']['public_key'])) { if (!isset($params['tls_settings']['public_key'])) {
$params['tls_settings']['public_key'] = base64_encode(SodiumCompat::crypto_box_publickey($keyPair)); $params['tls_settings']['public_key'] = Helper::base64EncodeUrlSafe(SodiumCompat::crypto_box_publickey($keyPair));
} }
if (!isset($params['tls_settings']['private_key'])) { if (!isset($params['tls_settings']['private_key'])) {
$params['tls_settings']['private_key'] = base64_encode(SodiumCompat::crypto_box_secretkey($keyPair)); $params['tls_settings']['private_key'] = Helper::base64EncodeUrlSafe(SodiumCompat::crypto_box_secretkey($keyPair));
} }
} }

View File

@ -111,6 +111,16 @@ class UniProxyController extends Controller
'obfs' => Helper::getServerKey($this->nodeInfo->created_at, 16) 'obfs' => Helper::getServerKey($this->nodeInfo->created_at, 16)
]; ];
break; break;
case "vless":
$response = [
'server_port' => $this->nodeInfo->server_port,
'network' => $this->nodeInfo->network,
'network_settings' => $this->nodeInfo->network_settings,
'tls' => $this->nodeInfo->tls,
'flow' => $this->nodeInfo->flow,
'tls_settings' => $this->nodeInfo->tls_settings
];
break;
} }
$response['base_config'] = [ $response['base_config'] = [
'push_interval' => (int)config('v2board.server_push_interval', 60), 'push_interval' => (int)config('v2board.server_push_interval', 60),

View File

@ -120,4 +120,10 @@ class Helper
$portRange = explode('-', $range); $portRange = explode('-', $range);
return rand($portRange[0], $portRange[1]); return rand($portRange[0], $portRange[1]);
} }
public static function base64EncodeUrlSafe($data)
{
$encoded = base64_encode($data);
return str_replace(['+', '/', '='], ['-', '_', ''], $encoded);
}
} }

File diff suppressed because one or more lines are too long