87 lines
3.8 KiB
PHP
87 lines
3.8 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\DashboardController;
|
|
use App\Http\Controllers\DocumentController;
|
|
use App\Http\Controllers\FolderController;
|
|
use App\Http\Controllers\PermissionController;
|
|
use App\Http\Controllers\ProfileController;
|
|
use App\Http\Controllers\ProjectController;
|
|
use App\Http\Controllers\RoleController;
|
|
use App\Http\Controllers\UserController;
|
|
use App\Livewire\ProjectShow;
|
|
use Illuminate\Support\Facades\Route;
|
|
use Livewire\Volt\Volt;
|
|
|
|
Route::get('/', function () {
|
|
return view('welcome');
|
|
})->name('home');
|
|
|
|
/*Route::view('dashboard', 'dashboard')
|
|
->middleware(['auth', 'verified'])
|
|
->name('dashboard');
|
|
|
|
Route::middleware(['auth'])->group(function () {
|
|
Route::redirect('settings', 'settings/profile');
|
|
|
|
Volt::route('settings/profile', 'settings.profile')->name('settings.profile');
|
|
Volt::route('settings/password', 'settings.password')->name('settings.password');
|
|
Volt::route('settings/appearance', 'settings.appearance')->name('settings.appearance');
|
|
});*/
|
|
|
|
require __DIR__.'/auth.php';
|
|
|
|
// Rutas autenticadas
|
|
Route::middleware(['auth', 'verified'])->group(function () {
|
|
// Dashboard
|
|
Route::get('/dashboard', [DashboardController::class, 'index'])->name('dashboard');
|
|
|
|
// Proyectos
|
|
Route::resource('projects', ProjectController::class);
|
|
Route::get('/projects/{project}', ProjectController::class)->name('projects.show');
|
|
Route::get('/projects/{project}', ProjectController::class)->name('projects.show')->middleware('can:view,project'); // Opcional: política de acceso
|
|
Route::get('/projects/{project}', ProjectShow::class)->name('projects.show');
|
|
|
|
|
|
// Documentos
|
|
Route::resource('documents', DocumentController::class);
|
|
Route::post('/documents/{document}/approve', [DocumentController::class, 'approve'])->name('documents.approve');
|
|
Route::post('/documents/{document}/comment', [DocumentController::class, 'addComment'])->name('documents.comment');
|
|
|
|
// Carpetas
|
|
Route::prefix('folders')->group(function () {
|
|
Route::put('/{folder}/move', [FolderController::class, 'move']);
|
|
Route::post('/', [FolderController::class, 'store']);
|
|
Route::put('/{folder}', [FolderController::class, 'update']);
|
|
Route::delete('/{folder}', [FolderController::class, 'destroy']);
|
|
});
|
|
|
|
// Gestión de Usuarios
|
|
Route::resource('users', UserController::class)->except('show');
|
|
Route::put('/users/{user}/password', [UserController::class, 'updatePassword'])->name('users.password.update');
|
|
|
|
// Permisos y Roles
|
|
// Rutas para gestión de roles
|
|
Route::prefix('roles')->middleware(['auth', 'can:view roles'])->group(function () {
|
|
Route::get('/', [RoleController::class, 'index']);
|
|
Route::post('/', [RoleController::class, 'store'])->middleware('can:create roles');
|
|
Route::resource('roles', \App\Http\Controllers\RoleController::class)->except(['show'])->middleware(['auth', 'verified']);
|
|
});
|
|
|
|
// Perfil de usuario
|
|
Route::get('/profile', [ProfileController::class, 'edit'])->name('profile.edit');
|
|
Route::patch('/profile', [ProfileController::class, 'update'])->name('profile.update');
|
|
Route::get('/profile', [ProfileController::class, 'show'])->name('profile.show');
|
|
|
|
// Ruta para el perfil de usuario
|
|
Route::redirect('settings', 'settings/profile');
|
|
Volt::route('settings/profile', 'settings.profile')->name('settings.profile');
|
|
Volt::route('settings/password', 'settings.password')->name('settings.password');
|
|
Volt::route('settings/appearance', 'settings.appearance')->name('settings.appearance');
|
|
});
|
|
|
|
// API (para integraciones futuras)
|
|
Route::prefix('api')->middleware('auth:sanctum')->group(function () {
|
|
Route::get('/projects', [ProjectController::class, 'apiIndex']);
|
|
Route::post('/documents/upload', [DocumentController::class, 'apiStore']);
|
|
});
|