authorize(); // Do not reset password if not entered/changed if (empty($this->request['password'])) { unset($this->request['current_password']); unset($this->request['password']); unset($this->request['password_confirmation']); } event(new UserUpdating($this->model, $this->request)); \DB::transaction(function () { $this->model->update($this->request->input()); // Upload picture if ($this->request->file('picture')) { $this->deleteMediaModel($this->model, 'picture', $this->request); $media = $this->getMedia($this->request->file('picture'), 'users'); $this->model->attachMedia($media, 'picture'); } elseif (! $this->request->file('picture') && $this->model->picture) { $this->deleteMediaModel($this->model, 'picture', $this->request); } if ($this->request->has('roles')) { $this->model->roles()->sync($this->request->get('roles')); } if ($this->request->has('companies')) { if (app()->runningInConsole() || request()->isInstall()) { $sync = $this->model->companies()->sync($this->request->get('companies')); } else { $user = user(); $companies = $user->withoutEvents(function () use ($user) { return $user->companies()->whereIn('id', $this->request->get('companies'))->pluck('id'); }); if ($companies->isNotEmpty()) { $sync = $this->model->companies()->sync($companies->toArray()); } } } if ($this->model->contact) { $this->model->contact->update($this->request->input()); } if (isset($sync) && !empty($sync['attached'])) { foreach ($sync['attached'] as $id) { $company = Company::find($id); Artisan::call('user:seed', [ 'user' => $this->model->id, 'company' => $company->id, ]); } } }); event(new UserUpdated($this->model, $this->request)); return $this->model; } /** * Determine if this action is applicable. */ public function authorize(): void { // Can't disable yourself if (($this->request->get('enabled', 1) == 0) && ($this->model->id == user()->id)) { $message = trans('auth.error.self_disable'); throw new \Exception($message); } // Can't unassigned company, The company must be assigned at least one user. if ($this->request->has('companies')) { $companies = (array) $this->request->get('companies', []); $user_companies = $this->model->companies()->pluck('id')->toArray(); $company_diff = array_diff($user_companies, $companies); if ($company_diff) { $errors = []; foreach ($company_diff as $company_id) { $company = Company::withCount('users')->find($company_id); if ($company->users_count < 2) { $errors[] = trans('auth.error.unassigned', ['company' => $company->name]); } } if ($errors) { $message = implode('\n', $errors); throw new \Exception($message); } } } } }