feat: 增强代理和玩家管理功能
- 在多个控制器中更新权限检查逻辑,确保管理员能够更灵活地管理代理和玩家。 - 在 AdminPlayerStoreController 中引入对玩家创建能力的验证,确保只有具备相应权限的管理员能够创建玩家。 - 更新请求验证逻辑,新增 credit_limit、rebate_rate 和 extra_rebate_rate 字段,以支持更细粒度的玩家管理。 - 在 AgentNodeProfileController 中添加对父代理能力授予的验证,确保子代理的权限在父代理范围内。 - 引入 AgentProfileFieldRules 以简化代理资料更新请求的规则定义,提升代码复用性。
This commit is contained in:
69
app/Support/AdminUserSiteBindingPresenter.php
Normal file
69
app/Support/AdminUserSiteBindingPresenter.php
Normal file
@@ -0,0 +1,69 @@
|
||||
<?php
|
||||
|
||||
namespace App\Support;
|
||||
|
||||
use App\Models\AdminUser;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
/** 平台账号在各站点上的角色绑定(API 展示用)。 */
|
||||
final class AdminUserSiteBindingPresenter
|
||||
{
|
||||
/**
|
||||
* @return list<array{site_id: int, site_code: string, site_name: string, role_slugs: list<string>}>
|
||||
*/
|
||||
public static function bindingsFor(AdminUser $user): array
|
||||
{
|
||||
if ($user->hasPrimaryAgentBinding()) {
|
||||
return [];
|
||||
}
|
||||
|
||||
$rows = DB::table('admin_user_site_roles as usr')
|
||||
->join('admin_sites as s', 's.id', '=', 'usr.site_id')
|
||||
->join('admin_roles as r', 'r.id', '=', 'usr.role_id')
|
||||
->where('usr.admin_user_id', $user->id)
|
||||
->orderBy('s.code')
|
||||
->orderBy('r.slug')
|
||||
->get(['usr.site_id', 's.code as site_code', 's.name as site_name', 'r.slug as role_slug']);
|
||||
|
||||
/** @var array<int, array{site_id: int, site_code: string, site_name: string, role_slugs: list<string>}> $bySite */
|
||||
$bySite = [];
|
||||
foreach ($rows as $row) {
|
||||
$siteId = (int) $row->site_id;
|
||||
if (! isset($bySite[$siteId])) {
|
||||
$bySite[$siteId] = [
|
||||
'site_id' => $siteId,
|
||||
'site_code' => (string) $row->site_code,
|
||||
'site_name' => (string) $row->site_name,
|
||||
'role_slugs' => [],
|
||||
];
|
||||
}
|
||||
$slug = (string) $row->role_slug;
|
||||
if ($slug !== '' && ! in_array($slug, $bySite[$siteId]['role_slugs'], true)) {
|
||||
$bySite[$siteId]['role_slugs'][] = $slug;
|
||||
}
|
||||
}
|
||||
|
||||
foreach ($bySite as &$binding) {
|
||||
sort($binding['role_slugs']);
|
||||
}
|
||||
unset($binding);
|
||||
|
||||
return array_values($bySite);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return list<array{id: int, code: string, name: string}>
|
||||
*/
|
||||
public static function accessibleSitesFor(AdminUser $admin): array
|
||||
{
|
||||
return AdminIntegrationSiteAccess::queryFor($admin)
|
||||
->get(['id', 'code', 'name'])
|
||||
->map(static fn ($site): array => [
|
||||
'id' => (int) $site->id,
|
||||
'code' => (string) $site->code,
|
||||
'name' => (string) $site->name,
|
||||
])
|
||||
->values()
|
||||
->all();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user