역할/부서 권한 관리 페이지 테넌트 처리 개선

- 테넌트 미선택 시 안내 메시지 표시 (역할/부서 목록 숨김)
- 역할/부서 선택 시 해당 항목의 tenant_id로 메뉴 필터링
- 자동 선택은 특정 테넌트 선택 시에만 동작
This commit is contained in:
2025-11-26 17:40:00 +09:00
parent ee9e645290
commit f59e7051ac
4 changed files with 90 additions and 84 deletions

View File

@@ -3,6 +3,7 @@
namespace App\Http\Controllers\Api\Admin;
use App\Http\Controllers\Controller;
use App\Models\Tenants\Department;
use App\Services\DepartmentPermissionService;
use Illuminate\Http\Request;
@@ -15,6 +16,28 @@ public function __construct(DepartmentPermissionService $departmentPermissionSer
$this->departmentPermissionService = $departmentPermissionService;
}
/**
* 부서의 tenant_id 조회 (세션이 'all'이거나 미선택일 때 사용)
*/
protected function getEffectiveTenantId(Request $request, ?int $departmentId = null): ?int
{
$sessionTenantId = session('selected_tenant_id');
// 세션에 특정 테넌트가 선택되어 있으면 그것을 사용
if ($sessionTenantId && $sessionTenantId !== 'all') {
return (int) $sessionTenantId;
}
// 'all'이거나 미선택일 때는 부서의 tenant_id를 사용
if ($departmentId) {
$department = Department::find($departmentId);
return $department?->tenant_id;
}
return null;
}
/**
* 권한 매트릭스 조회 (부서 변경 시 호출)
*/
@@ -22,13 +45,15 @@ public function getMatrix(Request $request)
{
$departmentId = $request->input('department_id');
$guardName = $request->input('guard_name', 'api');
$tenantId = session('selected_tenant_id');
if (! $departmentId) {
return view('department-permissions.partials.empty-state');
}
// 메뉴 트리 조회
// 부서의 tenant_id로 메뉴 필터링
$tenantId = $this->getEffectiveTenantId($request, $departmentId);
// 메뉴 트리 조회 (부서의 테넌트 기준)
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
// 권한 매트릭스 조회
@@ -50,7 +75,7 @@ public function toggle(Request $request)
$menuId = $request->input('menu_id');
$permissionType = $request->input('permission_type');
$guardName = $request->input('guard_name', 'api');
$tenantId = session('selected_tenant_id');
$tenantId = $this->getEffectiveTenantId($request, $departmentId);
$newValue = $this->departmentPermissionService->togglePermission(
$departmentId,
@@ -78,7 +103,7 @@ public function allowAll(Request $request)
{
$departmentId = $request->input('department_id');
$guardName = $request->input('guard_name', 'api');
$tenantId = session('selected_tenant_id');
$tenantId = $this->getEffectiveTenantId($request, $departmentId);
$this->departmentPermissionService->allowAllPermissions($departmentId, $tenantId, $guardName);
@@ -100,7 +125,7 @@ public function denyAll(Request $request)
{
$departmentId = $request->input('department_id');
$guardName = $request->input('guard_name', 'api');
$tenantId = session('selected_tenant_id');
$tenantId = $this->getEffectiveTenantId($request, $departmentId);
$this->departmentPermissionService->denyAllPermissions($departmentId, $tenantId, $guardName);
@@ -122,7 +147,7 @@ public function reset(Request $request)
{
$departmentId = $request->input('department_id');
$guardName = $request->input('guard_name', 'api');
$tenantId = session('selected_tenant_id');
$tenantId = $this->getEffectiveTenantId($request, $departmentId);
$this->departmentPermissionService->resetToDefaultPermissions($departmentId, $tenantId, $guardName);