feat: 부서 권한 관리 기능 구현
- DepartmentPermissionService 생성 (역할 권한 관리 패턴 적용) - 부서별 메뉴 권한 매트릭스 관리 - 하위 부서 권한 자동 전파 기능 - 전체 허용/거부/초기화 기능 - HTMX 기반 실시간 권한 토글 - Department 모델의 HasRoles trait 활용 - model_has_permissions 테이블 사용 주요 파일: - app/Services/DepartmentPermissionService.php - app/Http/Controllers/DepartmentPermissionController.php - app/Http/Controllers/Api/Admin/DepartmentPermissionController.php - resources/views/department-permissions/index.blade.php - resources/views/department-permissions/partials/*.blade.php - routes/web.php, routes/api.php 라우트 추가 - sidebar 부서 권한 관리 메뉴 활성화
This commit is contained in:
@@ -0,0 +1,112 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\Admin;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\DepartmentPermissionService;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class DepartmentPermissionController extends Controller
|
||||
{
|
||||
protected DepartmentPermissionService $departmentPermissionService;
|
||||
|
||||
public function __construct(DepartmentPermissionService $departmentPermissionService)
|
||||
{
|
||||
$this->departmentPermissionService = $departmentPermissionService;
|
||||
}
|
||||
|
||||
/**
|
||||
* 권한 매트릭스 조회 (부서 변경 시 호출)
|
||||
*/
|
||||
public function getMatrix(Request $request)
|
||||
{
|
||||
$departmentId = $request->input('department_id');
|
||||
$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);
|
||||
|
||||
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');
|
||||
$tenantId = session('selected_tenant_id');
|
||||
|
||||
$newValue = $this->departmentPermissionService->togglePermission(
|
||||
$departmentId,
|
||||
$menuId,
|
||||
$permissionType,
|
||||
$tenantId
|
||||
);
|
||||
|
||||
// 전체 매트릭스 다시 로드
|
||||
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
|
||||
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId);
|
||||
|
||||
return view('department-permissions.partials.permission-matrix', [
|
||||
'menus' => $menus,
|
||||
'permissions' => $permissions,
|
||||
'departmentId' => $departmentId,
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 전체 허용
|
||||
*/
|
||||
public function allowAll(Request $request)
|
||||
{
|
||||
$departmentId = $request->input('department_id');
|
||||
$tenantId = session('selected_tenant_id');
|
||||
|
||||
$this->departmentPermissionService->allowAllPermissions($departmentId, $tenantId);
|
||||
|
||||
// 전체 매트릭스 다시 로드
|
||||
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
|
||||
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId);
|
||||
|
||||
return view('department-permissions.partials.permission-matrix', [
|
||||
'menus' => $menus,
|
||||
'permissions' => $permissions,
|
||||
'departmentId' => $departmentId,
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 전체 거부
|
||||
*/
|
||||
public function denyAll(Request $request)
|
||||
{
|
||||
$departmentId = $request->input('department_id');
|
||||
$tenantId = session('selected_tenant_id');
|
||||
|
||||
$this->departmentPermissionService->denyAllPermissions($departmentId, $tenantId);
|
||||
|
||||
// 전체 매트릭스 다시 로드
|
||||
$menus = $this->departmentPermissionService->getMenuTree($tenantId);
|
||||
$permissions = $this->departmentPermissionService->getDepartmentPermissionMatrix($departmentId, $tenantId);
|
||||
|
||||
return view('department-permissions.partials.permission-matrix', [
|
||||
'menus' => $menus,
|
||||
'permissions' => $permissions,
|
||||
'departmentId' => $departmentId,
|
||||
]);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user