update: opt code

This commit is contained in:
tokumeikoi 2021-08-06 01:43:01 +09:00
parent 0f0f726269
commit e6a7c2c11c
32 changed files with 72 additions and 113 deletions

View File

@ -24,10 +24,6 @@ class CouponController extends Controller
$total = $builder->count(); $total = $builder->count();
$coupons = $builder->forPage($current, $pageSize) $coupons = $builder->forPage($current, $pageSize)
->get(); ->get();
foreach ($coupons as $k => $v) {
if ($coupons[$k]['limit_plan_ids']) $coupons[$k]['limit_plan_ids'] = json_decode($coupons[$k]['limit_plan_ids']);
}
return response([ return response([
'data' => $coupons, 'data' => $coupons,
'total' => $total 'total' => $total
@ -37,9 +33,6 @@ class CouponController extends Controller
public function save(CouponSave $request) public function save(CouponSave $request)
{ {
$params = $request->validated(); $params = $request->validated();
if (isset($params['limit_plan_ids'])) {
$params['limit_plan_ids'] = json_encode($params['limit_plan_ids']);
}
if (!$request->input('id')) { if (!$request->input('id')) {
if (!isset($params['code'])) { if (!isset($params['code'])) {
$params['code'] = Helper::randomChar(8); $params['code'] = Helper::randomChar(8);
@ -68,9 +61,6 @@ class CouponController extends Controller
} }
$params = $request->validated(); $params = $request->validated();
if (isset($params['limit_plan_ids'])) {
$params['limit_plan_ids'] = json_encode($params['limit_plan_ids']);
}
if (!$request->input('id')) { if (!$request->input('id')) {
if (!isset($params['code'])) { if (!isset($params['code'])) {
$params['code'] = Helper::randomChar(8); $params['code'] = Helper::randomChar(8);
@ -95,10 +85,8 @@ class CouponController extends Controller
{ {
$coupons = []; $coupons = [];
$coupon = $request->validated(); $coupon = $request->validated();
if (isset($coupon['limit_plan_ids'])) {
$coupon['limit_plan_ids'] = json_encode($coupon['limit_plan_ids']);
}
$coupon['created_at'] = $coupon['updated_at'] = time(); $coupon['created_at'] = $coupon['updated_at'] = time();
$coupon['limit_plan_ids'] = json_encode($coupon['limit_plan_ids']);
unset($coupon['generate_count']); unset($coupon['generate_count']);
for ($i = 0;$i < $request->input('generate_count');$i++) { for ($i = 0;$i < $request->input('generate_count');$i++) {
$coupon['code'] = Helper::randomChar(8); $coupon['code'] = Helper::randomChar(8);
@ -118,7 +106,7 @@ class CouponController extends Controller
$endTime = date('Y-m-d H:i:s', $coupon['ended_at']); $endTime = date('Y-m-d H:i:s', $coupon['ended_at']);
$limitUse = $coupon['limit_use'] ?? '不限制'; $limitUse = $coupon['limit_use'] ?? '不限制';
$createTime = date('Y-m-d H:i:s', $coupon['created_at']); $createTime = date('Y-m-d H:i:s', $coupon['created_at']);
$limitPlanIds = $coupon['limit_plan_ids'] ?? '不限制'; $limitPlanIds = implode("/", json_decode($coupon['limit_plan_ids'], true)) ?? '不限制';
$data .= "{$coupon['name']},{$type},{$value},{$startTime},{$endTime},{$limitUse},{$limitPlanIds},{$coupon['code']},{$createTime}\r\n"; $data .= "{$coupon['name']},{$type},{$value},{$startTime},{$endTime},{$limitUse},{$limitPlanIds},{$coupon['code']},{$createTime}\r\n";
} }
echo $data; echo $data;

View File

@ -52,8 +52,7 @@ class GroupController extends Controller
$servers = Server::all(); $servers = Server::all();
foreach ($servers as $server) { foreach ($servers as $server) {
$groupId = json_decode($server->group_id); if (in_array($request->input('id'), $server->group_id)) {
if (in_array($request->input('id'), $groupId)) {
abort(500, '该组已被节点所使用,无法删除'); abort(500, '该组已被节点所使用,无法删除');
} }
} }

View File

@ -14,11 +14,6 @@ class ShadowsocksController extends Controller
public function save(ServerShadowsocksSave $request) public function save(ServerShadowsocksSave $request)
{ {
$params = $request->validated(); $params = $request->validated();
$params['group_id'] = json_encode($params['group_id']);
if (isset($params['tags'])) {
$params['tags'] = json_encode($params['tags']);
}
if ($request->input('id')) { if ($request->input('id')) {
$server = ServerShadowsocks::find($request->input('id')); $server = ServerShadowsocks::find($request->input('id'));
if (!$server) { if (!$server) {

View File

@ -14,11 +14,6 @@ class TrojanController extends Controller
public function save(ServerTrojanSave $request) public function save(ServerTrojanSave $request)
{ {
$params = $request->validated(); $params = $request->validated();
$params['group_id'] = json_encode($params['group_id']);
if (isset($params['tags'])) {
$params['tags'] = json_encode($params['tags']);
}
if ($request->input('id')) { if ($request->input('id')) {
$server = ServerTrojan::find($request->input('id')); $server = ServerTrojan::find($request->input('id'));
if (!$server) { if (!$server) {

View File

@ -14,11 +14,6 @@ class V2rayController extends Controller
public function save(ServerV2raySave $request) public function save(ServerV2raySave $request)
{ {
$params = $request->validated(); $params = $request->validated();
$params['group_id'] = json_encode($params['group_id']);
if (isset($params['tags'])) {
$params['tags'] = json_encode($params['tags']);
}
if (isset($params['dnsSettings'])) { if (isset($params['dnsSettings'])) {
if (!is_object(json_decode($params['dnsSettings']))) { if (!is_object(json_decode($params['dnsSettings']))) {
abort(500, 'DNS规则配置格式不正确'); abort(500, 'DNS规则配置格式不正确');

View File

@ -67,18 +67,18 @@ class AnXray
]; ];
if ($server['tls']) { if ($server['tls']) {
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
$config['sni'] = urlencode($tlsSettings['serverName']); $config['sni'] = urlencode($tlsSettings['serverName']);
} }
} }
if ((string)$server['network'] === 'ws') { if ((string)$server['network'] === 'ws') {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path'])) $config['path'] = urlencode($wsSettings['path']); if (isset($wsSettings['path'])) $config['path'] = urlencode($wsSettings['path']);
if (isset($wsSettings['headers']['Host'])) $config['host'] = urlencode($wsSettings['headers']['Host']); if (isset($wsSettings['headers']['Host'])) $config['host'] = urlencode($wsSettings['headers']['Host']);
} }
if ((string)$server['network'] === 'grpc') { if ((string)$server['network'] === 'grpc') {
$grpcSettings = json_decode($server['networkSettings'], true); $grpcSettings = $server['networkSettings'];
if (isset($grpcSettings['serviceName'])) $config['serviceName'] = urlencode($grpcSettings['serviceName']); if (isset($grpcSettings['serviceName'])) $config['serviceName'] = urlencode($grpcSettings['serviceName']);
} }
return "vmess://" . $uuid . "@" . $server['host'] . ":" . $server['port'] . "?" . http_build_query($config) . "#" . urlencode($server['name']) . "\r\n"; return "vmess://" . $uuid . "@" . $server['host'] . ":" . $server['port'] . "?" . http_build_query($config) . "#" . urlencode($server['name']) . "\r\n";

View File

@ -84,7 +84,7 @@ class Clash
if ($server['tls']) { if ($server['tls']) {
$array['tls'] = true; $array['tls'] = true;
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure']))
$array['skip-cert-verify'] = ($tlsSettings['allowInsecure'] ? true : false); $array['skip-cert-verify'] = ($tlsSettings['allowInsecure'] ? true : false);
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
@ -94,7 +94,7 @@ class Clash
if ($server['network'] === 'ws') { if ($server['network'] === 'ws') {
$array['network'] = 'ws'; $array['network'] = 'ws';
if ($server['networkSettings']) { if ($server['networkSettings']) {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path']) && !empty($wsSettings['path'])) if (isset($wsSettings['path']) && !empty($wsSettings['path']))
$array['ws-path'] = $wsSettings['path']; $array['ws-path'] = $wsSettings['path'];
if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host'])) if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']))
@ -104,7 +104,7 @@ class Clash
if ($server['network'] === 'grpc') { if ($server['network'] === 'grpc') {
$array['network'] = 'grpc'; $array['network'] = 'grpc';
if ($server['networkSettings']) { if ($server['networkSettings']) {
$grpcObject = json_decode($server['networkSettings'], true); $grpcObject = $server['networkSettings'];
$array['grpc-opts'] = []; $array['grpc-opts'] = [];
$array['grpc-opts']['grpc-service-name'] = $grpcObject['serviceName']; $array['grpc-opts']['grpc-service-name'] = $grpcObject['serviceName'];
} }

View File

@ -63,18 +63,18 @@ class Passwall
]; ];
if ($server['tls']) { if ($server['tls']) {
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
$config['sni'] = $tlsSettings['serverName']; $config['sni'] = $tlsSettings['serverName'];
} }
} }
if ((string)$server['network'] === 'ws') { if ((string)$server['network'] === 'ws') {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path']; if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path'];
if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host']; if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host'];
} }
if ((string)$server['network'] === 'grpc') { if ((string)$server['network'] === 'grpc') {
$grpcSettings = json_decode($server['networkSettings'], true); $grpcSettings = $server['networkSettings'];
if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName']; if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName'];
} }
return "vmess://" . base64_encode(json_encode($config)) . "\r\n"; return "vmess://" . base64_encode(json_encode($config)) . "\r\n";

View File

@ -66,7 +66,7 @@ class QuantumultX
if ($server['network'] === 'tcp') if ($server['network'] === 'tcp')
array_push($config, 'obfs=over-tls'); array_push($config, 'obfs=over-tls');
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure']))
array_push($config, 'tls-verification=' . ($tlsSettings['allowInsecure'] ? 'false' : 'true')); array_push($config, 'tls-verification=' . ($tlsSettings['allowInsecure'] ? 'false' : 'true'));
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
@ -79,7 +79,7 @@ class QuantumultX
else else
array_push($config, 'obfs=ws'); array_push($config, 'obfs=ws');
if ($server['networkSettings']) { if ($server['networkSettings']) {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path']) && !empty($wsSettings['path'])) if (isset($wsSettings['path']) && !empty($wsSettings['path']))
array_push($config, "obfs-uri={$wsSettings['path']}"); array_push($config, "obfs-uri={$wsSettings['path']}");
if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']) && !isset($host)) if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']) && !isset($host))

View File

@ -63,18 +63,18 @@ class SSRPlus
]; ];
if ($server['tls']) { if ($server['tls']) {
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
$config['sni'] = $tlsSettings['serverName']; $config['sni'] = $tlsSettings['serverName'];
} }
} }
if ((string)$server['network'] === 'ws') { if ((string)$server['network'] === 'ws') {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path']; if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path'];
if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host']; if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host'];
} }
if ((string)$server['network'] === 'grpc') { if ((string)$server['network'] === 'grpc') {
$grpcSettings = json_decode($server['networkSettings'], true); $grpcSettings = $server['networkSettings'];
if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName']; if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName'];
} }
return "vmess://" . base64_encode(json_encode($config)) . "\r\n"; return "vmess://" . base64_encode(json_encode($config)) . "\r\n";

View File

@ -63,7 +63,7 @@ class Shadowrocket
if ($server['tls']) { if ($server['tls']) {
$config['tls'] = 1; $config['tls'] = 1;
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure']))
$config['allowInsecure'] = (int)$tlsSettings['allowInsecure']; $config['allowInsecure'] = (int)$tlsSettings['allowInsecure'];
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
@ -73,7 +73,7 @@ class Shadowrocket
if ($server['network'] === 'ws') { if ($server['network'] === 'ws') {
$config['obfs'] = "websocket"; $config['obfs'] = "websocket";
if ($server['networkSettings']) { if ($server['networkSettings']) {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path']) && !empty($wsSettings['path'])) if (isset($wsSettings['path']) && !empty($wsSettings['path']))
$config['path'] = $wsSettings['path']; $config['path'] = $wsSettings['path'];
if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host'])) if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']))
@ -83,7 +83,7 @@ class Shadowrocket
if ($server['network'] === 'grpc') { if ($server['network'] === 'grpc') {
$config['obfs'] = "grpc"; $config['obfs'] = "grpc";
if ($server['networkSettings']) { if ($server['networkSettings']) {
$grpcSettings = json_decode($server['networkSettings'], true); $grpcSettings = $server['networkSettings'];
if (isset($grpcSettings['serviceName']) && !empty($grpcSettings['serviceName'])) if (isset($grpcSettings['serviceName']) && !empty($grpcSettings['serviceName']))
$config['path'] = $grpcSettings['serviceName']; $config['path'] = $grpcSettings['serviceName'];
} }

View File

@ -88,7 +88,7 @@ class Surfboard
if ($server['tls']) { if ($server['tls']) {
array_push($config, 'tls=true'); array_push($config, 'tls=true');
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure']))
array_push($config, 'skip-cert-verify=' . ($tlsSettings['allowInsecure'] ? 'true' : 'false')); array_push($config, 'skip-cert-verify=' . ($tlsSettings['allowInsecure'] ? 'true' : 'false'));
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
@ -98,7 +98,7 @@ class Surfboard
if ($server['network'] === 'ws') { if ($server['network'] === 'ws') {
array_push($config, 'ws=true'); array_push($config, 'ws=true');
if ($server['networkSettings']) { if ($server['networkSettings']) {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path']) && !empty($wsSettings['path'])) if (isset($wsSettings['path']) && !empty($wsSettings['path']))
array_push($config, "ws-path={$wsSettings['path']}"); array_push($config, "ws-path={$wsSettings['path']}");
if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host'])) if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']))

View File

@ -92,7 +92,7 @@ class Surge
if ($server['tls']) { if ($server['tls']) {
array_push($config, 'tls=true'); array_push($config, 'tls=true');
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure']))
array_push($config, 'skip-cert-verify=' . ($tlsSettings['allowInsecure'] ? 'true' : 'false')); array_push($config, 'skip-cert-verify=' . ($tlsSettings['allowInsecure'] ? 'true' : 'false'));
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
@ -102,7 +102,7 @@ class Surge
if ($server['network'] === 'ws') { if ($server['network'] === 'ws') {
array_push($config, 'ws=true'); array_push($config, 'ws=true');
if ($server['networkSettings']) { if ($server['networkSettings']) {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path']) && !empty($wsSettings['path'])) if (isset($wsSettings['path']) && !empty($wsSettings['path']))
array_push($config, "ws-path={$wsSettings['path']}"); array_push($config, "ws-path={$wsSettings['path']}");
if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host'])) if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']))

View File

@ -63,18 +63,18 @@ class V2rayN
]; ];
if ($server['tls']) { if ($server['tls']) {
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
$config['sni'] = $tlsSettings['serverName']; $config['sni'] = $tlsSettings['serverName'];
} }
} }
if ((string)$server['network'] === 'ws') { if ((string)$server['network'] === 'ws') {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path']; if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path'];
if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host']; if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host'];
} }
if ((string)$server['network'] === 'grpc') { if ((string)$server['network'] === 'grpc') {
$grpcSettings = json_decode($server['networkSettings'], true); $grpcSettings = $server['networkSettings'];
if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName']; if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName'];
} }
return "vmess://" . base64_encode(json_encode($config)) . "\r\n"; return "vmess://" . base64_encode(json_encode($config)) . "\r\n";

View File

@ -63,18 +63,18 @@ class V2rayNG
]; ];
if ($server['tls']) { if ($server['tls']) {
if ($server['tlsSettings']) { if ($server['tlsSettings']) {
$tlsSettings = json_decode($server['tlsSettings'], true); $tlsSettings = $server['tlsSettings'];
if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
$config['sni'] = $tlsSettings['serverName']; $config['sni'] = $tlsSettings['serverName'];
} }
} }
if ((string)$server['network'] === 'ws') { if ((string)$server['network'] === 'ws') {
$wsSettings = json_decode($server['networkSettings'], true); $wsSettings = $server['networkSettings'];
if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path']; if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path'];
if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host']; if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host'];
} }
if ((string)$server['network'] === 'grpc') { if ((string)$server['network'] === 'grpc') {
$grpcSettings = json_decode($server['networkSettings'], true); $grpcSettings = $server['networkSettings'];
if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName']; if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName'];
} }
return "vmess://" . base64_encode(json_encode($config)) . "\r\n"; return "vmess://" . base64_encode(json_encode($config)) . "\r\n";

View File

@ -41,7 +41,7 @@ class DeepbworkController extends Controller
} }
Cache::put(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $server->id), time(), 3600); Cache::put(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $server->id), time(), 3600);
$serverService = new ServerService(); $serverService = new ServerService();
$users = $serverService->getAvailableUsers(json_decode($server->group_id)); $users = $serverService->getAvailableUsers($server->group_id);
$result = []; $result = [];
foreach ($users as $user) { foreach ($users as $user) {
$user->v2ray_user = [ $user->v2ray_user = [

View File

@ -39,7 +39,7 @@ class PoseidonController extends Controller
} }
Cache::put(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $server->id), time(), 3600); Cache::put(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $server->id), time(), 3600);
$serverService = new ServerService(); $serverService = new ServerService();
$users = $serverService->getAvailableUsers(json_decode($server->group_id)); $users = $serverService->getAvailableUsers($server->group_id);
$result = []; $result = [];
foreach ($users as $user) { foreach ($users as $user) {
$user->v2ray_user = [ $user->v2ray_user = [

View File

@ -41,7 +41,7 @@ class ShadowsocksTidalabController extends Controller
} }
Cache::put(CacheKey::get('SERVER_SHADOWSOCKS_LAST_CHECK_AT', $server->id), time(), 3600); Cache::put(CacheKey::get('SERVER_SHADOWSOCKS_LAST_CHECK_AT', $server->id), time(), 3600);
$serverService = new ServerService(); $serverService = new ServerService();
$users = $serverService->getAvailableUsers(json_decode($server->group_id)); $users = $serverService->getAvailableUsers($server->group_id);
$result = []; $result = [];
foreach ($users as $user) { foreach ($users as $user) {
array_push($result, [ array_push($result, [

View File

@ -41,7 +41,7 @@ class TrojanTidalabController extends Controller
} }
Cache::put(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $server->id), time(), 3600); Cache::put(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $server->id), time(), 3600);
$serverService = new ServerService(); $serverService = new ServerService();
$users = $serverService->getAvailableUsers(json_decode($server->group_id)); $users = $serverService->getAvailableUsers($server->group_id);
$result = []; $result = [];
foreach ($users as $user) { foreach ($users as $user) {
$user->trojan_user = [ $user->trojan_user = [

View File

@ -27,9 +27,8 @@ class CommController extends Controller
->where('payment', 'StripeCredit') ->where('payment', 'StripeCredit')
->first(); ->first();
if (!$payment) abort(500, 'payment is not found'); if (!$payment) abort(500, 'payment is not found');
$config = json_decode($payment->config, true);
return response([ return response([
'data' => $config['stripe_pk_live'] 'data' => $payment->config['stripe_pk_live']
]); ]);
} }
} }

View File

@ -27,8 +27,7 @@ class CouponController extends Controller
abort(500, __('This coupon has expired')); abort(500, __('This coupon has expired'));
} }
if ($coupon->limit_plan_ids) { if ($coupon->limit_plan_ids) {
$limitPlanIds = json_decode($coupon->limit_plan_ids); if (!in_array($request->input('plan_id'), $coupon->limit_plan_ids)) {
if (!in_array($request->input('plan_id'), $limitPlanIds)) {
abort(500, __('The coupon code cannot be used for this subscription')); abort(500, __('The coupon code cannot be used for this subscription'));
} }
} }

View File

@ -11,6 +11,7 @@ class Coupon extends Model
protected $guarded = ['id']; protected $guarded = ['id'];
protected $casts = [ protected $casts = [
'created_at' => 'timestamp', 'created_at' => 'timestamp',
'updated_at' => 'timestamp' 'updated_at' => 'timestamp',
'limit_plan_ids' => 'array'
]; ];
} }

View File

@ -11,6 +11,7 @@ class Order extends Model
protected $guarded = ['id']; protected $guarded = ['id'];
protected $casts = [ protected $casts = [
'created_at' => 'timestamp', 'created_at' => 'timestamp',
'updated_at' => 'timestamp' 'updated_at' => 'timestamp',
'surplus_order_ids' => 'array'
]; ];
} }

View File

@ -11,6 +11,7 @@ class Payment extends Model
protected $guarded = ['id']; protected $guarded = ['id'];
protected $casts = [ protected $casts = [
'created_at' => 'timestamp', 'created_at' => 'timestamp',
'updated_at' => 'timestamp' 'updated_at' => 'timestamp',
'config' => 'array'
]; ];
} }

View File

@ -11,6 +11,12 @@ class Server extends Model
protected $guarded = ['id']; protected $guarded = ['id'];
protected $casts = [ protected $casts = [
'created_at' => 'timestamp', 'created_at' => 'timestamp',
'updated_at' => 'timestamp' 'updated_at' => 'timestamp',
'group_id' => 'array',
'tlsSettings' => 'array',
'networkSettings' => 'array',
'dnsSettings' => 'array',
'ruleSettings' => 'array',
'tag' => 'array'
]; ];
} }

View File

@ -11,6 +11,7 @@ class ServerShadowsocks extends Model
protected $guarded = ['id']; protected $guarded = ['id'];
protected $casts = [ protected $casts = [
'created_at' => 'timestamp', 'created_at' => 'timestamp',
'updated_at' => 'timestamp' 'updated_at' => 'timestamp',
'tag' => 'array'
]; ];
} }

View File

@ -11,6 +11,7 @@ class ServerTrojan extends Model
protected $guarded = ['id']; protected $guarded = ['id'];
protected $casts = [ protected $casts = [
'created_at' => 'timestamp', 'created_at' => 'timestamp',
'updated_at' => 'timestamp' 'updated_at' => 'timestamp',
'tag' => 'array'
]; ];
} }

View File

@ -44,8 +44,7 @@ class CouponService
} }
} }
if ($this->coupon->limit_plan_ids) { if ($this->coupon->limit_plan_ids) {
$limitPlanIds = json_decode($this->coupon->limit_plan_ids); if (!in_array($order->plan_id, $this->coupon->limit_plan_ids)) {
if (!in_array($order->plan_id, $limitPlanIds)) {
return false; return false;
} }
} }

