mirror of
https://github.com/v2board/v2board.git
synced 2024-11-10 09:39:10 +08:00
update: vless
This commit is contained in:
parent
07de70d8ab
commit
31c5cf1c2b
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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),
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
2
public/assets/admin/umi.js
vendored
2
public/assets/admin/umi.js
vendored
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue
Block a user