user()->can('create', Client::class); } public function rules() { if ($this->input('documents') && is_array($this->input('documents'))) { $documents = count($this->input('documents')); foreach (range(0, $documents) as $index) { $rules['documents.' . $index] = 'file|mimes:png,ai,svg,jpeg,tiff,pdf,gif,psd,txt,doc,xls,ppt,xlsx,docx,pptx|max:20000'; } } elseif ($this->input('documents')) { $rules['documents'] = 'file|mimes:png,ai,svg,jpeg,tiff,pdf,gif,psd,txt,doc,xls,ppt,xlsx,docx,pptx|max:20000'; } /* 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 ]; if(auth()->user()->company()->account->isFreeHostedClient()) $rules['hosted_clients'] = new CanStoreClientsRule($this->company_id); 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; } } if (array_key_exists('assigned_user_id', $input) && is_string($input['assigned_user_id'])) { $input['assigned_user_id'] = $this->decodePrimaryKey($input['assigned_user_id']); } //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; } if (isset($input['currency_code'])) { $settings->currency_id = $this->getCurrencyCode($input['currency_code']); } $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']); } } } } } if(isset($input['country_code'])) { $input['country_id'] = $this->getCountryCode($input['country_code']); } if(isset($input['shipping_country_code'])) { $input['shipping_country_id'] = $this->getCountryCode($input['shipping_country_code']); } $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']), ]; } private function getCountryCode($country_code) { $countries = Cache::get('countries'); $country = $countries->filter(function ($item) use($country_code) { return $item->iso_3166_2 == $country_code || $item->iso_3166_3 == $country_code; })->first(); return (string) $country->id; } private function getCurrencyCode($code) { $currencies = Cache::get('currencies'); $currency = $currencies->filter(function ($item) use($code){ return $item->code == $code; })->first(); return (string) $currency->id; } }