View File

@ -37,7 +37,7 @@ class OrderService
DB::beginTransaction(); DB::beginTransaction();
if ($order->surplus_order_ids) { if ($order->surplus_order_ids) {
try { try {
Order::whereIn('id', json_decode($order->surplus_order_ids))->update([ Order::whereIn('id', $order->surplus_order_ids)->update([
'status' => 4 'status' => 4
]); ]);
} catch (\Exception $e) { } catch (\Exception $e) {
@ -190,7 +190,7 @@ class OrderService
$result = $trafficUnitPrice * $notUsedTraffic; $result = $trafficUnitPrice * $notUsedTraffic;
$orderModel = Order::where('user_id', $user->id)->where('cycle', '!=', 'reset_price')->where('status', 3); $orderModel = Order::where('user_id', $user->id)->where('cycle', '!=', 'reset_price')->where('status', 3);
$order->surplus_amount = $result > 0 ? $result : 0; $order->surplus_amount = $result > 0 ? $result : 0;
$order->surplus_order_ids = json_encode(array_column($orderModel->get()->toArray(), 'id')); $order->surplus_order_ids = array_column($orderModel->get()->toArray(), 'id');
} }
private function orderIsUsed(Order $order):bool private function orderIsUsed(Order $order):bool
@ -229,7 +229,7 @@ class OrderService
return; return;
} }
$order->surplus_amount = $orderSurplusAmount > 0 ? $orderSurplusAmount : 0; $order->surplus_amount = $orderSurplusAmount > 0 ? $orderSurplusAmount : 0;
$order->surplus_order_ids = json_encode(array_column($orders->toArray(), 'id')); $order->surplus_order_ids = array_column($orders->toArray(), 'id');
} }
public function success(string $callbackNo) public function success(string $callbackNo)

