72 lines
2.0 KiB
PHP
72 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Requests\Common;
|
|
|
|
use App\Abstracts\Http\FormRequest;
|
|
use Illuminate\Validation\Rule;
|
|
|
|
class Contact 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()
|
|
{
|
|
$email = [];
|
|
$required = '';
|
|
|
|
$type = $this->request->get('type', 'customer');
|
|
$company_id = $this->request->get('company_id');
|
|
|
|
// Check if store or update
|
|
if ($this->getMethod() == 'PATCH') {
|
|
$model = $this->isApi() ? 'contact' : $type;
|
|
|
|
$id = is_numeric($this->$model) ? $this->$model : $this->$model->getAttribute('id');
|
|
} else {
|
|
$id = null;
|
|
}
|
|
|
|
if (($this->request->get('create_user', 'false') === 'true') && empty($this->request->get('user_id'))) {
|
|
$required = 'required|';
|
|
}
|
|
|
|
if (!empty($this->request->get('email'))) {
|
|
$email[] = 'email';
|
|
$email[] = Rule::unique('contacts')
|
|
->ignore($id)
|
|
->where('company_id', $company_id)
|
|
->where('type', $type)
|
|
->where('deleted_at');
|
|
|
|
if (isset($model) && $this->$model->user_id) {
|
|
$email[] = Rule::unique('users')
|
|
->ignore($this->$model->user_id)
|
|
->where('deleted_at');
|
|
}
|
|
}
|
|
|
|
return [
|
|
'type' => 'required|string',
|
|
'name' => 'required|string',
|
|
'email' => $email,
|
|
'user_id' => 'integer|nullable',
|
|
'currency_code' => 'required|string|currency',
|
|
'password' => $required . 'confirmed',
|
|
'enabled' => 'integer|boolean',
|
|
];
|
|
}
|
|
}
|