- UserService: audit 컬럼 처리 추가 (created_by, updated_by, deleted_by) - UserService: restoreUser(), forceDeleteUser() 메서드 추가 - UserController: restore(), forceDestroy() 엔드포인트 추가 - 권한 체크: 영구삭제는 슈퍼관리자만 가능 - UI: 삭제된 사용자에 복원/영구삭제 버튼 추가 - Routes: restore, forceDestroy 라우트 추가 - UserService::getUsers()에 withTrashed() 추가
67 lines
3.1 KiB
PHP
67 lines
3.1 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\Api\Admin\DepartmentController;
|
|
use App\Http\Controllers\Api\Admin\RoleController;
|
|
use App\Http\Controllers\Api\Admin\TenantController;
|
|
use App\Http\Controllers\Api\Admin\UserController;
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| API Routes
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| HTMX 요청 시 HTML 반환, 일반 요청 시 JSON 반환
|
|
|
|
|
*/
|
|
|
|
Route::middleware(['web', 'auth'])->prefix('admin')->name('api.admin.')->group(function () {
|
|
|
|
// 테넌트 관리 API
|
|
Route::prefix('tenants')->name('tenants.')->group(function () {
|
|
// 고정 경로는 먼저 정의
|
|
Route::get('/stats', [TenantController::class, 'stats'])->name('stats');
|
|
|
|
// 동적 경로는 나중에 정의
|
|
Route::get('/', [TenantController::class, 'index'])->name('index');
|
|
Route::post('/', [TenantController::class, 'store'])->name('store');
|
|
Route::get('/{id}', [TenantController::class, 'show'])->name('show');
|
|
Route::put('/{id}', [TenantController::class, 'update'])->name('update');
|
|
Route::delete('/{id}', [TenantController::class, 'destroy'])->name('destroy');
|
|
|
|
// 추가 액션
|
|
Route::post('/{id}/restore', [TenantController::class, 'restore'])->name('restore');
|
|
Route::delete('/{id}/force', [TenantController::class, 'forceDestroy'])->name('forceDestroy');
|
|
});
|
|
|
|
// 역할 관리 API
|
|
Route::prefix('roles')->name('roles.')->group(function () {
|
|
Route::get('/', [RoleController::class, 'index'])->name('index');
|
|
Route::post('/', [RoleController::class, 'store'])->name('store');
|
|
Route::get('/{id}', [RoleController::class, 'show'])->name('show');
|
|
Route::put('/{id}', [RoleController::class, 'update'])->name('update');
|
|
Route::delete('/{id}', [RoleController::class, 'destroy'])->name('destroy');
|
|
});
|
|
|
|
// 부서 관리 API
|
|
Route::prefix('departments')->name('departments.')->group(function () {
|
|
Route::get('/', [DepartmentController::class, 'index'])->name('index');
|
|
Route::post('/', [DepartmentController::class, 'store'])->name('store');
|
|
Route::get('/{id}', [DepartmentController::class, 'show'])->name('show');
|
|
Route::put('/{id}', [DepartmentController::class, 'update'])->name('update');
|
|
Route::delete('/{id}', [DepartmentController::class, 'destroy'])->name('destroy');
|
|
});
|
|
|
|
// 사용자 관리 API
|
|
Route::prefix('users')->name('users.')->group(function () {
|
|
Route::get('/', [UserController::class, 'index'])->name('index');
|
|
Route::post('/', [UserController::class, 'store'])->name('store');
|
|
Route::get('/{id}', [UserController::class, 'show'])->name('show');
|
|
Route::put('/{id}', [UserController::class, 'update'])->name('update');
|
|
Route::delete('/{id}', [UserController::class, 'destroy'])->name('destroy');
|
|
|
|
// 추가 액션
|
|
Route::post('/{id}/restore', [UserController::class, 'restore'])->name('restore');
|
|
Route::delete('/{id}/force', [UserController::class, 'forceDestroy'])->name('forceDestroy');
|
|
});
|
|
}); |