departmentPermissionService = $departmentPermissionService; } /** * 권한 매트릭스 조회 (부서 변경 시 호출) */ 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'); } // 메뉴 트리 조회 $menus = $this->departmentPermissionService->getMenuTree($tenantId); // 권한 매트릭스 조회 $permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName); return view('department-permissions.partials.permission-matrix', [ 'menus' => $menus, 'permissions' => $permissions, 'departmentId' => $departmentId, ]); } /** * 권한 토글 */ public function toggle(Request $request) { $departmentId = $request->input('department_id'); $menuId = $request->input('menu_id'); $permissionType = $request->input('permission_type'); $guardName = $request->input('guard_name', 'api'); $tenantId = session('selected_tenant_id'); $newValue = $this->departmentPermissionService->togglePermission( $departmentId, $menuId, $permissionType, $tenantId, $guardName ); // 전체 매트릭스 다시 로드 $menus = $this->departmentPermissionService->getMenuTree($tenantId); $permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName); return view('department-permissions.partials.permission-matrix', [ 'menus' => $menus, 'permissions' => $permissions, 'departmentId' => $departmentId, ]); } /** * 전체 허용 */ public function allowAll(Request $request) { $departmentId = $request->input('department_id'); $guardName = $request->input('guard_name', 'api'); $tenantId = session('selected_tenant_id'); $this->departmentPermissionService->allowAllPermissions($departmentId, $tenantId, $guardName); // 전체 매트릭스 다시 로드 $menus = $this->departmentPermissionService->getMenuTree($tenantId); $permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName); return view('department-permissions.partials.permission-matrix', [ 'menus' => $menus, 'permissions' => $permissions, 'departmentId' => $departmentId, ]); } /** * 전체 거부 */ public function denyAll(Request $request) { $departmentId = $request->input('department_id'); $guardName = $request->input('guard_name', 'api'); $tenantId = session('selected_tenant_id'); $this->departmentPermissionService->denyAllPermissions($departmentId, $tenantId, $guardName); // 전체 매트릭스 다시 로드 $menus = $this->departmentPermissionService->getMenuTree($tenantId); $permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName); return view('department-permissions.partials.permission-matrix', [ 'menus' => $menus, 'permissions' => $permissions, 'departmentId' => $departmentId, ]); } /** * 기본 권한으로 초기화 (view만 허용) */ public function reset(Request $request) { $departmentId = $request->input('department_id'); $guardName = $request->input('guard_name', 'api'); $tenantId = session('selected_tenant_id'); $this->departmentPermissionService->resetToDefaultPermissions($departmentId, $tenantId, $guardName); // 전체 매트릭스 다시 로드 $menus = $this->departmentPermissionService->getMenuTree($tenantId); $permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName); return view('department-permissions.partials.permission-matrix', [ 'menus' => $menus, 'permissions' => $permissions, 'departmentId' => $departmentId, ]); } }