- 在多个控制器中更新权限检查逻辑,确保管理员能够更灵活地管理代理和玩家。 - 在 AdminPlayerStoreController 中引入对玩家创建能力的验证,确保只有具备相应权限的管理员能够创建玩家。 - 更新请求验证逻辑,新增 credit_limit、rebate_rate 和 extra_rebate_rate 字段,以支持更细粒度的玩家管理。 - 在 AgentNodeProfileController 中添加对父代理能力授予的验证,确保子代理的权限在父代理范围内。 - 引入 AgentProfileFieldRules 以简化代理资料更新请求的规则定义,提升代码复用性。
47 lines
1.5 KiB
PHP
47 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\V1\Admin\AgentSettlement;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Middleware\RecordAdminApiAudit;
|
|
use App\Services\AgentSettlement\SettlementPaymentService;
|
|
use App\Services\AuditLogger;
|
|
use App\Support\AdminAgentSettlementScope;
|
|
use App\Support\ApiResponse;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
final class AgentSettlementBillConfirmController extends Controller
|
|
{
|
|
public function __invoke(
|
|
Request $request,
|
|
int $settlement_bill,
|
|
SettlementPaymentService $payments,
|
|
): JsonResponse {
|
|
$admin = $request->lotteryAdmin();
|
|
abort_if($admin === null, 401);
|
|
|
|
abort_if(! AdminAgentSettlementScope::billAccessible($admin, $settlement_bill), 404);
|
|
|
|
$bill = DB::table('settlement_bills')->where('id', $settlement_bill)->first();
|
|
abort_if($bill === null, 404);
|
|
|
|
$payments->confirmBill($settlement_bill);
|
|
|
|
AuditLogger::recordForAdmin(
|
|
$admin,
|
|
$request,
|
|
moduleCode: 'settlement',
|
|
actionCode: 'settlement_bill.confirm',
|
|
targetType: 'settlement_bill',
|
|
targetId: (string) $settlement_bill,
|
|
beforeJson: ['status' => (string) $bill->status],
|
|
afterJson: ['status' => 'confirmed'],
|
|
);
|
|
$request->attributes->set(RecordAdminApiAudit::ATTRIBUTE_AUDIT_RECORDED, true);
|
|
|
|
return ApiResponse::success(['bill_id' => $settlement_bill, 'status' => 'confirmed']);
|
|
}
|
|
}
|