feat: 권한 관리 시스템에 Guard 선택 기능 추가

- 부서 권한 아키텍처 재설계 (Role → Department 직접 할당)
- Guard 선택 기능 구현 (API/Web 분리)
- 초기화(Reset) 기능 추가 (view 권한만 허용)
- UI 개선 (Guard 선택기 + 구분선)

부서 권한 관리:
- Department 모델에 HasPermissions trait 추가
- DepartmentPermissionService 완전 재작성 (직접 할당 패턴)
- model_has_permissions 테이블 직접 사용
- guard_name 파라미터 모든 메서드에 추가

역할 권한 관리:
- RolePermissionService에 guard_name 파라미터 추가
- RolePermissionController에 guard_name 처리 구현
- Guard별 독립적인 권한 매트릭스 관리

UI 개선:
- Guard 선택 드롭다운 (Web/API) 추가
- 모든 HTMX 요청에 guard_name 포함
- Guard 변경 시 자동 새로고침 기능
- 시각적 구분선으로 UI 가독성 향상
This commit is contained in:
2025-11-25 20:53:53 +09:00
parent fec284d872
commit 69b04ae041
11 changed files with 517 additions and 73 deletions

View File

@@ -21,6 +21,7 @@ public function __construct(DepartmentPermissionService $departmentPermissionSer
public function getMatrix(Request $request)
{
$departmentId = $request->input('department_id');
$guardName = $request->input('guard_name', 'api');
$tenantId = session('selected_tenant_id');
if (! $departmentId) {
@@ -31,7 +32,7 @@ public function getMatrix(Request $request)
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
// 권한 매트릭스 조회
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId);
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName);
return view('department-permissions.partials.permission-matrix', [
'menus' => $menus,
@@ -48,18 +49,20 @@ 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
$tenantId,
$guardName
);
// 전체 매트릭스 다시 로드
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId);
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName);
return view('department-permissions.partials.permission-matrix', [
'menus' => $menus,
@@ -74,13 +77,14 @@ public function toggle(Request $request)
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);
$this->departmentPermissionService->allowAllPermissions($departmentId, $tenantId, $guardName);
// 전체 매트릭스 다시 로드
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId);
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId, $guardName);
return view('department-permissions.partials.permission-matrix', [
'menus' => $menus,
@@ -95,13 +99,36 @@ public function allowAll(Request $request)
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);
$this->departmentPermissionService->denyAllPermissions($departmentId, $tenantId, $guardName);
// 전체 매트릭스 다시 로드
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $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,