- 在多个控制器中更新权限检查逻辑,确保管理员能够更灵活地管理代理和玩家。 - 在 AdminPlayerStoreController 中引入对玩家创建能力的验证,确保只有具备相应权限的管理员能够创建玩家。 - 更新请求验证逻辑,新增 credit_limit、rebate_rate 和 extra_rebate_rate 字段,以支持更细粒度的玩家管理。 - 在 AgentNodeProfileController 中添加对父代理能力授予的验证,确保子代理的权限在父代理范围内。 - 引入 AgentProfileFieldRules 以简化代理资料更新请求的规则定义,提升代码复用性。
51 lines
1.5 KiB
PHP
51 lines
1.5 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 Illuminate\Database\Eloquent\Builder;
|
|
|
|
/** 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;
|
|
}
|
|
|
|
$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);
|
|
}
|
|
|
|
$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);
|
|
}
|
|
|
|
$player->wallets()->delete();
|
|
$player->delete();
|
|
|
|
return ApiResponse::success(['deleted' => true]);
|
|
}
|
|
}
|