88 lines
5.1 KiB
PHP
88 lines
5.1 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\ProfileController;
|
|
use App\Http\Controllers\UserController;
|
|
use App\Http\Controllers\SettingsController;
|
|
use Illuminate\Foundation\Application;
|
|
use Illuminate\Support\Facades\Route;
|
|
use Inertia\Inertia;
|
|
use Spatie\Permission\Models\Role;
|
|
|
|
// Landing Page — redirect to login
|
|
Route::get('/', function () {
|
|
return redirect()->route('login');
|
|
});
|
|
|
|
// Global Search API
|
|
Route::get('/api/search', \App\Http\Controllers\GlobalSearchController::class)
|
|
->middleware(['auth'])
|
|
->name('api.search');
|
|
|
|
// Two-Factor Challenge (guest — user is not yet fully authenticated)
|
|
Route::get('/two-factor/challenge', [\App\Http\Controllers\TwoFactorController::class, 'challenge'])->name('two-factor.challenge');
|
|
Route::post('/two-factor/challenge', [\App\Http\Controllers\TwoFactorController::class, 'verify'])->name('two-factor.verify');
|
|
Route::post('/two-factor/resend', [\App\Http\Controllers\TwoFactorController::class, 'resendCode'])->name('two-factor.resend');
|
|
|
|
// Dashboard
|
|
Route::get('/dashboard', [\App\Http\Controllers\DashboardController::class, 'index'])
|
|
->middleware(['auth', 'verified'])
|
|
->name('dashboard');
|
|
|
|
Route::middleware(['auth', 'verified'])->group(function () {
|
|
|
|
// Profile
|
|
Route::get('/profile', [ProfileController::class, 'edit'])->name('profile.edit');
|
|
Route::patch('/profile', [ProfileController::class, 'update'])->name('profile.update');
|
|
Route::delete('/profile', [ProfileController::class, 'destroy'])->name('profile.destroy');
|
|
|
|
// Settings page
|
|
Route::get('/settings', [SettingsController::class, 'index'])->name('settings.index');
|
|
|
|
// System Settings (Super-Admin only)
|
|
Route::get('/system-settings', [\App\Http\Controllers\SystemSettingController::class, 'index'])->name('system.settings.index');
|
|
Route::patch('/system-settings', [\App\Http\Controllers\SystemSettingController::class, 'update'])->name('system.settings.update');
|
|
Route::post('/system-settings/test-email', [\App\Http\Controllers\SystemSettingController::class, 'testEmail'])->name('system.settings.test-email');
|
|
|
|
// Users CRUD
|
|
Route::get('/users', [UserController::class, 'index'])->name('users.index');
|
|
Route::post('/users', [UserController::class, 'store'])->name('users.store');
|
|
Route::get('/users/{user}', [UserController::class, 'show'])->name('users.show');
|
|
Route::patch('/users/{user}', [UserController::class, 'update'])->name('users.update');
|
|
Route::delete('/users/{user}', [UserController::class, 'destroy'])->name('users.destroy');
|
|
Route::post('/users/{id}/restore', [UserController::class, 'restore'])->name('users.restore');
|
|
Route::delete('/users/{id}/force-delete', [UserController::class, 'forceDelete'])->name('users.force-delete');
|
|
|
|
// Bulk Actions
|
|
Route::post('/users/bulk-archive', [UserController::class, 'bulkArchive'])->name('users.bulk-archive');
|
|
Route::post('/users/bulk-restore', [UserController::class, 'bulkRestore'])->name('users.bulk-restore');
|
|
Route::post('/users/bulk-force-delete', [UserController::class, 'bulkForceDelete'])->name('users.bulk-force-delete');
|
|
Route::get('/users-export', [UserController::class, 'export'])->name('users.export');
|
|
Route::post('/users-import', [UserController::class, 'import'])->name('users.import');
|
|
|
|
// Activity Logs
|
|
Route::get('/activity-logs', [\App\Http\Controllers\ActivityLogController::class, 'index'])->name('activity-logs.index');
|
|
Route::post('/activity-logs/bulk-delete', [\App\Http\Controllers\ActivityLogController::class, 'bulkDelete'])->name('activity-logs.bulk-delete');
|
|
|
|
// Notifications
|
|
Route::get('/notifications', [\App\Http\Controllers\NotificationController::class, 'index'])->name('notifications.index');
|
|
Route::post('/notifications', [\App\Http\Controllers\NotificationController::class, 'store'])->name('notifications.store');
|
|
|
|
// Internal Docs
|
|
Route::get('/documentation', fn() => Inertia::render('Docs/Index'))->name('docs.index');
|
|
|
|
// Two-Factor Authentication
|
|
Route::get('/two-factor', [\App\Http\Controllers\TwoFactorController::class, 'show'])->name('two-factor.show');
|
|
Route::post('/two-factor/enable', [\App\Http\Controllers\TwoFactorController::class, 'enable'])->name('two-factor.enable');
|
|
Route::post('/two-factor/disable', [\App\Http\Controllers\TwoFactorController::class, 'disable'])->name('two-factor.disable');
|
|
Route::post('/two-factor/recovery-codes', [\App\Http\Controllers\TwoFactorController::class, 'regenerateCodes'])->name('two-factor.recovery-codes');
|
|
Route::post('/two-factor/email', [\App\Http\Controllers\TwoFactorController::class, 'toggleEmail'])->name('two-factor.email.toggle');
|
|
|
|
// Roles & Permissions
|
|
Route::get('/roles', [\App\Http\Controllers\RoleController::class, 'index'])->name('roles.index');
|
|
Route::post('/roles', [\App\Http\Controllers\RoleController::class, 'store'])->name('roles.store');
|
|
Route::patch('/roles/{role}/permissions', [\App\Http\Controllers\RoleController::class, 'updatePermissions'])->name('roles.permissions.update');
|
|
Route::delete('/roles/{role}', [\App\Http\Controllers\RoleController::class, 'destroy'])->name('roles.destroy');
|
|
});
|
|
|
|
require __DIR__.'/auth.php';
|