feat: 切换 schema dump 基线并增强返点结算与管理校验
This commit is contained in:
@@ -11,7 +11,9 @@ use Illuminate\Http\Request;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Support\AdminSiteScope;
|
||||
use App\Support\PlayerFundingMode;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
/** DELETE /api/v1/admin/players/{player} */
|
||||
final class AdminPlayerDestroyController extends Controller
|
||||
@@ -25,13 +27,36 @@ final class AdminPlayerDestroyController extends Controller
|
||||
return $denied;
|
||||
}
|
||||
|
||||
$hasWallets = Player::query()
|
||||
->whereKey($player->getKey())
|
||||
->whereHas('wallets', static fn (Builder $q) => $q->where('balance', '!=', 0))
|
||||
if (PlayerFundingMode::usesCredit($player)) {
|
||||
$creditRow = DB::table('player_credit_accounts')
|
||||
->where('player_id', $player->getKey())
|
||||
->first();
|
||||
|
||||
$usedCredit = (int) ($creditRow->used_credit ?? 0);
|
||||
$frozenCredit = (int) ($creditRow->frozen_credit ?? 0);
|
||||
if ($usedCredit !== 0 || $frozenCredit !== 0) {
|
||||
return ApiMessage::errorResponse($request, 'admin.player_credit_in_use_blocks_delete', ErrorCode::ValidationFailed->value, null, 422);
|
||||
}
|
||||
} else {
|
||||
$hasWallets = Player::query()
|
||||
->whereKey($player->getKey())
|
||||
->whereHas('wallets', static fn (Builder $q) => $q->where('balance', '!=', 0))
|
||||
->exists();
|
||||
|
||||
if ($hasWallets) {
|
||||
return ApiMessage::errorResponse($request, 'admin.player_wallet_balance_blocks_delete', ErrorCode::ValidationFailed->value, null, 422);
|
||||
}
|
||||
}
|
||||
|
||||
$hasUnpaidSettlementBills = DB::table('settlement_bills')
|
||||
->where('owner_type', 'player')
|
||||
->where('owner_id', $player->getKey())
|
||||
->whereIn('status', ['confirmed', 'partial_paid', 'overdue'])
|
||||
->where('unpaid_amount', '>', 0)
|
||||
->exists();
|
||||
|
||||
if ($hasWallets) {
|
||||
return ApiMessage::errorResponse($request, 'admin.player_wallet_balance_blocks_delete', ErrorCode::ValidationFailed->value, null, 422);
|
||||
if ($hasUnpaidSettlementBills) {
|
||||
return ApiMessage::errorResponse($request, 'admin.player_unpaid_settlement_blocks_delete', ErrorCode::ValidationFailed->value, null, 422);
|
||||
}
|
||||
|
||||
$hasTickets = TicketOrder::query()
|
||||
@@ -42,6 +67,7 @@ final class AdminPlayerDestroyController extends Controller
|
||||
return ApiMessage::errorResponse($request, 'admin.player_has_tickets_blocks_delete', ErrorCode::ValidationFailed->value, null, 422);
|
||||
}
|
||||
|
||||
DB::table('player_credit_accounts')->where('player_id', $player->getKey())->delete();
|
||||
$player->wallets()->delete();
|
||||
$player->delete();
|
||||
|
||||
|
||||
Reference in New Issue
Block a user