feat: 切换 schema dump 基线并增强返点结算与管理校验

This commit is contained in:
2026-06-08 17:41:41 +08:00
parent 2d32f006c5
commit 8d5d7f5b17
130 changed files with 5746 additions and 6723 deletions

View File

@@ -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();

View File

@@ -35,7 +35,7 @@ final class AdminPlayerIndexController extends Controller
if ($keyword !== '') {
$term = '%'.addcslashes($keyword, '%_\\').'%';
$q->where(static function ($sub) use ($term): void {
$q->where(static function ($sub) use ($term, $keyword): void {
$sub->where('site_player_id', 'like', $term)
->orWhere('username', 'like', $term)
->orWhere('nickname', 'like', $term);

View File

@@ -55,7 +55,7 @@ final class AdminPlayerStoreController extends Controller
if ($isNative) {
$sitePlayerId = $sitePlayerId !== ''
? $sitePlayerId
: 'native:'.Str::lower(Str::ulid());
: $this->generateNativeSitePlayerId($siteCode);
}
if ($sitePlayerId === '') {
@@ -192,4 +192,20 @@ final class AdminPlayerStoreController extends Controller
return $rootId !== null ? (int) $rootId : null;
}
private function generateNativeSitePlayerId(string $siteCode): string
{
$prefix = strtoupper(substr(preg_replace('/[^A-Za-z]/', '', $siteCode) ?: 'LP', 0, 2));
$prefix = str_pad($prefix, 2, 'P');
do {
$candidate = sprintf('%s%06d', $prefix, random_int(0, 999999));
$exists = Player::query()
->where('site_code', $siteCode)
->where('site_player_id', $candidate)
->exists();
} while ($exists);
return $candidate;
}
}