mirror of
https://github.com/v2board/v2board.git
synced 2025-01-25 07:29:09 +08:00
update: rollback
This commit is contained in:
parent
decbae1413
commit
2a5e9ef079
@ -9,7 +9,6 @@ use Illuminate\Contracts\Queue\ShouldQueue;
|
||||
use Illuminate\Foundation\Bus\Dispatchable;
|
||||
use Illuminate\Queue\InteractsWithQueue;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class TrafficFetchJob implements ShouldQueue
|
||||
{
|
||||
@ -45,18 +44,14 @@ class TrafficFetchJob implements ShouldQueue
|
||||
*/
|
||||
public function handle()
|
||||
{
|
||||
$user = User::find($this->userId);
|
||||
$user = User::lockForUpdate()->find($this->userId);
|
||||
if (!$user) return;
|
||||
try {
|
||||
$user->update([
|
||||
't' => time(),
|
||||
'u' => DB::raw("u+{$this->u}"),
|
||||
'd' => DB::raw("d+{$this->d}")
|
||||
]);
|
||||
} catch (\Exception $e) {
|
||||
throw new \Exception('流量更新失败');
|
||||
}
|
||||
|
||||
$user->t = time();
|
||||
$user->u = $user->u + $this->u;
|
||||
$user->d = $user->d + $this->d;
|
||||
if (!$user->save()) throw new \Exception('流量更新失败');
|
||||
$mailService = new MailService();
|
||||
$mailService->remindTraffic($user->first());
|
||||
$mailService->remindTraffic($user);
|
||||
}
|
||||
}
|
||||
|
@ -13,8 +13,4 @@ class ServerLog extends Model
|
||||
'created_at' => 'timestamp',
|
||||
'updated_at' => 'timestamp'
|
||||
];
|
||||
protected $fillable = [
|
||||
'u',
|
||||
'd'
|
||||
];
|
||||
}
|
||||
|
@ -13,9 +13,4 @@ class User extends Model
|
||||
'created_at' => 'timestamp',
|
||||
'updated_at' => 'timestamp'
|
||||
];
|
||||
protected $fillable = [
|
||||
'u',
|
||||
'd',
|
||||
't'
|
||||
];
|
||||
}
|
||||
|
@ -9,7 +9,6 @@ use App\Models\Server;
|
||||
use App\Models\ServerTrojan;
|
||||
use App\Utils\CacheKey;
|
||||
use Illuminate\Support\Facades\Cache;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class ServerService
|
||||
{
|
||||
@ -269,18 +268,12 @@ class ServerService
|
||||
->where('user_id', $userId)
|
||||
->where('rate', $rate)
|
||||
->where('method', $method)
|
||||
->lockForUpdate()
|
||||
->first();
|
||||
if ($serverLog) {
|
||||
try {
|
||||
$serverLog->update([
|
||||
'u' => DB::raw("u+{$u}"),
|
||||
'd' => DB::raw("d+{$d}")
|
||||
]);
|
||||
return true;
|
||||
} catch (\Exception $e) {
|
||||
info($e);
|
||||
return false;
|
||||
}
|
||||
$serverLog->u = $serverLog->u + $u;
|
||||
$serverLog->d = $serverLog->d + $d;
|
||||
return $serverLog->save();
|
||||
} else {
|
||||
$serverLog = new ServerLog();
|
||||
$serverLog->user_id = $userId;
|
||||
|
Loading…
Reference in New Issue
Block a user