- 역할 목록: 테넌트/Guard 컬럼 추가, Guard 필터 드롭다운 추가 - 역할 등록/수정: Guard 선택 기능 추가 (API/Web) - 권한 선택 UI를 메뉴 기반 매트릭스로 변경 (7가지 권한 유형) - 테넌트 미선택 시 역할 등록 차단 - pagination.js 디버그 로그 제거
80 lines
2.2 KiB
PHP
80 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Services\RolePermissionService;
|
|
use App\Services\RoleService;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\View\View;
|
|
|
|
class RoleController extends Controller
|
|
{
|
|
public function __construct(
|
|
private readonly RoleService $roleService,
|
|
private readonly RolePermissionService $rolePermissionService
|
|
) {}
|
|
|
|
/**
|
|
* 역할 목록 (Blade 화면만)
|
|
*/
|
|
public function index(Request $request): View
|
|
{
|
|
return view('roles.index');
|
|
}
|
|
|
|
/**
|
|
* 역할 생성 화면
|
|
*/
|
|
public function create(): View
|
|
{
|
|
$tenantId = session('selected_tenant_id');
|
|
|
|
// 테넌트 미선택 시 생성 불가
|
|
if (! $tenantId || $tenantId === 'all') {
|
|
return view('roles.create', [
|
|
'requireTenant' => true,
|
|
'menus' => collect(),
|
|
'permissionTypes' => [],
|
|
]);
|
|
}
|
|
|
|
// 메뉴 트리 조회 (권한 매트릭스용)
|
|
$menus = $this->rolePermissionService->getMenuTree($tenantId);
|
|
|
|
// 권한 유형 목록
|
|
$permissionTypes = ['view', 'create', 'update', 'delete', 'approve', 'export', 'manage'];
|
|
|
|
return view('roles.create', compact('menus', 'permissionTypes'));
|
|
}
|
|
|
|
/**
|
|
* 역할 수정 화면
|
|
*/
|
|
public function edit(int $id): View
|
|
{
|
|
$role = $this->roleService->getRoleById($id);
|
|
|
|
if (! $role) {
|
|
abort(404, '역할을 찾을 수 없습니다.');
|
|
}
|
|
|
|
$tenantId = session('selected_tenant_id');
|
|
$effectiveTenantId = ($tenantId && $tenantId !== 'all') ? $tenantId : null;
|
|
|
|
// 메뉴 트리 조회 (권한 매트릭스용)
|
|
$menus = $this->rolePermissionService->getMenuTree($effectiveTenantId);
|
|
|
|
// 권한 유형 목록
|
|
$permissionTypes = ['view', 'create', 'update', 'delete', 'approve', 'export', 'manage'];
|
|
|
|
// 현재 역할의 권한 매트릭스 조회
|
|
$permissions = $this->rolePermissionService->getRolePermissionMatrix(
|
|
$role->id,
|
|
$effectiveTenantId,
|
|
$role->guard_name
|
|
);
|
|
|
|
return view('roles.edit', compact('role', 'menus', 'permissionTypes', 'permissions'));
|
|
}
|
|
}
|