72 lines
2.2 KiB
PHP
72 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Requests\Auth;
|
|
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
|
|
class User extends FormRequest
|
|
{
|
|
/**
|
|
* Determine if the user is authorized to make this request.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function authorize()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Get the validation rules that apply to the request.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function rules()
|
|
{
|
|
$picture = 'nullable';
|
|
|
|
if ($this->files->get('picture')) {
|
|
$picture = 'mimes:' . config('filesystems.mimes') . '|between:0,' . config('filesystems.max_size') * 1024 . '|dimensions:max_width=1000,max_height=1000';
|
|
}
|
|
|
|
$email = 'required|email:rfc,dns';
|
|
|
|
if ($this->getMethod() == 'PATCH') {
|
|
// Updating user
|
|
$id = is_numeric($this->user) ? $this->user : $this->user->getAttribute('id');
|
|
$companies = $this->user->can('read-common-companies') ? 'required' : '';
|
|
$roles = $this->user->can('read-auth-roles') ? 'required|string' : '';
|
|
|
|
if ($this->user->contact) {
|
|
$email .= '|unique:contacts,NULL,'
|
|
. $this->user->contact->id . ',id'
|
|
. ',company_id,' . company_id()
|
|
. ',type,customer'
|
|
. ',deleted_at,NULL';
|
|
}
|
|
} else {
|
|
// Creating user
|
|
$id = null;
|
|
$companies = 'required';
|
|
$roles = 'required|string';
|
|
}
|
|
|
|
$email .= '|unique:users,email,' . $id . ',id,deleted_at,NULL';
|
|
|
|
$change_password = $this->request->get('change_password') == true || $this->request->get('change_password') != null;
|
|
|
|
$current_password = $change_password ? '|current_password' : '';
|
|
$password = $change_password ? '|confirmed' : '';
|
|
|
|
return [
|
|
'name' => 'required|string',
|
|
'email' => $email,
|
|
'current_password' => 'required_if:change_password,true' . $current_password,
|
|
'password' => 'required_if:change_password,true' . $password,
|
|
'companies' => $companies,
|
|
'roles' => $roles,
|
|
'picture' => $picture,
|
|
];
|
|
}
|
|
}
|