<?php namespace App\Http\Requests; use Illuminate\Foundation\Http\FormRequest; use Illuminate\Http\Request; use Illuminate\Support\Facades\Gate; use Illuminate\Validation\Rule; use App\Models\User; class UserRequest extends FormRequest { public function authorize() { return Gate::allows( 'admin'); } public function rules(Request $request) { if (! $request->isMethod('post')) return []; $o = $this->route('o'); return [ 'email' => 'required|email|unique:users,email,'.($o->exists ? $o->id : 0), 'name' => 'required|min:3', 'pgp_pubkey' => [ 'nullable', 'min:64', //function ($attribute,$value,$fail) { return $fail('Not this time'); } ], 'alias' => 'nullable|min:1', 'active' => 'required|boolean', 'admin' => 'required|boolean', 'system_id' => [ 'nullable', Rule::in($o->systems->pluck('id')), ], ]; } }