user()->can('create', Client::class); } public function rules() { /* Ensure we have a client name, and that all emails are unique*/ //$rules['name'] = 'required|min:1'; $rules['id_number'] = 'unique:clients,id_number,' . $this->id . ',id,company_id,' . $this->company_id; $rules['settings'] = new ValidClientGroupSettingsRule(); $rules['contacts.*.email'] = 'nullable|distinct'; $rules['contacts.*.password'] = [ 'nullable', 'sometimes', 'string', 'min:7', // must be at least 10 characters in length 'regex:/[a-z]/', // must contain at least one lowercase letter 'regex:/[A-Z]/', // must contain at least one uppercase letter 'regex:/[0-9]/', // must contain at least one digit //'regex:/[@$!%*#?&.]/', // must contain a special character ]; // $contacts = request('contacts'); // if (is_array($contacts)) { // for ($i = 0; $i < count($contacts); $i++) { // //$rules['contacts.' . $i . '.email'] = 'nullable|email|distinct'; // } // } return $rules; } protected function prepareForValidation() { $input = $this->all(); //@todo implement feature permissions for > 100 clients // $settings = ClientSettings::defaults(); if (array_key_exists('settings', $input) && !empty($input['settings'])) { foreach ($input['settings'] as $key => $value) { $settings->{$key} = $value; } } //is no settings->currency_id is set then lets dive in and find either a group or company currency all the below may be redundant!! if (!property_exists($settings, 'currency_id') && isset($input['group_settings_id'])) { $input['group_settings_id'] = $this->decodePrimaryKey($input['group_settings_id']); $group_settings = GroupSetting::find($input['group_settings_id']); if ($group_settings && property_exists($group_settings->settings, 'currency_id') && isset($group_settings->settings->currency_id)) { $settings->currency_id = (string)$group_settings->settings->currency_id; } else { $settings->currency_id = (string)auth()->user()->company()->settings->currency_id; } } elseif (!property_exists($settings, 'currency_id')) { $settings->currency_id = (string)auth()->user()->company()->settings->currency_id; } $input['settings'] = $settings; if (isset($input['contacts'])) { foreach ($input['contacts'] as $key => $contact) { if (array_key_exists('id', $contact) && is_numeric($contact['id'])) { unset($input['contacts'][$key]['id']); } elseif (array_key_exists('id', $contact) && is_string($contact['id'])) { $input['contacts'][$key]['id'] = $this->decodePrimaryKey($contact['id']); } //Filter the client contact password - if it is sent with ***** we should ignore it! if (isset($contact['password'])) { if (strlen($contact['password']) == 0) { $input['contacts'][$key]['password'] = ''; } else { $contact['password'] = str_replace("*", "", $contact['password']); if (strlen($contact['password']) == 0) { unset($input['contacts'][$key]['password']); } } } } } $this->replace($input); } public function messages() { return [ 'unique' => ctrans('validation.unique', ['attribute' => 'email']), //'required' => trans('validation.required', ['attribute' => 'email']), 'contacts.*.email.required' => ctrans('validation.email', ['attribute' => 'email']), ]; } }