. */ declare(strict_types=1); namespace FireflyIII\Api\V1\Requests; use FireflyIII\User; /** * Class UserRequest */ class UserRequest extends Request { /** * @return bool */ public function authorize(): bool { // Only allow authenticated users if (!auth()->check()) { return false; // @codeCoverageIgnore } /** @var User $user */ $user = auth()->user(); if (!$user->hasRole('owner')) { return false; // @codeCoverageIgnore } return true; } /** * @return array */ public function getAll(): array { $data = [ 'email' => $this->string('email'), 'blocked' => $this->boolean('blocked'), 'blocked_code' => $this->string('blocked_code'), ]; return $data; } /** * @return array */ public function rules(): array { $rules = [ 'email' => 'required|email|unique:users,email,', 'blocked' => 'required|boolean', 'blocked_code' => 'in:email_changed', ]; switch ($this->method()) { default: break; case 'PUT': case 'PATCH': $user = $this->route()->parameter('user'); $rules['email'] = 'required|email|unique:users,email,' . $user->id; break; } return $rules; } }