Files
lotteryLaravel/app/Http/Controllers/Api/V1/Admin/Player/AdminPlayerDestroyController.php

77 lines
2.8 KiB
PHP

<?php
namespace App\Http\Controllers\Api\V1\Admin\Player;
use App\Models\Player;
use App\Models\TicketOrder;
use App\Lottery\ErrorCode;
use App\Support\ApiMessage;
use App\Support\ApiResponse;
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
{
public function __invoke(Request $request, Player $player): JsonResponse
{
$admin = $request->lotteryAdmin();
abort_if($admin === null, 401);
if ($denied = AdminSiteScope::denyUnlessPlayerAccessible($admin, $player)) {
return $denied;
}
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 ($hasUnpaidSettlementBills) {
return ApiMessage::errorResponse($request, 'admin.player_unpaid_settlement_blocks_delete', ErrorCode::ValidationFailed->value, null, 422);
}
$hasTickets = TicketOrder::query()
->where('player_id', $player->getKey())
->exists();
if ($hasTickets) {
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();
return ApiResponse::success(['deleted' => true]);
}
}