user(); return $user->can('edit', $this->client); } public function rules() { /* Ensure we have a client name, and that all emails are unique*/ /** @var \App\Models\User $user */ $user = auth()->user(); if ($this->file('documents') && is_array($this->file('documents'))) { $rules['documents.*'] = $this->fileValidation(); } elseif ($this->file('documents')) { $rules['documents'] = $this->fileValidation(); } if ($this->file('file') && is_array($this->file('file'))) { $rules['file.*'] = $this->fileValidation(); } elseif ($this->file('file')) { $rules['file'] = $this->fileValidation(); } else { $rules['documents'] = 'bail|sometimes|array'; } $rules['company_logo'] = 'mimes:jpeg,jpg,png,gif|max:10000'; $rules['industry_id'] = 'integer|nullable'; $rules['size_id'] = 'integer|nullable'; $rules['country_id'] = 'integer|nullable|exists:countries,id'; $rules['shipping_country_id'] = 'integer|nullable|exists:countries,id'; $rules['classification'] = 'bail|sometimes|nullable|in:individual,business,company,partnership,trust,charity,government,other'; $rules['id_number'] = ['sometimes', 'bail', 'nullable', Rule::unique('clients')->where('company_id', $user->company()->id)->ignore($this->client->id)]; $rules['number'] = ['sometimes', 'bail', Rule::unique('clients')->where('company_id', $user->company()->id)->ignore($this->client->id)]; $rules['settings'] = new ValidClientGroupSettingsRule(); $rules['contacts'] = 'array'; $rules['contacts.*.email'] = 'bail|nullable|distinct|sometimes|email'; $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 ]; return $rules; } public function messages() { return [ 'email' => ctrans('validation.email', ['attribute' => 'email']), 'name.required' => ctrans('validation.required', ['attribute' => 'name']), 'required' => ctrans('validation.required', ['attribute' => 'email']), 'contacts.*.password.min' => ctrans('texts.password_strength'), 'contacts.*.password.regex' => ctrans('texts.password_strength'), 'contacts.*.password.string' => ctrans('texts.password_strength'), ]; } public function prepareForValidation() { $input = $this->all(); /** @var \App\Models\User $user */ $user = auth()->user(); /* If the user removes the currency we must always set the default */ if (array_key_exists('settings', $input) && ! array_key_exists('currency_id', $input['settings'])) { $input['settings']['currency_id'] = (string) $user->company()->settings->currency_id; } elseif (empty($input['settings']['currency_id']) ?? true) { $input['settings']['currency_id'] = (string) $user->company()->settings->currency_id; } if (isset($input['language_code'])) { $input['settings']['language_id'] = $this->getLanguageId($input['language_code']); } $input = $this->decodePrimaryKeys($input); if (array_key_exists('settings', $input)) { $input['settings'] = $this->filterSaveableSettings($input['settings']); } if (array_key_exists('name', $input)) { $input['name'] = strip_tags($input['name']); } // allow setting country_id by iso code if (isset($input['country_code'])) { $input['country_id'] = $this->getCountryCode($input['country_code']); } // allow setting country_id by iso code if (isset($input['shipping_country_code'])) { $input['shipping_country_id'] = $this->getCountryCode($input['shipping_country_code']); } $this->replace($input); } 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(); if ($country) { return (string) $country->id; } return ''; } private function getLanguageId($language_code) { $languages = Cache::get('languages'); $language = $languages->filter(function ($item) use ($language_code) { return $item->locale == $language_code; })->first(); if ($language) { return (string) $language->id; } return ''; } /** * For the hosted platform, we restrict the feature settings. * * This method will trim the company settings object * down to the free plan setting properties which * are saveable * * @param \stdClass $settings * @return \stdClass $settings */ private function filterSaveableSettings($settings) { $account = $this->client->company->account; if (! $account->isFreeHostedClient()) { return $settings; } $saveable_casts = CompanySettings::$free_plan_casts; foreach ($settings as $key => $value) { if (! array_key_exists($key, $saveable_casts)) { unset($settings->{$key}); } //26-04-2022 - In case settings are returned as array instead of object if ($key == 'default_task_rate' && is_array($settings)) { $settings['default_task_rate'] = floatval($value); } elseif ($key == 'default_task_rate' && is_object($settings)) { $settings->default_task_rate = floatval($value); } } return $settings; } }