View File

@ -22,7 +22,7 @@ class PaymentService
if ($uuid) $payment = Payment::where('uuid', $uuid)->first()->toArray(); if ($uuid) $payment = Payment::where('uuid', $uuid)->first()->toArray();
$this->config = []; $this->config = [];
if (isset($payment)) { if (isset($payment)) {
$this->config = json_decode($payment['config'], true); $this->config = $payment['config'];
$this->config['enable'] = $payment['enable']; $this->config['enable'] = $payment['enable'];
$this->config['id'] = $payment['id']; $this->config['id'] = $payment['id'];
$this->config['uuid'] = $payment['uuid']; $this->config['uuid'] = $payment['uuid'];

View File

@ -25,7 +25,7 @@ class ServerService
$v2ray = $model->get(); $v2ray = $model->get();
for ($i = 0; $i < count($v2ray); $i++) { for ($i = 0; $i < count($v2ray); $i++) {
$v2ray[$i]['type'] = 'v2ray'; $v2ray[$i]['type'] = 'v2ray';
$groupId = json_decode($v2ray[$i]['group_id']); $groupId = $v2ray[$i]['group_id'];
if (in_array($user->group_id, $groupId)) { if (in_array($user->group_id, $groupId)) {
if ($v2ray[$i]['parent_id']) { if ($v2ray[$i]['parent_id']) {
$v2ray[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $v2ray[$i]['parent_id'])); $v2ray[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $v2ray[$i]['parent_id']));
@ -50,7 +50,7 @@ class ServerService
$trojan = $model->get(); $trojan = $model->get();
for ($i = 0; $i < count($trojan); $i++) { for ($i = 0; $i < count($trojan); $i++) {
$trojan[$i]['type'] = 'trojan'; $trojan[$i]['type'] = 'trojan';
$groupId = json_decode($trojan[$i]['group_id']); $groupId = $trojan[$i]['group_id'];
if (in_array($user->group_id, $groupId)) { if (in_array($user->group_id, $groupId)) {
if ($trojan[$i]['parent_id']) { if ($trojan[$i]['parent_id']) {
$trojan[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $trojan[$i]['parent_id'])); $trojan[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $trojan[$i]['parent_id']));
@ -73,7 +73,7 @@ class ServerService
$shadowsocks = $model->get(); $shadowsocks = $model->get();
for ($i = 0; $i < count($shadowsocks); $i++) { for ($i = 0; $i < count($shadowsocks); $i++) {
$shadowsocks[$i]['type'] = 'shadowsocks'; $shadowsocks[$i]['type'] = 'shadowsocks';
$groupId = json_decode($shadowsocks[$i]['group_id']); $groupId = $shadowsocks[$i]['group_id'];
if (in_array($user->group_id, $groupId)) { if (in_array($user->group_id, $groupId)) {
if ($shadowsocks[$i]['parent_id']) { if ($shadowsocks[$i]['parent_id']) {
$shadowsocks[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_SHADOWSOCKS_LAST_CHECK_AT', $shadowsocks[$i]['parent_id'])); $shadowsocks[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_SHADOWSOCKS_LAST_CHECK_AT', $shadowsocks[$i]['parent_id']));
@ -159,7 +159,7 @@ class ServerService
private function setDns(Server $server, object $json) private function setDns(Server $server, object $json)
{ {
if ($server->dnsSettings) { if ($server->dnsSettings) {
$dns = json_decode($server->dnsSettings); $dns = $server->dnsSettings;
if (isset($dns->servers)) { if (isset($dns->servers)) {
array_push($dns->servers, '1.1.1.1'); array_push($dns->servers, '1.1.1.1');
array_push($dns->servers, 'localhost'); array_push($dns->servers, 'localhost');
@ -174,25 +174,25 @@ class ServerService
if ($server->networkSettings) { if ($server->networkSettings) {
switch ($server->network) { switch ($server->network) {
case 'tcp': case 'tcp':
$json->inbound->streamSettings->tcpSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->tcpSettings = $server->networkSettings;
break; break;
case 'kcp': case 'kcp':
$json->inbound->streamSettings->kcpSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->kcpSettings = $server->networkSettings;
break; break;
case 'ws': case 'ws':
$json->inbound->streamSettings->wsSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->wsSettings = $server->networkSettings;
break; break;
case 'http': case 'http':
$json->inbound->streamSettings->httpSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->httpSettings = $server->networkSettings;
break; break;
case 'domainsocket': case 'domainsocket':
$json->inbound->streamSettings->dsSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->dsSettings = $server->networkSettings;
break; break;
case 'quic': case 'quic':
$json->inbound->streamSettings->quicSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->quicSettings = $server->networkSettings;
break; break;
case 'grpc': case 'grpc':
$json->inbound->streamSettings->grpcSettings = json_decode($server->networkSettings); $json->inbound->streamSettings->grpcSettings = $server->networkSettings;
break; break;
} }
} }
@ -203,7 +203,7 @@ class ServerService
$domainRules = array_filter(explode(PHP_EOL, config('v2board.server_v2ray_domain'))); $domainRules = array_filter(explode(PHP_EOL, config('v2board.server_v2ray_domain')));
$protocolRules = array_filter(explode(PHP_EOL, config('v2board.server_v2ray_protocol'))); $protocolRules = array_filter(explode(PHP_EOL, config('v2board.server_v2ray_protocol')));
if ($server->ruleSettings) { if ($server->ruleSettings) {
$ruleSettings = json_decode($server->ruleSettings); $ruleSettings = $server->ruleSettings;
// domain // domain
if (isset($ruleSettings->domain)) { if (isset($ruleSettings->domain)) {
$ruleSettings->domain = array_filter($ruleSettings->domain); $ruleSettings->domain = array_filter($ruleSettings->domain);
@ -241,7 +241,7 @@ class ServerService
private function setTls(Server $server, object $json) private function setTls(Server $server, object $json)
{ {
if ((int)$server->tls) { if ((int)$server->tls) {
$tlsSettings = json_decode($server->tlsSettings); $tlsSettings = $server->tlsSettings;
$json->inbound->streamSettings->security = 'tls'; $json->inbound->streamSettings->security = 'tls';
$tls = (object)[ $tls = (object)[
'certificateFile' => '/root/.cert/server.crt', 'certificateFile' => '/root/.cert/server.crt',
@ -292,10 +292,6 @@ class ServerService
$server = ServerShadowsocks::orderBy('sort', 'ASC')->get(); $server = ServerShadowsocks::orderBy('sort', 'ASC')->get();
for ($i = 0; $i < count($server); $i++) { for ($i = 0; $i < count($server); $i++) {
$server[$i]['type'] = 'shadowsocks'; $server[$i]['type'] = 'shadowsocks';
if (!empty($server[$i]['tags'])) {
$server[$i]['tags'] = json_decode($server[$i]['tags']);
}
$server[$i]['group_id'] = json_decode($server[$i]['group_id']);
} }
return $server->toArray(); return $server->toArray();
} }
@ -305,19 +301,6 @@ class ServerService
$server = Server::orderBy('sort', 'ASC')->get(); $server = Server::orderBy('sort', 'ASC')->get();
for ($i = 0; $i < count($server); $i++) { for ($i = 0; $i < count($server); $i++) {
$server[$i]['type'] = 'v2ray'; $server[$i]['type'] = 'v2ray';
if (!empty($server[$i]['tags'])) {
$server[$i]['tags'] = json_decode($server[$i]['tags']);
}
if (!empty($server[$i]['dnsSettings'])) {
$server[$i]['dnsSettings'] = json_decode($server[$i]['dnsSettings']);
}
if (!empty($server[$i]['tlsSettings'])) {
$server[$i]['tlsSettings'] = json_decode($server[$i]['tlsSettings']);
}
if (!empty($server[$i]['ruleSettings'])) {
$server[$i]['ruleSettings'] = json_decode($server[$i]['ruleSettings']);
}
$server[$i]['group_id'] = json_decode($server[$i]['group_id']);
} }
return $server->toArray(); return $server->toArray();
} }
@ -327,10 +310,6 @@ class ServerService
$server = ServerTrojan::orderBy('sort', 'ASC')->get(); $server = ServerTrojan::orderBy('sort', 'ASC')->get();
for ($i = 0; $i < count($server); $i++) { for ($i = 0; $i < count($server); $i++) {
$server[$i]['type'] = 'trojan'; $server[$i]['type'] = 'trojan';
if (!empty($server[$i]['tags'])) {
$server[$i]['tags'] = json_decode($server[$i]['tags']);
}
$server[$i]['group_id'] = json_decode($server[$i]['group_id']);
} }
return $server->toArray(); return $server->toArray();
} }

File diff suppressed because one or more lines are too long