Files
panel-pelican-dev/app/Http/Requests/Api/Client/Account/UpdatePasswordRequest.php

38 lines
1.0 KiB
PHP
Raw Permalink Normal View History

2018-06-17 16:53:24 -07:00
<?php
2024-03-12 22:39:16 -04:00
namespace App\Http\Requests\Api\Client\Account;
2018-06-17 16:53:24 -07:00
2025-09-24 13:34:19 +02:00
use App\Exceptions\Http\Base\InvalidPasswordProvidedException;
use App\Http\Requests\Api\Client\ClientApiRequest;
use Illuminate\Container\Container;
use Illuminate\Contracts\Hashing\Hasher;
2018-06-17 16:53:24 -07:00
class UpdatePasswordRequest extends ClientApiRequest
{
/**
* @throws InvalidPasswordProvidedException
2018-06-17 16:53:24 -07:00
*/
public function authorize(): bool
{
2021-01-23 12:33:34 -08:00
if (!parent::authorize()) {
2018-06-17 16:53:24 -07:00
return false;
}
$hasher = Container::getInstance()->make(Hasher::class);
2018-06-17 16:53:24 -07:00
// Verify password matches when changing password or email.
if (!$hasher->check($this->input('current_password'), $this->user()->password)) {
2018-07-15 11:44:18 -07:00
throw new InvalidPasswordProvidedException(trans('validation.internal.invalid_password'));
2018-06-17 16:53:24 -07:00
}
return !$this->user()->is_managed_externally;
2018-06-17 16:53:24 -07:00
}
public function rules(): array
{
return [
'password' => ['required', 'string', 'confirmed', 'min:8'],
];
2018-06-17 16:53:24 -07:00
}
}