reportify_mncl/app/Http/Requests/User/UpdateUserRequest.php
2025-05-13 15:03:09 +02:00

49 lines
1.3 KiB
PHP

<?php
namespace Vanguard\Http\Requests\User;
use Illuminate\Validation\Rule;
use Vanguard\Http\Requests\Request;
use Vanguard\Support\Enum\UserStatus;
use Vanguard\User;
class UpdateUserRequest extends Request
{
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
$user = $this->user();
return [
'email' => 'email|unique:users,email,' . $user->id,
'username' => 'nullable|unique:users,username,' . $user->id,
'password' => [
'nullable',
'confirmed',
'min:8',
'regex:/^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/'
],
'birthday' => 'nullable|date',
'role_id' => 'exists:roles,id',
'country_id' => 'exists:countries,id',
'status' => Rule::in(array_keys(UserStatus::lists()))
];
}
/**
* Get custom messages for validator errors.
*
* @return array
*/
public function messages()
{
return [
'password.regex' => __('The password must be at least 8 characters long and contain at least one number and one special character (@$!%*?&).')
];
}
}