mirror of
https://github.com/cedar2025/Xboard.git
synced 2025-01-22 18:48:14 -05:00
Compare commits
2 Commits
6b436255a0
...
70998d0c08
Author | SHA1 | Date | |
---|---|---|---|
|
70998d0c08 | ||
|
ed43ffc3f5 |
@ -82,7 +82,7 @@ class UniProxyController extends Controller
|
|||||||
$baseConfig = [
|
$baseConfig = [
|
||||||
'server_port' => $serverPort,
|
'server_port' => $serverPort,
|
||||||
'network' => $protocolSettings['network'] ?? null,
|
'network' => $protocolSettings['network'] ?? null,
|
||||||
'network_settings' => $protocolSettings['network_settings'] ?? null,
|
'networkSettings' => $protocolSettings['network_settings'] ?? null,
|
||||||
];
|
];
|
||||||
|
|
||||||
$response = match ($nodeType) {
|
$response = match ($nodeType) {
|
||||||
|
@ -52,21 +52,28 @@ class StatServerJob implements ShouldQueue
|
|||||||
$u += $traffic[0];
|
$u += $traffic[0];
|
||||||
$d += $traffic[1];
|
$d += $traffic[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update or create traffic stats
|
|
||||||
DB::transaction(function () use ($u, $d, $recordAt) {
|
DB::transaction(function () use ($u, $d, $recordAt) {
|
||||||
StatServer::updateOrCreate(
|
$stat = StatServer::lockForUpdate()
|
||||||
[
|
->where('record_at', $recordAt)
|
||||||
|
->where('server_id', $this->server['id'])
|
||||||
|
->where('server_type', $this->protocol)
|
||||||
|
->where('record_type', $this->recordType)
|
||||||
|
->first();
|
||||||
|
|
||||||
|
if ($stat) {
|
||||||
|
$stat->u += $u;
|
||||||
|
$stat->d += $d;
|
||||||
|
$stat->save();
|
||||||
|
} else {
|
||||||
|
StatServer::create([
|
||||||
'record_at' => $recordAt,
|
'record_at' => $recordAt,
|
||||||
'server_id' => $this->server['id'],
|
'server_id' => $this->server['id'],
|
||||||
'server_type' => $this->protocol,
|
'server_type' => $this->protocol,
|
||||||
'record_type' => $this->recordType,
|
'record_type' => $this->recordType,
|
||||||
],
|
'u' => $u,
|
||||||
[
|
'd' => $d,
|
||||||
'u' => DB::raw("COALESCE(u, 0) + $u"),
|
]);
|
||||||
'd' => DB::raw("COALESCE(d, 0) + $d"),
|
}
|
||||||
]
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -47,19 +47,30 @@ class StatUserJob implements ShouldQueue
|
|||||||
: strtotime(date('Y-m-d'));
|
: strtotime(date('Y-m-d'));
|
||||||
|
|
||||||
foreach ($this->data as $uid => $v) {
|
foreach ($this->data as $uid => $v) {
|
||||||
StatUser::updateOrCreate(
|
DB::transaction(function () use ($uid, $v, $recordAt) {
|
||||||
[
|
$stat = StatUser::lockForUpdate()
|
||||||
'user_id' => $uid,
|
->where('user_id', $uid)
|
||||||
'server_rate' => $this->server['rate'],
|
->where('server_rate', $this->server['rate'])
|
||||||
'record_at' => $recordAt,
|
->where('record_at', $recordAt)
|
||||||
'record_type' => $this->recordType,
|
->where('record_type', $this->recordType)
|
||||||
],
|
->first();
|
||||||
[
|
if ($stat) {
|
||||||
'u' => DB::raw('COALESCE(u, 0) + ' . ($v[0] * $this->server['rate'])),
|
$stat->u += ($v[0] * $this->server['rate']);
|
||||||
'd' => DB::raw('COALESCE(d, 0) + ' . ($v[1] * $this->server['rate'])),
|
$stat->d += ($v[1] * $this->server['rate']);
|
||||||
't' => time(),
|
$stat->t = time();
|
||||||
]
|
$stat->save();
|
||||||
);
|
} else {
|
||||||
|
StatUser::create([
|
||||||
|
'user_id' => $uid,
|
||||||
|
'server_rate' => $this->server['rate'],
|
||||||
|
'record_at' => $recordAt,
|
||||||
|
'record_type' => $this->recordType,
|
||||||
|
'u' => ($v[0] * $this->server['rate']),
|
||||||
|
'd' => ($v[1] * $this->server['rate']),
|
||||||
|
't' => time(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -93,7 +93,7 @@ class General implements ProtocolInterface
|
|||||||
break;
|
break;
|
||||||
case 'grpc':
|
case 'grpc':
|
||||||
$config['type'] = 'grpc';
|
$config['type'] = 'grpc';
|
||||||
$config['service_name'] = data_get($protocol_settings, 'network_settings.serviceName');
|
$config['path'] = data_get($protocol_settings, 'network_settings.serviceName');
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
2
public/assets/admin/assets/index.js
vendored
2
public/assets/admin/assets/index.js
vendored
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue
Block a user