- 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 부서 권한 관리 메뉴 활성화
94 lines
3.9 KiB
PHP
94 lines
3.9 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\Auth\LoginController;
|
|
use App\Http\Controllers\DepartmentController;
|
|
use App\Http\Controllers\MenuController;
|
|
use App\Http\Controllers\PermissionController;
|
|
use App\Http\Controllers\RoleController;
|
|
use App\Http\Controllers\RolePermissionController;
|
|
use App\Http\Controllers\TenantController;
|
|
use App\Http\Controllers\UserController;
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Guest Routes (인증 불필요)
|
|
|--------------------------------------------------------------------------
|
|
*/
|
|
|
|
Route::middleware('guest')->group(function () {
|
|
Route::get('/login', [LoginController::class, 'showLoginForm'])->name('login');
|
|
Route::post('/login', [LoginController::class, 'login']);
|
|
});
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Authenticated Routes (인증 필요)
|
|
|--------------------------------------------------------------------------
|
|
*/
|
|
|
|
Route::middleware('auth')->group(function () {
|
|
Route::post('/logout', [LoginController::class, 'logout'])->name('logout');
|
|
|
|
// 테넌트 전환
|
|
Route::post('/tenant/switch', [TenantController::class, 'switch'])->name('tenant.switch');
|
|
|
|
// 테넌트 관리 (Blade 화면만)
|
|
Route::prefix('tenants')->name('tenants.')->group(function () {
|
|
Route::get('/', [TenantController::class, 'index'])->name('index');
|
|
Route::get('/create', [TenantController::class, 'create'])->name('create');
|
|
Route::get('/{id}/edit', [TenantController::class, 'edit'])->name('edit');
|
|
});
|
|
|
|
// 역할 관리 (Blade 화면만)
|
|
Route::prefix('roles')->name('roles.')->group(function () {
|
|
Route::get('/', [RoleController::class, 'index'])->name('index');
|
|
Route::get('/create', [RoleController::class, 'create'])->name('create');
|
|
Route::get('/{id}/edit', [RoleController::class, 'edit'])->name('edit');
|
|
});
|
|
|
|
// 부서 관리 (Blade 화면만)
|
|
Route::prefix('departments')->name('departments.')->group(function () {
|
|
Route::get('/', [DepartmentController::class, 'index'])->name('index');
|
|
Route::get('/create', [DepartmentController::class, 'create'])->name('create');
|
|
Route::get('/{id}/edit', [DepartmentController::class, 'edit'])->name('edit');
|
|
});
|
|
|
|
// 사용자 관리 (Blade 화면만)
|
|
Route::prefix('users')->name('users.')->group(function () {
|
|
Route::get('/', [UserController::class, 'index'])->name('index');
|
|
Route::get('/create', [UserController::class, 'create'])->name('create');
|
|
Route::get('/{id}/edit', [UserController::class, 'edit'])->name('edit');
|
|
});
|
|
|
|
// 메뉴 관리 (Blade 화면만)
|
|
Route::prefix('menus')->name('menus.')->group(function () {
|
|
Route::get('/', [MenuController::class, 'index'])->name('index');
|
|
Route::get('/create', [MenuController::class, 'create'])->name('create');
|
|
Route::get('/{id}/edit', [MenuController::class, 'edit'])->name('edit');
|
|
});
|
|
|
|
// 권한 관리 (Blade 화면만)
|
|
Route::prefix('permissions')->name('permissions.')->group(function () {
|
|
Route::get('/', [PermissionController::class, 'index'])->name('index');
|
|
Route::get('/create', [PermissionController::class, 'create'])->name('create');
|
|
Route::get('/{id}/edit', [PermissionController::class, 'edit'])->name('edit');
|
|
});
|
|
|
|
// 역할 권한 관리 (Blade 화면만)
|
|
Route::get('/role-permissions', [RolePermissionController::class, 'index'])->name('role-permissions.index');
|
|
|
|
// 부서 권한 관리 (Blade 화면만)
|
|
Route::get('/department-permissions', [\App\Http\Controllers\DepartmentPermissionController::class, 'index'])->name('department-permissions.index');
|
|
|
|
// 대시보드
|
|
Route::get('/dashboard', function () {
|
|
return view('dashboard.index');
|
|
})->name('dashboard');
|
|
|
|
// 루트 리다이렉트
|
|
Route::get('/', function () {
|
|
return redirect()->route('dashboard');
|
|
});
|
|
});
|