Initial commit with contrats and domaines modules
This commit is contained in:
59
routes/auth.php
Normal file
59
routes/auth.php
Normal file
@@ -0,0 +1,59 @@
|
||||
<?php
|
||||
|
||||
use App\Http\Controllers\Auth\AuthenticatedSessionController;
|
||||
use App\Http\Controllers\Auth\ConfirmablePasswordController;
|
||||
use App\Http\Controllers\Auth\EmailVerificationNotificationController;
|
||||
use App\Http\Controllers\Auth\EmailVerificationPromptController;
|
||||
use App\Http\Controllers\Auth\NewPasswordController;
|
||||
use App\Http\Controllers\Auth\PasswordController;
|
||||
use App\Http\Controllers\Auth\PasswordResetLinkController;
|
||||
use App\Http\Controllers\Auth\RegisteredUserController;
|
||||
use App\Http\Controllers\Auth\VerifyEmailController;
|
||||
use Illuminate\Support\Facades\Route;
|
||||
|
||||
Route::middleware('guest')->group(function () {
|
||||
Route::get('register', [RegisteredUserController::class, 'create'])
|
||||
->name('register');
|
||||
|
||||
Route::post('register', [RegisteredUserController::class, 'store']);
|
||||
|
||||
Route::get('login', [AuthenticatedSessionController::class, 'create'])
|
||||
->name('login');
|
||||
|
||||
Route::post('login', [AuthenticatedSessionController::class, 'store']);
|
||||
|
||||
Route::get('forgot-password', [PasswordResetLinkController::class, 'create'])
|
||||
->name('password.request');
|
||||
|
||||
Route::post('forgot-password', [PasswordResetLinkController::class, 'store'])
|
||||
->name('password.email');
|
||||
|
||||
Route::get('reset-password/{token}', [NewPasswordController::class, 'create'])
|
||||
->name('password.reset');
|
||||
|
||||
Route::post('reset-password', [NewPasswordController::class, 'store'])
|
||||
->name('password.store');
|
||||
});
|
||||
|
||||
Route::middleware('auth')->group(function () {
|
||||
Route::get('verify-email', EmailVerificationPromptController::class)
|
||||
->name('verification.notice');
|
||||
|
||||
Route::get('verify-email/{id}/{hash}', VerifyEmailController::class)
|
||||
->middleware(['signed', 'throttle:6,1'])
|
||||
->name('verification.verify');
|
||||
|
||||
Route::post('email/verification-notification', [EmailVerificationNotificationController::class, 'store'])
|
||||
->middleware('throttle:6,1')
|
||||
->name('verification.send');
|
||||
|
||||
Route::get('confirm-password', [ConfirmablePasswordController::class, 'show'])
|
||||
->name('password.confirm');
|
||||
|
||||
Route::post('confirm-password', [ConfirmablePasswordController::class, 'store']);
|
||||
|
||||
Route::put('password', [PasswordController::class, 'update'])->name('password.update');
|
||||
|
||||
Route::post('logout', [AuthenticatedSessionController::class, 'destroy'])
|
||||
->name('logout');
|
||||
});
|
||||
8
routes/console.php
Normal file
8
routes/console.php
Normal file
@@ -0,0 +1,8 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Foundation\Inspiring;
|
||||
use Illuminate\Support\Facades\Artisan;
|
||||
|
||||
Artisan::command('inspire', function () {
|
||||
$this->comment(Inspiring::quote());
|
||||
})->purpose('Display an inspiring quote');
|
||||
81
routes/web.php
Normal file
81
routes/web.php
Normal file
@@ -0,0 +1,81 @@
|
||||
<?php
|
||||
|
||||
use App\Http\Controllers\ArticleController;
|
||||
use App\Http\Controllers\CategorieController;
|
||||
use App\Http\Controllers\CommandeController;
|
||||
use App\Http\Controllers\ContratController;
|
||||
use App\Http\Controllers\DomaineController;
|
||||
use App\Http\Controllers\DashboardController;
|
||||
use App\Http\Controllers\FournisseurController;
|
||||
use App\Http\Controllers\PieceJointeController;
|
||||
use App\Http\Controllers\ProfileController;
|
||||
use App\Http\Controllers\ServiceController;
|
||||
use App\Http\Controllers\UserController;
|
||||
use Illuminate\Support\Facades\Route;
|
||||
|
||||
Route::get('/', fn () => redirect()->route('dashboard'));
|
||||
|
||||
Route::middleware(['auth', 'verified'])->group(function () {
|
||||
|
||||
Route::get('/dashboard', [DashboardController::class, 'index'])->name('dashboard');
|
||||
|
||||
// Commandes
|
||||
Route::resource('commandes', CommandeController::class);
|
||||
Route::patch('/commandes/{commande}/transition', [CommandeController::class, 'transition'])
|
||||
->name('commandes.transition');
|
||||
Route::get('/commandes/{commande}/pdf', [CommandeController::class, 'exportPdf'])
|
||||
->name('commandes.pdf');
|
||||
|
||||
// Contrats
|
||||
Route::resource('contrats', ContratController::class);
|
||||
|
||||
// Domaines
|
||||
Route::resource('domaines', DomaineController::class)->except(['show']);
|
||||
Route::post('/domaines/{domaine}/sync-whois', [DomaineController::class, 'syncWhois'])
|
||||
->name('domaines.sync-whois');
|
||||
|
||||
// Pièces jointes
|
||||
Route::post('/commandes/{commande}/pieces-jointes', [PieceJointeController::class, 'store'])
|
||||
->name('pieces-jointes.store');
|
||||
Route::post('/contrats/{contrat}/pieces-jointes', [PieceJointeController::class, 'storeContrat'])
|
||||
->name('pieces-jointes.contrat.store');
|
||||
Route::get('/pieces-jointes/{pieceJointe}/download', [PieceJointeController::class, 'download'])
|
||||
->name('pieces-jointes.download');
|
||||
Route::delete('/pieces-jointes/{pieceJointe}', [PieceJointeController::class, 'destroy'])
|
||||
->name('pieces-jointes.destroy');
|
||||
|
||||
// Fournisseurs
|
||||
Route::resource('fournisseurs', FournisseurController::class);
|
||||
Route::patch('/fournisseurs/{fournisseur}/toggle-active', [FournisseurController::class, 'toggleActive'])
|
||||
->name('fournisseurs.toggle-active');
|
||||
|
||||
// Catégories (pas de create/show/edit pages séparées — géré via modal dans Index)
|
||||
Route::post('/categories', [CategorieController::class, 'store'])->name('categories.store');
|
||||
Route::put('/categories/{categorie}', [CategorieController::class, 'update'])->name('categories.update');
|
||||
Route::delete('/categories/{categorie}', [CategorieController::class, 'destroy'])->name('categories.destroy');
|
||||
Route::get('/categories', [CategorieController::class, 'index'])->name('categories.index');
|
||||
|
||||
// Articles
|
||||
Route::resource('articles', ArticleController::class)->except(['show']);
|
||||
|
||||
// Profil
|
||||
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');
|
||||
|
||||
// Administration (admin uniquement)
|
||||
Route::middleware('role:admin')->group(function () {
|
||||
Route::get('/services', [ServiceController::class, 'index'])->name('services.index');
|
||||
Route::post('/services', [ServiceController::class, 'store'])->name('services.store');
|
||||
Route::put('/services/{service}', [ServiceController::class, 'update'])->name('services.update');
|
||||
Route::delete('/services/{service}', [ServiceController::class, 'destroy'])->name('services.destroy');
|
||||
|
||||
Route::get('/users', [UserController::class, 'index'])->name('users.index');
|
||||
Route::get('/users/{user}/edit', [UserController::class, 'edit'])->name('users.edit');
|
||||
Route::put('/users/{user}', [UserController::class, 'update'])->name('users.update');
|
||||
Route::patch('/users/{user}/toggle-active', [UserController::class, 'toggleActive'])
|
||||
->name('users.toggle-active');
|
||||
});
|
||||
});
|
||||
|
||||
require __DIR__ . '/auth.php';
|
||||
Reference in New Issue
Block a user