Files
dsi-commander/app/Providers/AppServiceProvider.php
jeremy bayse 0ad77de412 feat: module budgets complet avec sécurité, performance et métier
## Fonctionnalités
- Module Budgets : enveloppes, lignes budgétaires, arbitrage DSI/Direction
- Suivi de l'exécution budgétaire avec alertes visuelles (dépassement, seuil 80%)
- Blocage des commandes si budget insuffisant (store + update)
- Audit trail complet des arbitrages via HistoriqueBudget
- Page d'index budgets refaite en tableau avec filtres et tri côté client
- Page Services avec sélecteur d'icônes FontAwesome (solid + regular + brands)

## Sécurité
- BudgetPolicy centralisée (viewAny, view, create, update, addLigne, updateLigne, deleteLigne, arbitrerLigne)
- Autorisation sur tous les endpoints LigneBudget et Budget
- Protection XSS : remplacement v-html par classes dynamiques
- Validation des paramètres d'export (type, envelope)
- Validation montant_arbitre ≤ montant_propose côté serveur

## Performance
- Eager loading lignes.commandes.commune dans execution() et exportPdf()
- Calculs montant_consomme/engage en mémoire sur collections déjà chargées
- Null-safety sur montant_arbitre dans getMontantDisponibleAttribute

## Technique
- Migration historique_budgets, budgets, ligne_budgets, rôle raf
- SearchableSelect avec affichage du disponible budgétaire
- FontAwesome enregistré globalement (fas, far, fab)
- 33 tests Feature (sécurité, performance, métier)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-11 20:20:05 +02:00

54 lines
1.6 KiB
PHP

<?php
namespace App\Providers;
use App\Models\Budget;
use App\Models\Categorie;
use App\Models\Commande;
use App\Models\Fournisseur;
use App\Models\LigneBudget;
use App\Models\PieceJointe;
use App\Models\User;
use App\Policies\BudgetPolicy;
use App\Policies\CommandePolicy;
use App\Policies\FournisseurPolicy;
use App\Policies\PieceJointePolicy;
use App\Policies\UserPolicy;
use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
use Illuminate\Support\Facades\Gate;
use Illuminate\Support\Facades\Vite;
class AppServiceProvider extends ServiceProvider
{
protected $policies = [
Budget::class => BudgetPolicy::class,
LigneBudget::class => BudgetPolicy::class,
Commande::class => CommandePolicy::class,
Fournisseur::class => FournisseurPolicy::class,
PieceJointe::class => PieceJointePolicy::class,
User::class => UserPolicy::class,
];
public function register(): void
{
//
}
public function boot(): void
{
$this->registerPolicies();
Vite::prefetch(concurrency: 3);
// Les admins passent toutes les gates sauf les policies de user
Gate::before(function (User $user, string $ability) {
if ($user->hasRole('admin')) {
return true;
}
});
// Gates pour catégories et services (pas de modèle dédié à une Policy)
Gate::define('manage-categories', fn (User $user) => $user->hasAnyRole(['admin', 'responsable']));
Gate::define('manage-services', fn (User $user) => $user->hasRole('admin'));
}
}