Files
mesreleves-php/app/Http/Requests/StoreReleveRequest.php
T
yann64 5feceb0882 Fix RelevePolicy : harmoniser les signatures avec les appels du Gate
Le Gate Laravel se comporte différemment selon que le 1er argument est
une classe string ou une instance :
- [Releve::class, $source] → Gate passe $source directement (vue + contrôleurs)
- [app(Releve::class), $source] → Gate injecte l'instance + $source (ancien StoreReleveRequest)

Correction : revenir aux signatures originales (User, Source) et remplacer
app(Releve::class) par Releve::class dans StoreReleveRequest pour uniformiser.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-06-05 19:22:55 +02:00

57 lines
1.7 KiB
PHP

<?php
namespace App\Http\Requests;
use App\Enums\CalendarType;
use App\Enums\FieldType;
use App\Models\Source;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Validation\Rules\Enum;
class StoreReleveRequest extends FormRequest
{
public function authorize(): bool
{
$source = $this->route('source');
return $this->user()->can('create', [\App\Models\Releve::class, $source]);
}
public function rules(): array
{
/** @var Source $source */
$source = $this->route('source');
$source->loadMissing('sourceType.fields');
$rules = [];
foreach ($source->sourceType->fields as $field) {
$base = "data.{$field->name}";
switch ($field->type) {
case FieldType::Date:
$rules["{$base}.valeur"] = [$field->required ? 'required' : 'nullable', 'string', 'max:50'];
$rules["{$base}.calendrier"] = ['required', new Enum(CalendarType::class)];
break;
case FieldType::Boolean:
$rules[$base] = ['nullable', 'boolean'];
break;
case FieldType::Number:
$rules[$base] = [$field->required ? 'required' : 'nullable', 'numeric'];
break;
case FieldType::Select:
$options = $field->options ?? [];
$rules[$base] = [$field->required ? 'required' : 'nullable', 'string', 'in:' . implode(',', $options)];
break;
default: // text, textarea
$rules[$base] = [$field->required ? 'required' : 'nullable', 'string', 'max:2000'];
}
}
return $rules;
}
}